springmvc常用注解类

[list]
[*][color=blue][size=large]RequestMapping 注解类
[*]四大注解类 Component、Controller、Service、Repository
[*]其他注解类[/size][/color]
[/list]

[size=medium][b]RequestMapping 注解类[/b][/size]

[size=small][list]
[*]RequestMapping注解类的使用方法
[*]RequestMapping注解类的属性
[*]定义Ant风格和带占位符的URL
[/list][/size]
示例:
[img]http://dl2.iteye.com/upload/attachment/0115/1437/8505b4e9-85d1-3694-9169-3e2265029527.png[/img]
RequestMapping注解类的属性,分别有 value, method, consumes, produces, params, headers,
第一,介绍value属性:

代表具体的请求路径,比如上面的 /user, /login 都是value的值
value可以省略,就像例子中一样,直接用 @RequestMapping("/login") 的格式,它等同于@RequestMapping(value = "/login")

[img]http://dl2.iteye.com/upload/attachment/0115/1439/abed0de5-9f8d-363c-8904-94d3d8da6276.png[/img]

第二,介绍method的属性

method属性包含以下几种, GET、POST、PUT、DELETE等
例:@RequestMapping(value = "/login", method = RequestMethod.POST) 那么只有发送POST请求才会触发这个方法
例:@RequestMapping(value = "/login", method = {RequestMethod.POST, RequestMethod.GET})

[img]http://dl2.iteye.com/upload/attachment/0115/1445/fba1ffd3-aaab-39ef-9683-7e4fa100f623.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1447/7f935ae4-3988-30b6-951e-95e60e9677ae.png[/img]

第三、介绍consumes属性:

指定请求的提交内容类型(Content-Type),例如application/json, text/html
它的值既可以是字符串也可以是数组
[img]http://dl2.iteye.com/upload/attachment/0115/1452/334dd7e4-7a41-3159-8514-050df6182a74.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1454/2e5abc59-aa5d-376a-93e2-8bfd94ba3176.png[/img]

第四,介绍produces属性

指定请求中必须包含某些参数值,才会触发这个处理方法。
[img]http://dl2.iteye.com/upload/attachment/0115/1460/8b08b341-9273-3c3a-a7f5-4e9099f25590.png[/img]

第五,介绍params属性

参数中除了使用=等号外,还可以使用!=号,表示在参数的值不等于的情况下触发这个方法
也可以不指定具体的值,直接使用 "paramName" 的格式,代表请求中必须包含参数名为 paramName 的参数
直接使用 “!paramName”格式表示请求不能包含名为paramName的请求参数
[img]http://dl2.iteye.com/upload/attachment/0115/1456/d2b0e8a0-b845-331a-a122-d1c2bb1b8b98.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1458/13d938a2-f6bb-345f-b273-4dc4c2fbfcf0.png[/img]

第六,介绍headers属性:

请求头Header中必须包含某些指定的参数值,才能让该方法处理请求
[img]http://dl2.iteye.com/upload/attachment/0115/1462/16c18b39-a8c1-3498-bd5e-46e737f409a0.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1464/c3e3ce04-d750-341f-a346-3b2d89bb76af.png[/img]


[size=small][b]带占位符的@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等[/b][/size]


四大注解类
Component、Controller、Service、Repository

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

[img]http://dl2.iteye.com/upload/attachment/0115/1466/c46fb55f-fe17-3858-a0a1-497111c48329.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1468/ea0f9575-f31a-3ac7-9de5-fb6fe87b2fb8.png[/img]


@Resource和@Autowired注解的异同:

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

[img]http://dl2.iteye.com/upload/attachment/0115/1472/2b398936-dde6-3ae1-a563-115dc6563259.png[/img]

@Resource和@Autowired注解的异同:

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


[color=blue][size=medium]其他注解类[/size][/color]

[list]
[*]PathVariable注解类
[*]RequestParam注解类
[*]CookieValue注解类
[*]SessionAttributes注解类
[*]ResponseBody注解类
[*]RequestHeader注解类
[/list]


PathVariable注解类知识点:

@RequestMapping注解中使用占位符的情况下,需要使用@PathVariable注解指定占位符参数
[img]http://dl2.iteye.com/upload/attachment/0115/1476/1868ddfb-bbcd-3395-8a1f-2778f1acec33.png[/img]


RequestParam注解类的知识点:

在SpringMVC后台控制层获取参数的方式主要有两种,一种是request.getParameter("name"),另外一种是用注解@RequestParam直接获取
有三个属性 value, required, defaultValue
不带任何参数,表示需要的参数名与标注的变量名相同
可以通过required=false或者true来要求@RequestParam配置的前端参数是否一定要传
参数类型尽量不要使用基本类型int,long等,而应该使用具体的对象类Integer、Long、String等。
[img]http://dl2.iteye.com/upload/attachment/0115/1478/27c7f5fd-c0f9-3e56-b39a-3bf22243e37a.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1480/1623ef25-3f76-3eab-b6f7-7dd10aad0d18.png[/img]

CookieValue注解类的知识点:

读取Cookies中的值,并且赋值给变量
有三个属性 value, required, defaultValue,分别表示Cookie的名字,是否必须有这个Cookie值,如果没有默认值
不带任何参数,表示需要的参数名与标注的变量名相同
[img]http://dl2.iteye.com/upload/attachment/0115/1482/d730a709-5a31-39f5-ae60-623fba93c0cb.png[/img]

SessionAttributes注解类的知识点:

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

[img]http://dl2.iteye.com/upload/attachment/0115/1484/f1c9589a-ff5a-3a73-acd6-d51399ddec71.png[/img]


ResponseBody注解类的知识点:

用于将Controller的方法返回的对象,通过适当的HttpMessageConverter(转换器)转换为指定格式后,写入到Response对象的body数据区
返回如json、xml等时使用
在springmvc配置文件中通过<mvc:annotation-driven />,给AnnotationMethodHandlerAdapter初始化7个转换器
常用的转换器:
[img]http://dl2.iteye.com/upload/attachment/0115/1486/c7e6725c-ea30-31ec-9c8d-6c1d56bab1c1.png[/img]

用法示例:
[img]http://dl2.iteye.com/upload/attachment/0115/1488/dd975f58-f8ec-3ba6-9bd1-5232005ac43e.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1490/1eef825e-ef65-3016-a48b-9a10a0d16099.png[/img]

RequestHeader注解类的知识点:

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

用法示例:
[img]http://dl2.iteye.com/upload/attachment/0115/1492/07d5bfea-75ff-374c-96bc-6aed17fb4103.png[/img]
[img]http://dl2.iteye.com/upload/attachment/0115/1494/1c981f86-a210-31f1-9267-2141a4afe9fb.png[/img]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值