springmvc 注解
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数据
ResponseBody
- 用于将Controller的方法返回的对象,通过适当的HttpMessageConverter(转换器)转换为指定格式后,写入到Response对象的body数据区
- 返回如json,xml等时使用
- 在springmvc配置文件中通过<mvc:annotation-driven/>,给AnnotationMethodHandlerAdapter初始化7个转换器
RequestHeader
可以把request请求header部分的值绑定到方法的参数上。