SpringMVC-02(常用注解)
SpringMVC-02(常用注解)
1.RequestMapping注解
- 作用:建立请求URL和处理方法之间的对应关系
- 可以作用在方法和类上
- 作用在类上:第一级的访问目录
- 作用在方法上:第二级的访问目录
- 细节:路径可以不编写
/表示应用的根目录开始 - 细节:
${pageContext.request.contextPath}也可以省略不写,但是路径上不能写/
- RequestMapping的属性
- path:指定请求路径的url
- value:value属性和path属性是一样的
- mthod:指定该方法的请求方式
- params:指定限制请求参数的条件
- headers:发送的请求中必须包含的请求头
2.RequestParam注解
- 作用:把请求中的指定名称的参数传递给控制器中的形参赋值
- 属性
- value:请求参数中的名称
- required:请求参数中是否必须提供此参数,默认值是true,必须提供
- 代码:
/**
* 接收请求
* @return
*/
@RequestMapping(path="/hello")
public String sayHello(@RequestParam(value="username",required=false)String name) {
System.out.println("aaaa");
System.out.println(name);
return "success";
}
3.RequestBody注解
- 作用:
用于获取请求体的内容。直接使用得到是key=value&key=value...结构的数据。
get请求方法不适用。 - 属性:
- required:是否必须有请求体。
- 默认值是:true。当取值为true时,get请求方式会报错。如果取值为false,get请求得到是null。
- 代码:
/**
* 接收请求
* @return
*/
@RequestMapping(path="/hello")
public String sayHello(@RequestBody String body) {
System.out.println("aaaa");
System.out.println(body);
return "success";
}
4.PathVariable注解
- 作用:
- 用于绑定url中的占位符的。例如:请求url中
/delete/{id},这个{id}就是url占位符。 - url支持占位符是spring3.0之后加入的。是springmvc支持rest风格URL的一个重要标志。
- 用于绑定url中的占位符的。例如:请求url中
- 属性:
- value:用于指定url中占位符名称。
- required:是否必须提供占位符。
- Restful风格的URL
- 请求路径一样,可以根据不同的请求方式去执行后台的不同方法
- restful风格的URL优点
- 结构清晰
- 符合标准
- 易于理解
- 扩展方便
- 代码:
<a href="user/hello/1">入门案例</a>
/**
* 接收请求
* @return
*/
@RequestMapping(path="/hello/{id}")
public String sayHello(@PathVariable(value="id") String id) {
System.out.println(id);
return "success";
}
5.RequestHeader注解(实际开发中一般不怎么用)
- 作用:用于获取请求消息头。
- 属性:
- value:提供消息头名称
- required:是否必须有此消息头
- 代码:
@RequestMapping(path="/hello")
public String sayHello(@RequestHeader(value="Accept") String header) {
System.out.println(header);
return "success";
}
6.CookieValue注解
- 作用:用于把指定cookie名称的值传入控制器方法参数
- 属性:
- value:指定cookie的名称
- required:是否必须有此cookie。
- 代码:
@RequestMapping(path="/hello")
public String sayHello(@CookieValue(value="JSESSIONID") String cookieValue) {
System.out.println(cookieValue);
return "success";
}
7.ModelAttribute注解
-
作用:该注解时SpringMVC4.3版本以后新加入的。它可以用于修饰方法和参数。
- 出现在方法上:表示当前方法会在控制器的方法执行之前,先执行。它可以修饰没有返回值的方法,也可以修饰有具体返回值的方法。
- 出现在参数上,获取指定的数据给参数赋值。
-
属性:
- value:用于获取数据的key。key可以时POJO的属性名称,也可以时map结构的key。
-
应用场景:当表单提交数据不是完整的实体类数据时,保证没有提交数据的字段使用数据库对象原来的数据。
-
代码:
- 修饰的方法有返回值
/** * 作用在方法,先执行 * @param name * @return */ @ModelAttribute public User showUser(String name) { System.out.println("showUser执行了..."); // 模拟从数据库中查询对象 User user = new User(); user.setName("哈哈"); user.setPassword("123"); user.setMoney(100d); return user; } /** * 修改用户的方法 * @param cookieValue * @return */ @RequestMapping(path="/updateUser") public String updateUser(User user) { System.out.println(user); return "success"; }- 修饰的方法没有返回值
/** * 作用在方法,先执行 * @param name * @return */ @ModelAttribute public void showUser(String name,Map<String, User> map) { System.out.println("showUser执行了..."); // 模拟从数据库中查询对象 User user = new User(); user.setName("哈哈"); user.setPassword("123"); user.setMoney(100d); map.put("abc", user); } /** * 修改用户的方法 * @param cookieValue * @return */ @RequestMapping(path="/updateUser") public String updateUser(@ModelAttribute(value="abc") User user) { System.out.println(user); return "success"; }
8.SessionAttributes注解
- 作用:用于多次执行控制器方法间的参数共享。
- 属性:
- value:用于指定存入的属性名称
- type:用于指定存入的数据类型
- 代码:
@Controller
@RequestMapping(path="/user")
@SessionAttributes(value= {"username","password","age"},types=
{String.class,Integer.class}) // 把数据存入到session域对象中
public class HelloController {
/**
* 向session中存入值
* @return
*/
@RequestMapping(path="/save")
public String save(Model model) {
System.out.println("向session域中保存数据");
model.addAttribute("username", "root");
model.addAttribute("password", "123");
model.addAttribute("age", 20);
return "success";
}
/**
* 从session中获取值
* @return
*/
@RequestMapping(path="/find")
public String find(ModelMap modelMap) {
String username = (String) modelMap.get("username");
String password = (String) modelMap.get("password");
Integer age = (Integer) modelMap.get("age");
System.out.println(username + " : "+password +" : "+age);
return "success";
}
/**
* 清除值
* @return
*/
@RequestMapping(path="/delete")
public String delete(SessionStatus status) {
status.setComplete();
return "success";
}
}
浙公网安备 33010602011771号