springmvc常用注解

RequestParam注解

  1. 作用:把请求中的指定名称的参数传递给控制器中的形参赋值
  2. 属性
    1. value:请求参数中的名称
    2. required:请求参数中是否必须提供此参数,默认值是true,必须提供
  3. 代码如下
    @RequestMapping("/testRequestParam")
    //                         会把name的值赋值给username
    public String testRequestParam(@RequestParam(name="name",required = false) String username){
        System.out.println("testRequestParam 执行了");
        System.out.println(username);
        return "success";
    }

RequestBody注解

  1. 作用:用于获取请求体的内容(注意:get方法不可以)
  2. 属性
    1. required:是否必须有请求体,默认值是true
    @RequestMapping("/testRequestBody")
    public String testRequestBody(@RequestBody String body){
        System.out.println(body);
        return "success";
    }

PathVariable注解

  1. 作用:拥有绑定url中的占位符的。例如:url中有/delete/{id},{id}就是占位符
  2. 属性
    1. value:指定url中的占位符名称
  3. Restful风格的URL
    1. 请求路径一样,可以根据不同的请求方式去执行后台的不同方法
    2. restful风格的URL优点
      1. 结构清晰
      2. 符合标准
      3. 易于理解
      4. 扩展方便
  4. 代码如下
 @RequestMapping("/testPathVariable/{id}")
 public String testPathVariable(@PathVariable(value="id") String id){
     System.out.println(id);
     return "success";
 }

RequestHeader注解

  1. 作用:获取指定请求头的值
  2. 属性
    1. value:请求头的名称
  3. 代码如下
 @RequestMapping("/testRequestHeader")
 public String testRequestHeader(@RequestHeader(value = "Accept") String header) {
     System.out.println(header);
     return "success";
 }

CookieValue注解

  1. 作用:用于获取指定cookie的名称的值
  2. 属性
    1. value:cookie的名称
  3. 代码
    @RequestMapping("/testCookieValue")
    public String testCookieValue(@CookieValue(value = "JSESSIONID") String cookieValue) {
        System.out.println(cookieValue);
        return "success";
    }

ModelAttribute注解

  1. 作用
    1. 出现在方法上:表示当前方法会在控制器方法执行前线执行。
    2. 出现在参数上:获取指定的数据给参数赋值。
  2. 应用场景
    1. 当提交表单数据不是完整的实体数据时,保证没有提交的字段使用数据库原来的数据。
  3. 具体的代码

修饰的方法有返回值

/**
     * testModelAttribute 注解
     * @return
     */
    @RequestMapping("/testModelAttribute")
    public String testModelAttribute(User user) {
        System.out.println("testModelAttribute,执行了");
        System.out.println(user);
        return "success";
    }
    
    //该方法先执行
    @ModelAttribute
    public User showUser(String uname){
        System.out.println("showUser,执行了");
        //通过用户名查询数据库(...)
        User user=new User();
        user.setUname(uname);
        user.setAge(20);
        user.setDate(new Date());
        return user;
    }

修饰的方法没有返回值

    @ModelAttribute
    public void showUser(String uname, Map<String,User> map){
        System.out.println("showUser,执行了");
        //通过用户名查询数据库(...)
        User user=new User();
        user.setUname(uname);
        user.setAge(20);
        user.setDate(new Date());
        map.put("aaa",user);
    }

    /**
     * testModelAttribute 注解
     * @return
     */
    @RequestMapping("/testModelAttribute")
    public String testModelAttribute(@ModelAttribute(value = "aaa") User user) {
        System.out.println("testModelAttribute,执行了");
        System.out.println(user);
        return "success";
    }

SessionAttributes注解

  1. 作用:用于多次执行控制器方法间的参数共享
  2. 属性
    1. value:指定存入属性的名称
  3. 代码如下
     //@SessionAttributes(value = {"msg"}) 在类上 注解 表示把msg存到session中

    /**
     * SessionAttributes
     * @return
     */
    @RequestMapping("/testSessionAttributes")
    public String testSessionAttributes(Model model) {
        System.out.println("testSessionAttributes,执行了");
        model.addAttribute("msg","this is msg");
        return "success";
    }

    /**
     * 获取SessionAttributes
     * @param model
     * @return
     */
    @RequestMapping("/getSessionAttributes")
    public String getSessionAttributes(ModelMap modelMap) {
        System.out.println("getSessionAttributes,执行了");
        String msg = (String) modelMap.get("msg");
        System.out.println(msg);
        return "success";
    }
    @RequestMapping("/delSessionAttributes")
    public String delSessionAttributes(SessionStatus status) {
        System.out.println("delSessionAttributes,执行了");
        status.setComplete();
        return "success";
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值