springMVC常用注解

RequestParam:

  作用:
    把请求中指定名称的参数给控制器中的形参赋值。还可以解决请求参数名称和控制器方法参数不一致不能封装的问题
  属性:
    value:请求参数中的名称。
    required:请求参数中是否必须提供此参数。默认值:true。表示必须提供,如果不提供将报错。

    defaultValue:如果不传值,可以使用默认值

@RequestMapping("/useRequestParam")
public String useRequestParam(@RequestParam("name")String username, @RequestParam(name="age",required=false)Integer age){
  System.out.println(username+","+age);
  return "success";
}

InitBinder:

  作用:

    对WebDataBinder初始化,webDataBinder是用于表单到方法的数据绑定的!

    @InitBinder只在@Controller中注解方法来为这个控制器注册一个绑定器初始化方法,方法只对本控制器有效。

  对数据绑定进行设置:

    WebDataBinder中有很多方法可以对数据绑定进行具体的设置:比如我们设置name属性为非绑定属性(也可以设置绑定值setAllowedFields),

    在Controller中添加一个方法:

@InitBinder
public void initBinder(WebDataBinder binder) {
    binder.setDisallowedFields("name");
}

  注册已有的编辑器:

    WebDataBinder是用来绑定请求参数到指定的属性编辑器.由于前台传到controller里的值是String类型的,当往Model里Set这个值的时候,如果set的这个属性是个对象,Spring就会去找到对应的editor进行转换,然后再set进去!Spring自己提供了大量的实现类(如下图所示的在org.springframwork.beans.propertyEditors下的所有editor),诸如CustomDateEditor ,CustomBooleanEditor,CustomNumberEditor等许多,基本上够用。  在平时使用SpringMVC时,会碰到javabean中有Date类型参数,表单中传来代表日期的字符串转化为日期类型,SpringMVC默认不支持这种类型的转换。我们就需要手动设置时间格式并在webDateBinder上注册这个编辑器!

    

    

  如果仅仅是做日期类型转换可以在实体类中使用@DataTimeFormat :

    

ControllerAdvice:相对于@InitBinder注解单独在方法上使用只对所在的控制器有效,配合@ControllerAdvice注解使用表示对所有控制进行增强

  

RequestBody:

  作用:
    用于获取请求体内容。直接使用得到的是 key=value&key=value...结构的数据。
    get 请求(没有请求体)方式不适用。

    接收的请求参数是 json 格式数据时使用
  属性:
    required:是否必须有请求体。默认值是:true。当取值为 true 时,get 请求方式会报错。如果取值为 false,get 请求得到是 null。

@RequestMapping("/useRequestBody")
public String useRequestBody(@RequestBody(required=false) String body){
  System.out.println(body);
  return "success";
}

PathVaribale:

  作用:
    用于绑定 url 中的占位符。例如:请求 url 中 /delete/{id},这个 {id} 就是 url 占位符。
    url 支持占位符是 spring3.0 之后加入的,是 springmvc 支持 rest 风格 URL 的一个重要标志。
  属性:
    value:用于指定 url 中占位符名称。
    required:是否必须提供占位符。

  

@RequestMapping("/usePathVariable/{id}")
public String usePathVariable(@PathVariable("id") Integer id){
  System.out.println(id);
  return "success";
}

RequestHeader:

  作用:
    用于获取请求消息头。
  属性:
    value / name:提供消息头名称
    required:是否必须有此消息头

    defaultValue:如果没有指定的消息头,使用此默认值

@RequestMapping("/useRequestHeader")
public String useRequestHeader(@RequestHeader(value="Accept-Language", required=false)String requestHeader){
  System.out.println(requestHeader);
  return "success";
}

CookieValue:

  作用:
    用于把指定 cookie 名称的值传入控制器方法参数。
  属性:
    value:指定 cookie 的名称。
    required:是否必须有此 cookie。

    defaultValue:如果没有指定的cookie,使用此默认值

@RequestMapping("/useCookieValue")
public String useCookieValue(@CookieValue(value="JSESSIONID",required=false)String cookieValue){
  System.out.println(cookieValue);
  return "success";
}

ModelAttribute:

  作用:
    该注解是 SpringMVC4.3 版本以后新加入的。它可以用于修饰方法和参数。
    出现在方法上,表示当前方法会在控制器的方法执行之前,先执行。它可以修饰没有返回值的方法,也可以修饰有具体返回值的方法。
    出现在参数上,获取指定的数据给参数赋值。
  属性:
    value:用于获取数据的 key。key 可以是 POJO 的属性名称,也可以是 map 结构的 key。
  应用场景:
    当表单提交数据不是完整的实体类数据时,保证没有提交数据的字段使用数据库对象原来的数据。
    例如:
      我们在编辑一个用户时,用户有一个创建信息字段,该字段的值是不允许被修改的。

      在提交表单数据是肯定没有此字段的内容,一旦更新会把该字段内容置为 null,此时就可以使用此注解解决问题。

  具体用法:

    1. 修饰的方法有返回值

/**
* 作用在方法,先执行
* @param user
* @return
*/
@ModelAttribute("user")
public User showUser(User user) {
  System.out.println("showUser执行了...");
  // 模拟从数据库中查询对象
  User u = new User();
  user.setName(u.getName);
  return user;
}
/**
* 修改用户的方法
* @param user
* @return
*/
@RequestMapping(path="/updateUser")
public String updateUser(@ModelAttribute("user") User user) {
  System.out.println(user);
  return "success";
}

    2. 修饰的方法没有返回值

/**
* 作用在方法,先执行
* @param name
* @return
*/
@ModelAttribute
public void showUser(String name,Map<String, User> map) {
  System.out.println("showUser执行了...");
  // 模拟从数据库中查询对象
  User user = new User();
  user.setName(name);
  map.put("abc", user);
}
/**
* 修改用户的方法
* @param cookieValue
* @return
*/@RequestMapping(path="/updateUser")
public String updateUser(@ModelAttribute(value="abc") User user) {
  System.out.println(user);
  return "success";
}

CrossOrigin:

  作用:

    用于指定是否支持跨域访问,可以用在接口、类和方法上

SessionAttributes:

  作用:
    表示往session域中存入数据,同时请求域中也会存一份
  属性:
    value:用于指定存入的属性名称
    type:用于指定存入的数据类型

  

@Controller
@RequestMapping(path="/user")
@SessionAttributes(value= {"username","password","age"},types=
  {String.class,String.class,Integer.class}) // 把数据存入到session域对象中
public class HelloController {
  /**
  * 向session中存入值
  * @return
  */
  @RequestMapping(path="/save")
  public String save(Model model) { // ModelMap modelMap
    System.out.println("向session域中保存数据");
    model.addAttribute("username", "root");
    model.addAttribute("password", "123");
    model.addAttribute("age", 20);
    return "success";
  }
}

SessionAttribute:

  作用:
    表示从session域中取出数据

  

 清除 session 域中的值:

/**
  * 清除值
  * @return
  */
  @RequestMapping(path="/delete")
  public String delete(SessionStatus status) {
    status.setComplete();
    return "success";
  }

 

posted @ 2020-02-15 02:25  糖不甜,盐不咸  阅读(236)  评论(0编辑  收藏  举报