SpringMVC常用注解

Springmvc常用注解
[email protected]
@Controller 用于标记在一个类上,使用它标记的类就是一个SpringMVC Controlle对象。通过Sping配置的注解扫描,将这个bean注册到Spring容器中。

[email protected]
@RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。该注解为控制器指定可以处理哪些 URL 请求。
SpringMVC常用注解

[email protected]
该注解用于将Controller的方法返回的对象,通过适当的HttpMessageConverter转换为指定格式后,写入到Response对象的body数据区。
使用时机:返回的数据不是html标签的页面,而是其他某种格式的数据时(如json、xm)使用;

[email protected]
@requestParam主要用于在SpringMVC后台控制层获取参数,类似一种是 request.getParameter(“name”),它有三个常用参数:defaultValue = “0”, required = false, value = “isApp”;defaultValue 表示设置默认值,required 铜过boolean设置是否是必须要传入的参数, value 值表示接受的传入的参数类型。
[email protected]和@Autowired
@Resource和@Autowired都是做bean的注入时使用,其实@Resource并不是Spring的注解,它 的包是javax.annotation.Resource,需要导入,但是Spring支持该注解的注入。
1、共同点
两者都可以写在字段和setter方法上。两者如果都写在字段上,那么就不需要再写setter方法。
2、不同点
(1)@Autowired
@Autowired注解是按照类型(byType)装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它的required属性为false。如果我们想使用按照名称(byName)来装配,可以结合@Qualifier注解一起使用。
(2)@Resource
@Resource默认按照ByName自动注入,由J2EE提供,需要导入包 javax.annotation.Resource。@Resource有两个重要的属性:name和type,而Spring将 @Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以, 如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自 动注入策略。如果既不制定name也不制定type属性,这时将通过反射机制使用byName自 动注入策略。
[email protected]
相当于通用的注解,当不知道一些类归到哪个层时使用,但是不建议。
[email protected]
用于注解dao层,在daoImpl类上面注解。