SpringMVC(2)-- 常用注解类

来源:互联网 发布:手机房屋平面设计软件 编辑:程序博客网 时间:2024/06/01 08:06

RequestMapping注解类


RequestMapping注解类的使用方法

1、开发Controller控制器类,使用@Controller注解标注,并在配置文件中用扫描。
2、在Controller控制器类的类定义和方法定义处都可以标注@RequestMapping注解。
3、DispatcherServlet截获请求后,就可以通过控制器上的@RequestMapping提供的映射信息确定请求所对应的处理方法。


RequestMapping注解类的属性
分别有 value, method, consumes, produces, params, headers,
1、value属性
代表具体的请求路径,value可以省略,例子中一样,直接用 @RequestMapping(“/login”) 的格式,它等同于@RequestMapping(value = “/login”)

2、method属性:
指定请求的method类型, GET、POST、PUT、DELETE等
例:@RequestMapping(value = “/login”, method = RequestMethod.POST) 那么只有发送POST请求才会触发这个方法
例:@RequestMapping(value = “/login”, method = {RequestMethod.POST, RequestMethod.GET})

3、consumes属性:
指定请求的提交内容类型(Content-Type),例如application/json, text/html
它的值既可以是字符串也可以是数组

4、produces属性:
指定请求中必须包含某些参数值,才会触发这个处理方法。

5、params属性:
指定请求中必须包含某些参数值,才会触发这个处理方法
参数中除了使用=等号外,还可以使用!=号,表示在参数的值不等于的情况下触发这个方法
也可以不指定具体的值,直接使用 “paramName” 的格式,代表请求中必须包含参数名为 paramName 的参数
直接使用 “!paramName”格式表示请求不能包含名为paramName的请求参数

6、headers属性:
请求头Header中必须包含某些指定的参数值,才能让该方法处理请求


定义Ant风格和带占位符的RUL
@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,Service,Repository

@Component 是通用标注
@Controller 标注 web 控制器
@Service 标注 Servicec 层的服务
@Respository 标注 DAO 层的数据访问
这些注解都是类级别的, 可以不带任何参数,也可以带一个参数,代表bean名字,在进行注入的时候就可以通过名字进行注入了。

在不清楚使用那个注解的时候,可以统统使用Component
为了代码逻辑清晰,还是建议使用具体的注解
在springmvc的配置文件中,通过context:component-scan使注解生效
使用@Resource或@Autowired注解实现注入

<context:component-scan base-package="com.ssm"></context:component-scan>

@Resource和@Autowired注解:

异同:

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

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


其他注解类

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

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

2、RequestParam注解类的知识点:

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

3、CookieValue注解类的知识点:

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

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

5、ResponseBody注解类的知识点:
用于将Controller的方法返回的对象,通过适当的HttpMessageConverter(转换器)转换为指定格式后,写入到Response对象的body数据区
返回如json、xml等时使用
在springmvc配置文件中通过,给AnnotationMethodHandlerAdapter初始化7个转换器

6、RequestHeader注解类的知识点:
@RequestHeader 注解,可以把Request请求header部分的值绑定到方法的参数上


总结:
1、SpringMVC学习总结(1):主要就是四大注解类,Component,Controller,Service,Repository(dao层的数据访问)。在使用四个注解类的使用,需要在springmvc的配置文件配置context:component-scan使注解生效。
2、SpringMVC学习总结(2):接着就是RequestMapping注解类的使用。在RequestMapping注解类的使用中,主要使用三个属性,value属性、params属性、method属性。
3、SpringMVC学习总结(3):定义Ant风格的带占位符的URL,平时用的比较少,主要就是使用“*”在url中占位,然后请求的时候可以传入参数。类似与params属性。