zoukankan      html  css  js  c++  java
  • Spring 常用注解 ***

    @Controller

      在SpringMVC 中,控制器Controller负责处理由DispatcherServlet分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model,然后再把该Model返回给对应的View进行展示。

      在SpringMVC中,你无需继承特定的类或实现特定的接口,只需使用 @Controller标记一个类是Controller,然后使用 @RequestMapping和 @RequestParam等一些注解用以定义URL请求和Controller方法之间的映射,这样的Controller就能被外界访问到。此外Controller不会直接依赖于HttpServletRequest 和HttpServletResponse等HttpServlet对象,它们可以通过Controller的方法参数灵活的获取到。

    @Service/@Repository/@Component

      负责注册一个bean到spring的上下文中,bean的ID默认为类名称开头字母小写,可以被注入

      @Service 表示是一个业务逻辑bean

      @Repository 表示与持久层相关的bean

    @RequestMapping

    来处理多个 URL

    @RestController
    @RequestMapping("/home")
    public class IndexController {
    
        @RequestMapping(value = {
            "",
            "/page",
            "page*",
            "view/*,**/msg"
        })
        String indexMultipleMapping() {
            return "Hello from index multiple mapping.";
        }
    }

     @RequestParam

    @RestController  
    @RequestMapping("/home")  
    public class IndexController {  
        @RequestMapping(value = "/name")  
        String getName(@RequestParam(value = "person", required = false) String personName) {  
            return "Required element of request param";  
        }  
    }  

    在这段代码中,因为 required(是否必传) 被指定为 false,即persion可以不传,所以 getName() 处理方法对于如下两个 URL 都会进行处理: 

      • /home/name?person=xyz
      • /home/name

    @PathVariable

    @RequestMapping(value = "user/login/{id}/{name}/{status}")
    @ResponseBody
    public User login(@PathVariable int id, @PathVariable String name, @PathVariable boolean status) {
        return new User(id, name, status);
    }
    @Controller  
    public class TestController {  
         @RequestMapping(value="/user/{userId}/roles/{roleId}",method = RequestMethod.GET)  
         public String getLogin(@PathVariable("userId") String userId,  
             @PathVariable("roleId") String roleId){  
             System.out.println("User Id : " + userId);  
             System.out.println("Role Id : " + roleId);  
             return "hello";  
         }  
         @RequestMapping(value="/product/{productId}",method = RequestMethod.GET)  
         public String getProduct(@PathVariable("productId") String productId){  
               System.out.println("Product Id : " + productId);  
               return "hello";  
         }  
         @RequestMapping(value="/javabeat/{regexp1:[a-z-]+}",  
               method = RequestMethod.GET)  
         public String getRegExp(@PathVariable("regexp1") String regexp1){  
               System.out.println("URI Part 1 : " + regexp1);  
               return "hello";  
         }  
    }

    @GetMapping/PostMapping

      @GetMapping相当于:@RequestMapping(method = RequestMethod.GET)

      @PostMapping相当于:@RequestMapping(method = RequestMethod.POST)

    @ResponseBody

      @Responsebody 注解表示该方法的返回的结果直接写入 HTTP 响应正文(ResponseBody)中,一般在异步获取数据时使用,通常是在使用 @RequestMapping 后,返回值通常解析为跳转路径

    加上@Responsebody 后返回结果不会被解析为跳转路径,而是直接写入HTTP 响应正文中。
    作用:
        该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。
    使用时机:
        返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xml等)使用;

    当页面发出异步请求,客户端:

    function login() {
        var datas = '{"username":"' + $('#username').val() + '","userid":"' + $('#userid').val() + '","status":"' + $('#status').val() + '"}';
        $.ajax({
            type : 'POST',
            contentType : 'application/json',
            url : "${pageContext.request.contextPath}/user/login",
            processData : false,
            dataType : 'json',
            data : datas,
            success : function(data) {
                alert("userid: " + data.userid + "username: " + data.username + "status: "+ data.status);
            },
            error : function(XMLHttpRequest, textStatus, errorThrown) {
                alert("出现异常,异常信息:"+textStatus,"error");
            }
        });
    };

    服务端:

        异步获取 json 数据,加上 @Responsebody 注解后,就会直接返回 json 数据。

    @RequestMapping(value = "user/login")
    @ResponseBody
    // 将ajax(datas)发出的请求写入 User 对象中,返回json对象响应回去
    public User login(User user) {   
        User user = new User();
        user .setUserid(1);
        user .setUsername("MrF");
        user .setStatus("1");
        return user ;
    }

    @RestController

      @RestController注解相当于 @ResponseBody + @Controller 组合作用

      1) 如果只是使用@RestController,则Controller中的方法无法返回jsp页面,或者html,配置的视图解析器 InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。

      2) 如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行。
        如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解。

    @RequestBody

    @RequestBody 注解则是将 HTTP 请求正文插入方法中,使用适合的 HttpMessageConverter 将请求体写入某个对象。

    作用:

        1) 该注解用于读取Request请求的body部分数据,使用系统默认配置的HttpMessageConverter进行解析,然后把相应的数据绑定到要返回的对象上;
        2) 再把HttpMessageConverter返回的对象数据绑定到 controller中方法的参数上。

    @RequestMapping(value = "user/login")
    @ResponseBody
    // 将ajax(datas)发出的请求写入 User 对象中
    public User login(@RequestBody User user) {   
    // 这样就不会再被解析为跳转路径,而是直接将user对象写入 HTTP 响应正文中
        return user;    
    }

     @Entity

      JPA: java类对应数据库的一个表

  • 相关阅读:
    三:理解Page类的运行机制(例:在render方法中生成静态文件)
    给力的2011,我来了
    推荐全球最大图标搜索FindIcons.com
    C#读图片EXIF信息
    WCF分布式开发步步为赢系列
    几个微软经典开源的项目源代码
    用jQuery合并表格中相同文本的相邻单元格
    收集脚本SQL
    事在人为,境由心造
    据说月薪过了6000的应届生,都知道这些网站
  • 原文地址:https://www.cnblogs.com/jiangzhaowei/p/9881583.html
Copyright © 2011-2022 走看看