SpringMvc的常用注解
@RequestMapping()
SpringMvc通过@RequestMapping注解将URL请求与业务的方法进行映射,在控制器的类定义处定义方法处都可以添加@RequestMapping,在类定义处添加相当于多了一层访问路径。
- value :指定URL请求的地址,是@RequestMapping的默认值。
- method:请求的method类型包括 GET POST PUT DELETE
- params 请求的参数
• @Controller
public class HellowHandler {
@RequestMapping (value = "/index",params = {"id=1","name=tom"})
public String index(){
System.out.println("接受到了请求");
//返回逻辑视图
return "index";
}
}
参数绑定
params是对URL请求参数进行限制,不满足的URL不能访问,需要在业务方法中获取URL的参数值。
1.在业务方法定义时声明参数列表
2.给参数列表添加@RequsetParam 注解进行绑定
@Controller
public class HellowHandler {
@RequestMapping (value = "/index",params = {"id"})
public String index(@RequestParam("id") double id){
System.out.println("接受到了请求"+"id="+id);
//返回逻辑视图
return "index";
}
}
Springmvc也支持RESTful风格的URL传参
@RequestMapping (value = "/index/{id}")
public String index1(@PathVariable("id") double id){
System.out.println("接受到了请求"+"id="+id);
//返回逻辑视图
return "index";
}
映射Cookie
@RequestMapping (value = "/Cookie")
public String index2(@CookieValue("JSESSIONID") String session){
System.out.println("接受到了请求"+"session="+session);
//返回逻辑视图
return "index";
}
使用POJO绑定参数
Springmvc会自动更据请求参数与POJO的属性名匹配,自动为该对象填充属性值,并支持属性级联。
乱码
<!-- 过滤器-->
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
User:
package com.southwind.entity;
import lombok.Data;
@Data
public class User {
private Integer id;
private String name;
private Address address;
}
Address;
package com.southwind.entity;
import lombok.Data;
@Data
public class Address {
private Integer code;
private String name;
}
jsp:
<%--
Created by IntelliJ IDEA.
User: 郝泾钊
Date: 2022-04-06
Time: 17:34
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<form action="/add">
<table>
<tr>
<td>编号:</td>
<td>
<input type="text" name="id">
</td>
</tr>
<tr>
<td>姓名:</td>
<td>
<input type="text" name="name">
</td>
</tr>
<tr>
<td>地址编号:</td>
<td>
<input type="text" name="address.code">
</td>
</tr>
<tr>
<td>地址信息:</td>
<td>
<input type="text" name="address.name">
</td>
</tr>
<tr>
<td>
<input type="submit" value="提交">
</td>
</tr>
</table>
</form>
</body>
</html>
controller:
@RequestMapping("/add")
public String add(User user){
System.out.println(user);
return "addUser";
}
JSP页面的转发和重定向
转发是服务器行为,重定向是客户端行为。转发耗时比重定向少。
转发——>客户浏览器发送HTTP请求——>web服务器接受请求——>调用内部一个方法在容器内部完成请求处理和转发动作——>再将转发跳转到的那个网页资源返回给客户; 转发只能在同一个容器内完成 转发的时候浏览器地址是不会变的,在客户浏览器里只会显示第一次进入的那个网址或者路径,客户看不到这个过程,只是得到了想要的目标资源。转发行为浏览器只做了一次请求。(转发只能跳转一次)
重定向——>客户浏览器发送HTTP请求——>web服务器接受请求后发送302状态码以及新的位置给客户浏览器——>客户浏览器发现是302响应,则自动再发送一个新的HTTP请求,请求指向新的地址(302:Found 临时移动,但资源只是临时被移动。即你访问网址A,但是网址A因为服务器端的拦截器或者其他后端代码处理的原因,会被重定向到网址B。)——>服务器根据此请求寻找资源发个客户;再客户浏览器中显示的是重定向之后的路径,客户可以看到地址的变化。重定向行为浏览器做了至少两次请求。(重定向可以跳转多次
SpringMVC默认是以转发,(地址栏没有改变0
重定向:redirect
@RequestMapping("/add")
public String add(User user){
System.out.println(user);
return "redirect:/addUser.jsp";
}
转发;forward