springmvc 注解
2016-07-20 16:57
183 查看
RequestMapping注解类:
使用方法:
开发Controller控制器类,使用@Controller注解标注,并在配置文件中用<context:component-scan>扫描
在Controller控制器类的类定义和方法定义处都可以标注@RequestMapping注解
DispatcherServlet截获请求后,就可以通过控制器上的@RequestMapping提供的映射信息确定请求所对应的处理方法。
@RequestMapping不仅支持标准的URL,还支持Ant风格和带{xxx}占位符的URL
下面的URL都是合法的:
/user/*/login:匹配/user/aaa/logim,/user/任意字符/login等
/user/**/login:匹配/user/login,/user/aaa/bbb/login 可省略,也可以用任意字符替换
/user/login??:每个问号代表一个字符,可以是任意字符
/user/{userId}:匹配/user/123,/user/234等 占位符的加入
RequestMapping注解类的属性,分别有value,method,consumes,produces,params,headers,
value属性:
代表具体的请求路径,比如上面的/user,/login都是value的值
value可以省略的,就像例子中一样,直接用@RequestMapping("/login")的格式
它等同于@RequestMapping(value="/login")
method属性:
指定请求的method类型,GET,POST、PUT、DELETE等
它的值既可以是字符串也可以是数组
例:@RequestMapping(value="/login",method=RequestMethod.POST)
那么只有发送POST请求才会触发这个方法
@RequestMapping(value="/login",method={RequestMethod.POST,RequestMethod.GET})
consumes属性:
指定请求的提交内容类型(Content-Type),列如application/json,text/html
它的值既可以是字符串也可以是数组
例:@RequestMapping(value="/login",consumes="application/json")
@RequestMapping(value="/login",consumes={"application/json","text/plain"})
produces属性:
指定返回的内容类型
@RequestMapping(value="/login",produces="text/plain")
params属性:
指定请求中必须包含某些参数值,才会触发这个处理方法。
@RequestMapping(value="/login",params="myParam=myValue")
参数中除了使用=等号外,还可以使用!=号,表示参数的值不等于的情况下触发这个方法。
@RequestMapping(value="/login",params={"myParam0=myValue","myParam1!=myValue"})
也可以不指定具体的值,直接使用"paramName"的格式,代表请求中必须包含参数名为paramName的参数
直接使用"!paramName"格式表示请求不能包含名为paramName的请求参数
headers属性:
请求头Header中必须包含某些指定的参数值,才能让该方法处理请求。
@RequestMapping(value="/login",headers="content-type="text/*")
四大常用注解类:
Component、Controller、Service、Repository四大注解类:
@Component是通用标注@Controller标注Web控制器@Service 标注Service层的服务@Repository 标注DAO层的数据访问
这些注解都是类级别的,可以不带任务参数,也可以带一个参数,代表bean名字,在进行注入的时候就可以通过名字进行注入了。
@Service("loginService")
public class LoginService{
}
在不清楚使用哪个注解的时候,可以统统使用Component
为了代码逻辑清晰,还是建议使用具体的注解
在springmvc的配置文件中,通过context:component-scan使注解生效
使用@Resource或@Autowired注解实现注入
@Autowired默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,例如:
@Autowired(required=false),如果我们想使用名称装配可以结合@Qualifier注解进行使用
@Autowired
@Qualifier("loginService")
LoginService service;
@Resource,默认安装名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配
其他注解类:
PathVariable
RequestParam
CookieValue
SessionAttributes
ResponseBody
RequestHeader
PathVariable:@RequestMapping注解中使用占位符的情况下,需要使用@PathVariable注解指定占位符参数
RequestParam
在springmvc后台控制层获取参数的方式主要有两种,一种是request.getParameter("name"),另外一种是用注解@RequestParam直接获取
有三个属性value,required,defaultValue
不带任何参数,表示需要的参数名于标注的变量名相同
可以通过required=false或者true来要求@RequestParam配置的前端参数是否一定要传
参数类型尽量不要使用基本类型int,long,等,而应该使用具体的对象类Integer、Long、String等
CookieValue
读取Cookies中的值,并且赋值给变量
有三个属性value,reuqired,defaultValue,分别表示Cookie的名字,是否必须有这个Cookie值,如果没有默认值
不带任何参数,表示需要的参数名于标注的变量名相同
SessionAttributes
如果希望在多个请求之间公用某个模型属性数据,则可以在控制器类标注一个@SessionAttributes,Spring MVC会将模型中对应的属性暂存到HttpSession中
除了SessionAttributes,还可以直接用原生态的request.getSession()来处理session数据
[b]ResponseBody
[/b]
用于将Controller的方法返回的对象,通过适当的HttpMessageConverter(转换器)转换为指定格式后,写入到Response对象的body数据区
返回如json,xml等时使用
在springmvc配置文件中通过<mvc:annotation-driven/>,给AnnotationMethodHandlerAdapter初始化7个转换器
[b]RequestHeader
[/b]
可以把request请求header部分的值绑定到方法的参数上。
使用方法:
开发Controller控制器类,使用@Controller注解标注,并在配置文件中用<context:component-scan>扫描
在Controller控制器类的类定义和方法定义处都可以标注@RequestMapping注解
DispatcherServlet截获请求后,就可以通过控制器上的@RequestMapping提供的映射信息确定请求所对应的处理方法。
@RequestMapping不仅支持标准的URL,还支持Ant风格和带{xxx}占位符的URL
下面的URL都是合法的:
/user/*/login:匹配/user/aaa/logim,/user/任意字符/login等
/user/**/login:匹配/user/login,/user/aaa/bbb/login 可省略,也可以用任意字符替换
/user/login??:每个问号代表一个字符,可以是任意字符
/user/{userId}:匹配/user/123,/user/234等 占位符的加入
RequestMapping注解类的属性,分别有value,method,consumes,produces,params,headers,
value属性:
代表具体的请求路径,比如上面的/user,/login都是value的值
value可以省略的,就像例子中一样,直接用@RequestMapping("/login")的格式
它等同于@RequestMapping(value="/login")
method属性:
指定请求的method类型,GET,POST、PUT、DELETE等
它的值既可以是字符串也可以是数组
例:@RequestMapping(value="/login",method=RequestMethod.POST)
那么只有发送POST请求才会触发这个方法
@RequestMapping(value="/login",method={RequestMethod.POST,RequestMethod.GET})
consumes属性:
指定请求的提交内容类型(Content-Type),列如application/json,text/html
它的值既可以是字符串也可以是数组
例:@RequestMapping(value="/login",consumes="application/json")
@RequestMapping(value="/login",consumes={"application/json","text/plain"})
produces属性:
指定返回的内容类型
@RequestMapping(value="/login",produces="text/plain")
params属性:
指定请求中必须包含某些参数值,才会触发这个处理方法。
@RequestMapping(value="/login",params="myParam=myValue")
参数中除了使用=等号外,还可以使用!=号,表示参数的值不等于的情况下触发这个方法。
@RequestMapping(value="/login",params={"myParam0=myValue","myParam1!=myValue"})
也可以不指定具体的值,直接使用"paramName"的格式,代表请求中必须包含参数名为paramName的参数
直接使用"!paramName"格式表示请求不能包含名为paramName的请求参数
headers属性:
请求头Header中必须包含某些指定的参数值,才能让该方法处理请求。
@RequestMapping(value="/login",headers="content-type="text/*")
四大常用注解类:
Component、Controller、Service、Repository四大注解类:
@Component是通用标注@Controller标注Web控制器@Service 标注Service层的服务@Repository 标注DAO层的数据访问
这些注解都是类级别的,可以不带任务参数,也可以带一个参数,代表bean名字,在进行注入的时候就可以通过名字进行注入了。
@Service("loginService")
public class LoginService{
}
在不清楚使用哪个注解的时候,可以统统使用Component
为了代码逻辑清晰,还是建议使用具体的注解
在springmvc的配置文件中,通过context:component-scan使注解生效
使用@Resource或@Autowired注解实现注入
@Autowired默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,例如:
@Autowired(required=false),如果我们想使用名称装配可以结合@Qualifier注解进行使用
@Autowired
@Qualifier("loginService")
LoginService service;
@Resource,默认安装名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配
其他注解类:
PathVariable
RequestParam
CookieValue
SessionAttributes
ResponseBody
RequestHeader
PathVariable:@RequestMapping注解中使用占位符的情况下,需要使用@PathVariable注解指定占位符参数
RequestParam
在springmvc后台控制层获取参数的方式主要有两种,一种是request.getParameter("name"),另外一种是用注解@RequestParam直接获取
有三个属性value,required,defaultValue
不带任何参数,表示需要的参数名于标注的变量名相同
可以通过required=false或者true来要求@RequestParam配置的前端参数是否一定要传
参数类型尽量不要使用基本类型int,long,等,而应该使用具体的对象类Integer、Long、String等
CookieValue
读取Cookies中的值,并且赋值给变量
有三个属性value,reuqired,defaultValue,分别表示Cookie的名字,是否必须有这个Cookie值,如果没有默认值
不带任何参数,表示需要的参数名于标注的变量名相同
SessionAttributes
如果希望在多个请求之间公用某个模型属性数据,则可以在控制器类标注一个@SessionAttributes,Spring MVC会将模型中对应的属性暂存到HttpSession中
除了SessionAttributes,还可以直接用原生态的request.getSession()来处理session数据
[b]ResponseBody
[/b]
用于将Controller的方法返回的对象,通过适当的HttpMessageConverter(转换器)转换为指定格式后,写入到Response对象的body数据区
返回如json,xml等时使用
在springmvc配置文件中通过<mvc:annotation-driven/>,给AnnotationMethodHandlerAdapter初始化7个转换器
[b]RequestHeader
[/b]
可以把request请求header部分的值绑定到方法的参数上。
相关文章推荐
- 【JAVA】多线程之synchronized 同步数据 方法
- Spring配置文件模板
- 二叉查找树Java实现代码
- Java中的异常处理
- java socket 多线程的服务端与客户端的demo
- Java - 数据库(mysql - 4)
- 未检测到Java SDK 环境-Java环境变量设置-Java开发环境搭建
- change project compliance and jre to 1.5
- Spring的IOC原理
- IntellJ Idea 特性和与Eclipse的区别
- Spring中 @Autowired标签与 @Resource标签 的区别
- 用Java实现扑克牌洗牌
- 阿里云OSS实例运行报错
- 排列算法
- java基本数据类型取值范围
- Eclipse的xml编译插件 安装XMLBuddy
- java 实现回调代码实例
- MyEclipse 10 Maven自动更新关闭
- JAVA 注解的几大作用及使用方法详解(完)
- 揭开Java EE开发框架之谜