zoukankan      html  css  js  c++  java
  • springMVC学习笔记六(注解方式实现控制器)

    =========================注解方式实现控制器===========================
    <context:component-scan/>扫描指定包中类上的注解,常用的注解有:
    @controller: 声明处理器类
    @requestMapping("/menu"):处理器功能方法的映射
    @requestParam: 请求参数到处理器处理方法参数上的绑定
    @modleAttribute:请求参数到命令对象的绑定
    @sessionAttribute: session级别存储的属性
    @initBinder:用于将请求参数转换到命令对象属性的对应类型 




    spring3.0引入restful架构风格支持
    @cookieValue:cookies数据到处理器处理方法的方法参数上的绑定
    @requestHander:请求头到处理器处理方法的方法参数上的绑定
    @requestBody:请求body体的绑定
    @responseBody:处理器处理方法的返回值作为响应体
    @responseStatus:定义处理器功能处理方法/异常处理器返回的状态码和原因
    @exceptionHandler:注解声明异常处理器
    @pathVarible:请求 URI 中的模板变量部分到处理器功能处理方法的方法参数上的绑定


    Spring3.1 使用新的 HandlerMapping 和 HandlerAdapter 来支持@Contoller 和@RequestMapping注解处理器




    @service: 声明service组件
    @repository: 声明dao组件
    @component: 泛指组件,当不好归类时
    @resource:用于注入,按名称装配(@Resource(name="beanName"))
    @autowired:用于注入,按类型装配
    @transactional(rollbackFor={Exception.class}):事务管理
    @responseBody
    @scope("prototype"):设定bean的作用域






    示程序如下:
    @Controller
    // 或是@RequestMapping
    public class AnnotationHelloWorldController {
    @RequestMapping(value = "/annoHello")
    public ModelAndView helloWorld() {
    // 收集参数,验证参数
    // 绑定参数到命令对象
    // 将命令传入业务对象进行处理
    // 选择下一个界面
    ModelAndView mv = new ModelAndView();
    mv.addObject("message", "hello world!!!!!");
    mv.setViewName("hello");
    return mv;
    }
    }




    spring配置文件添加如下:
    <!-- 注解 HandlerMapping -->
    <bean
    class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping" />
    <!-- 注解 HandlerAdapter -->
    <bean
    class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter" />
    <!-- 注解方式实现控制器 -->
    <bean class="cn.yue.mvc.controller.AnnotationHelloWorldController" />


    页面视图/jsp/hello.jsp
    <%@ page language="java" pageEncoding="UTF-8"
    contentType="text/html; charset=UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <title>Hello World</title>
    </head>
    <body>${message}
    </body>
    </html>




    -------------------处理器的定义
    方式一:
    @controller
    方式二:
    @requestMapping




    ---------------------窄化请求映射
    控制器AnnotationHelloWorldController修改如下:
    @Controller
    @RequestMapping(value = "/user3")
    public class AnnotationHelloWorldController {
    @RequestMapping(value = "/annoHello")
    public ModelAndView helloWorld() {
    // 收集参数,验证参数
    // 绑定参数到命令对象
    // 将命令传入业务对象进行处理
    // 选择下一个界面
    ModelAndView mv = new ModelAndView();
    mv.addObject("message", "hello world!!!!!");
    mv.setViewName("hello");
    return mv;
    }
    }


    测试:
    http://localhost:8089/user3/annoHello








    ------------------------请求映射
    //
    Remote Address:::1:8089
    Request URL:http://localhost:8089/user3/annoHello  请求url
    Request Method:GET   请求方法
    Status Code:200 OK


    Request Headersview source //请求头信息
    Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
    Accept-Encoding:gzip,deflate,sdch
    Accept-Language:zh-CN,zh;q=0.8
    Cache-Control:max-age=0
    Connection:keep-alive
    Cookie:JSESSIONID=6D207F75EF61B67C5DBC7D0C15809208
    Host:localhost:8089
    User-Agent:Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/35.0.1916.114 Safari/537.36




    -----------------------url路径映射
    a 普通url映射 
     //多个url可以映射同一个路径
     @RequestMapping(value={"/user1","/user2"});


    b url模板模式映射 
    @RequestMapping(value="/users/{userId}"):{×××}占位符, 请求的 URL 可以是 “/users/123456”或 
    “/users/abcd”, 通过@PathVariable 可以提取 URI 模板模式中的{×××}中的×××变量。 
    @RequestMapping(value="/users/{userId}/create") : 这 样 也 是 可 以 的 , 请 求 的 URL 可 以 是
    “/users/123/create”。 
    @RequestMapping(value="/users/{userId}/topics/{topicId}"):这样也是可以的,请求的 URL 可以是
    “/users/123/topics/123”。 




    c ant风格的url路径映射
    @RequestMapping(value="/users/**"):可以匹配“/users/abc/abc”,但“/users/123”将会被【URI模板模式映射
    中的“/users/{userId}”模式优先映射到】  
     
    @RequestMapping(value="/product?"):可匹配“/product1”或“/producta”,但不匹配“/product”或“/productaa”; 
    @RequestMapping(value="/product*"):可匹配“/productabc”或“/product”,但不匹配“/productabc/abc”; 
    @RequestMapping(value="/product/*"):可匹配“/product/abc”,但不匹配“/productabc”; 
    @RequestMapping(value="/products/**/{productId}"):可匹配“/products/abc/abc/123”或“/products/123”,


    Ant风格和URI模板变量风格可混用;




    d 正则表达式风格的URL路径映射
    @RequestMapping(value="/products/{categoryCode:\d+}-{pageNumber:\d+}") : 可 以 匹 配
    “/products/123-1”,但不能匹配“/products/abc-1”




    e 组合使用或的关系 
     @RequestMapping(value={"/test1", "/user/create"})








    -------------------请求方法映射限定




    @Controller 
    @RequestMapping("/customers/**") //①处理器的通用映射前缀 
    public class RequestMethodController { 
     @RequestMapping(value="/create", method = RequestMethod.GET)//类级别的@RequestMapping窄化
     public String showForm() { 
     System.out.println("===============GET"); 
     return "customer/create"; 
     } 
     @RequestMapping(value="/create", method = RequestMethod.POST)//类级别的@RequestMapping窄化
     public String submit() { 
     System.out.println("================POST"); 
     return "redirect:/success"; 
     } 
    }




    -----------------请求参数数据映射限定


    请求数据中有指定参数名
    @Controller 
    @RequestMapping("/parameter1") //①处理器的通用映射前缀 
    public class RequestParameterController1 { 
     //②进行类级别的@RequestMapping窄化 
     @RequestMapping(params="create", method=RequestMethod.GET) 
     public String showForm() { 
     System.out.println("===============showForm"); 
     return "parameter/create"; 
     } 
     //③进行类级别的@RequestMapping窄化 
     @RequestMapping(params="create", method=RequestMethod.POST) 
     public String submit() { 
     System.out.println("================submit"); 
     return "redirect:/success"; 
     } 
    }


    请求数据中没有指定参数名
    @RequestMapping(params="!create", method=RequestMethod.GET)


    请求数据中指定参数名=值
    @RequestMapping(params="submitFlag=create", method=RequestMethod.GET)


    请求数据中指定参数名!=值 
    @RequestMapping(params="submitFlag!=create", method=RequestMethod.GET) 


    组合使用是“且”的关系
    @RequestMapping(params={"test1", "test2=create"})






    ------------ 请求头映射限定????






    -------------生产者和消费者限定


    ...............................media type


    媒体类型格式:type/subtype(;parameter)? 
    type 主类型,任意的字符串,如 text,如果是*号代表所有; 
    subtype 子类型,任意的字符串,如 html,如果是*号代表所有; 
    parameter 可选,一些参数,如 Accept 请求头的 q 参数, Content-Type 的 charset 参数


    常见媒体类型: 
    text/html : HTML 格式 
    text/plain :纯文本格式 
    text/xml :XML 格式 
    image/gif :gif 图片格式 
    image/jpeg :jpg 图片格式 
    image/png:png 图片格式 
    application/x-www-form-urlencoded : <form encType=””>中默认的 encType,form 表单数据被编码为 key/value 格式发
    送到服务器(表单默认的提交数据的格式)。 
    multipart/form-data : 当你需要在表单中进行文件上传时,就需要使用该格式; 
     
    application/xhtml+xml :XHTML 格式 
    application/xml : XML 数据格式 
    application/atom+xml :Atom XML 聚合格式 
    application/json : JSON 数据格式 
    application/pdf :pdf 格式 
    application/msword : Word 文档格式 
    application/octet-stream : 二进制流数据(如常见的文件下载)




    .........................content-type:请求/响应的内容区数据的媒体类型


    请求头的内容类型
    @RequestMapping(value = "/request/ContentType", method = RequestMethod.POST, 
    headers = "Content-Type=application/json") 


    //客户端发送json数据请求
    //请求的地址 
     String url = "http://localhost:9080/springmvc-chapter6/request/ContentType"; 
     //创建Http Request(内部使用HttpURLConnection) 
     ClientHttpRequest request = 
     new SimpleClientHttpRequestFactory(). 
     createRequest(new URI(url), HttpMethod.POST); 
     //设置请求头的内容类型头和内容编码(GBK) 
     request.getHeaders().set("Content-Type", "application/json;charset=gbk"); 
     //以GBK编码写出请求内容体 
     String jsonData = "{"username":"zhang", "password":"123"}"; 
     request.getBody().write(jsonData.getBytes("gbk")); 
     //发送请求并得到响应 
     ClientHttpResponse response = request.execute(); 
     System.out.println(response.getStatusCode()); 








    响应头的内容类型
    @RequestMapping("/response/ContentType") 
     public void response1(HttpServletResponse response) throws IOException { 
     //表示响应的内容区数据的媒体类型为html格式,且编码为utf-8(客户端应该以utf-8解码) 
     response.setContentType("text/html;charset=utf-8"); 
     //写出响应体内容 
     response.getWriter().write("<font style='color:red'>hello</font>"); }


    .....................accept:指定什么类型的响应是可以接受的




    json数据
    服务端控制器
    @RequestMapping(value = "/response/ContentType", headers = "Accept=application/json") 


    客户端接收服务端数据
    需要把请求头Accept改为“Accept=application/json”


    xml数据
    服务端控制器
    @RequestMapping(value = "/response/ContentType", headers = "Accept=application/xml") 
    客户端接收服务端数据
    需要把请求头Accept改为“Accept=application/xml”






    生产者和消费者的限定


    <!-- HandlerMapping --> 
    <bean 
    class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
    <!-- HandlerAdapter --> 
    <bean 
    class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>




    当功能处理方法是消费者时
    @RequestMapping(value = "/consumes", consumes = {"application/json"}):




    当功能处理方法是生产者时
    @RequestMapping(value = "/produces", produces = "application/json")




    窄化时是覆盖而不是继承
    类级别 @RequestMapping(value="/narrow", produces="text/html")
    方法级别@RequestMapping(produces="application/xml") 
    此时方法级别将覆盖类级别


    组合使用是“或”的关系 
    @RequestMapping(produces={"text/html", "application/json"})






    数据绑定


    功能处理方法支持的数据类型
    ServletRequest/HttpServletRequest 和 ServletResponse/HttpServletResponse
    InputStream/OutputStream 和 Reader/Writer
    WebRequest/NativeWebRequest
    HttpSession
    命令/表单对象
    Model、Map、ModelMap
    Errors/BindingResult
    Locale /Principal




    @requestParam绑定单个请求参数
    注:右击项目,选择“属性”,打开“属性对话框”,选择“Java Compiler”然后再打开的选项卡将“Add 
    variable attributes to generated class files”取消勾选,意思是不将局部变量信息添加到类文件中


    功能:
    将请求参数区数据映射到功能处理方法的参数上
    示例代码如下:
    @RequestParam(value="username", required=true, defaultValue="zhang") String username)
    参数:
    value:参数名
    required:请求中是否一定要有相应的参数,默认为false
    defaultValue:请求中没有同名参数时的默认值




    @requestHeader绑定请求头数据
    功能:
    将请求头信息区数据映射到功能处理方法的参数上
    示例代码如下:
    @RequestHeader("User-Agent") String userAent, 
     @RequestHeader(value="Accept") String[] accepts) 






    @modelAttribute绑定请求参数到命令对象
    功能:
    a 绑定请求参数到命令对象
    //可以在视图页面使用${user.username}来获取绑定的命令对象的属性。
    public String test1(@ModelAttribute("user") UserModel user)




    b 暴露表单引用对象为模型数据
    @ModelAttribute("cityList") 
    public List<String> cityList() { 
     return Arrays.asList("北京", "山东"); 
    }




    c 暴露@requestMapping方法返回值为模型数据
    public @ModelAttribute("user2") UserModel test3(@ModelAttribute("user2") UserModel user)




    匿名绑定命令参数
    public @ModelAttribute List<UserModel> test()








    @sessionAttributes绑定到命令对象session








    @value绑定spEL表达式

    public String test(@Value("#{systemProperties['java.vm.version']}") String jvmVersion) 

    参考:http://jinnianshilongnian.iteye.com/blog/1752171 




  • 相关阅读:
    关于随机数生成
    全文搜索基本原理(倒排索引、搜索结果排序)
    Log-Structured Merge Tree (LSM Tree)
    Spring Cloud组件使用/配置小记
    容错框架之Hystrix小记
    (转)调试程序时设置断点的原理
    字符串匹配算法
    信息论小记
    Java 函数式编程(Lambda表达式)与Stream API
    (转)自动控制的故事
  • 原文地址:https://www.cnblogs.com/retacn-yue/p/6194264.html
Copyright © 2011-2022 走看看