web佛脚-SpringMVC常用注解类

作者: 在南方的北方人_Elijah | 来源:发表于2017-02-23 19:35 被阅读48次

RequestMapping注解类

  • 在mvc-dispatcher-servlet.xml(也可能名字不一样,就是springmvc的配置文件)中,添加扫描<context:component-scan>用于扫描包中的@contorller控制器类,拦截URL。

  • 在Controller控制器类的类定义和方法定义处都可以标注@RequestMapping,用于处理路径请求。

  • DispatcherServlet截获请求后,就可以通过控制器上的@RequestMapping提供的映射信息确定请求所对应的处理方法。

  • RequestMapping属性:value method consumes produces params headers
    method类型:GET POST PUT DELETE
    cosumes:制定请求提交内容的类型 如{application/json,text/plain}可以是一个数组,也可以是一个字符串。
    produces:返回的内容类型。
    params:表示 请求中必须包含某些参数才会出发这个方法,如params="myParam=myValue",也可以用数组表示params={"myParam0=myValue","myParam1!=myValue"}

  • headers:请求头中必须包含某些指定的参数值,才能让该方法处理请求,如hearders="contet-type=text/*"

  • @RequestMapping不仅支持标准的URL,还支持Ant风格和带{xxx}占位符的URL,下面的URL都是合法的:
    /user//login:匹配/user/aaa/login,/user/任意字符/login 等
    /user/
    /login:匹配/user/login, /user/aaa/bbb/login 等
    /user/login??:匹配/user/loginAA, /user/loginbb 等
    /user/{userId}:匹配/user/123, /user/234 等
    /user/
    */{userId}:匹配/user/aaa/bbb/123,/user/aaa/234等

四大注解类

  • @Component 是通用标注
  • @Controller标注web控制器
  • @Service标注Service层的服务
  • @Respository标注DAO层的数据访问

这些注解都是类级别的,可以不带任何参数,也可以带一个参数,代表bean的名字,在进行注入的时候就可以通过名字进行注入了

在不清楚使用那个注解的时候,可以统统使用Component 。为了代码逻辑清晰,还是建议使用具体的注解

@Resource 和@Autowired的异同

@Autowired默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,例如:@Autowired(required=false) ,如果我们想使用名称装配可以结合@Qualifier注解进行使用

图片 7.png

@Resource,默认安装名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配

图片 8.png

其他常用注解类

  • PathVariable注解类
  • RequestParam注解类
  • CookieValue注解类
  • SessionAttributes注解类
  • ResponseBody注解类
  • RequestHeader注解类

PathVariable

@RequestMapping注解中使用占位符的情况下,需要使用@PathVariable注解指定占位符参数

图片 pv.png

其实就是用路径里面的参数复制给注解后面的变量

RequestParam

在SpringMVC后台控制层获取参数的方式主要有两种,一种是request.getParameter("name"),另外一种是用注解@RequestParam直接获取
有三个属性 value, required, defaultValue
不带任何参数,表示需要的参数名与标注的变量名相同
可以通过required=false或者true来要求@RequestParam配置的前端参数是否一定要传
参数类型尽量不要使用基本类型int,long等,而应该使用具体的对象类Integer、Long、String等
就是把request对象中的同名参数,赋值给后面的变量

rp1.png rp2 rp3.png rp4.png

CookieValue

读取Cookies中的值,并且赋值给变量
有三个属性 value, required, defaultValue,分别表示Cookie的名字,是否必须有这个Cookie值,如果没有默认值
不带任何参数,表示需要的参数名与标注的变量名相同

cv

SessionAttrinutes

如果希望在多个请求之间公用某个模型属性数据,则可以在控制器类标注一个@SessionAttributes,Spring MVC会将模型中对应的属性暂存到HttpSerssion中
除了SessionAttributes,还可以直接用原生态的request.getSession()来处理session数据

sa.png

ResponseBody

用于将Controller的方法返回的对象,通过适当的HttpMessageConverter(转换器)转换为指定格式后,写入到Response对象的body数据区
返回如json、xml等时使用
在springmvc配置文件中通过<mvc:annotation-driven />,给AnnotationMethodHandlerAdapter初始化7个转换器

转换器.png

用的最多的是转换成xml和json
这里配置文件中property属性指定了返回xml

convert.png

RequestHeader

@RequestHeader 注解,可以把Request请求header部分的值绑定到方法的参数上

rh.png

相关文章

网友评论

    本文标题:web佛脚-SpringMVC常用注解类

    本文链接:https://www.haomeiwen.com/subject/lqgbwttx.html