2018-03-10 Spring常见注解
随笔中默认的包为com.demo
默认接口:Demo
实现类:Demo1,Demo2
使用spring注解第一步,需要在applicationContext*.xml中配置对应的包下的注解扫描,配置如下:
<context:component-scan base-package=”com.demo”/>
配置之后spring会自动扫描配置包下类中的注解,,多个包的时候需要以,分割
1、@Autowired,即自动装配,默认按类型匹配,spring会在容器中查找匹配的bean,当且仅有一个匹配的Bean时,将其注入到注解对应的变量中,匹配不到会报错。
@Autowired
private Demo demo;
2、@Qualifier,指定需要注入的Bean的名称,适用于当一个接口A有两个不同的实现类A1,A2的情况,这时候直接使用@Autowired,spring在容器中默认根据类型匹配会获取到两个实现类,会异常报错,这时候就需要通过指定Bean名称的方式来注入正确的Bean了。使用方式如下:
@Autowired
@Qualifier("demo2")
private Demo demo;
3、@Resource,这个J2EE的注解,并不是spring的注解,也实现了@Autowired的功能,当@Resource后面无任何内容时,默认通过name去匹配bean,找不到再去按type去匹配,可以显式的指定name或者type,匹配不到会报错,使用方式如下
@Resource
@Resource(name="demo1")
@Resource(type=Demo.class)
4、@Compoent,对原有的XML配置Bean的简化,一种通用的注解,用于申明这是一个Bean,不建议使用
5、@Controller,对原有的XML配置Bean的简化,对应的是表现层的Bean,负责DispatcherServlet分发的请求,即控制器Controller,当然完整的控制器仍需要@RequestMapping 和@RequestParam等一些注解来定时URL和Controller方法之间的映射
@Controller
@RequestMapping(value = "/test")
public class ControllerDemo {
@RequestMapping(value = "/demoMethod",method =RequestMethod.POST)
public String demoMethod(){
return "";
}
}
对于/test/demoMehtod的post请求,demoMethod会被执行。
6、@Service,对原有的XML配置Bean的简化,一般配置于业务层,对应的类在容器中的id为demo1,即类名且首字母小写,当然也可以单独对id进行赋值
@Service
public class Demo1{
}
@Service("Demo1")
public class Demo1{
}
7、@Repository,用于注解Dao层
8@RequrestMapping 将web请求映射到MVC和REST 控制器上,此注解属性和用于较多还有与一些注解搭配的使用方法,这里只是简单记录一下
简单介绍一些本身的属性
(1)value:用来对URL进行限制
(2)method:申明不同的HTTP请求的方法类型
(3)params:可以对URL传入的参数进行限制
(4)produces、consumes:produce可以修改相应的格式,consumes对特定格式的内容进行处理
(5)headers:配置具体的header属性,进行映射限制
例子:
@Controller
@RequestMapping(value = "/test")
public class ControllerDemo {
@RequestMapping(value = "/demoMethod",
method =RequestMethod.POST,
params = {"id=10"},
produces = "application/JSON" ,
headers = "content-type=text/plain"
)
public String demoPostMethod(){
return "";
}
}
上面的示例中会对/test/demoMethod?id=10,header中content-type属性为text/plain的HTTP POST请求返回一个JSON响应。
关于RequrestMapping的详细使用可以参考:http://www.iteye.com/news/32657