- @Component:可以使用此注解描述Spring中的Bean,但它是一个泛化的概念,仅仅表示一个组件(Bean),并且可以作用在任何层次。使用时只需要将该注解标注在相应类上即可。
- @Repository:用于将数据访问层(DAO层)的类标识为Spring中的Bean,其功能与@Component相同。
- @Service:通常作用于业务层(Service层),用于将业务层的类标识为Spring中的Bean,其功能与@Component相同。
- @Controller:通常作用于控制层(如Spring MVC的Controller),用于将控制层的类标识为Spring中的Bean,其功能与@Component相同。
- @Autowired:用于对Bean的属性变量、属性的setter方法及构造方法进行标注,配合对应的注解处理器完成Bean的自动
配置工作。默认按照Bean的类型进行装配。 - @Resource:其作用与@Autowired一样。其区别在于@Autowired默认按照Bean类型装配,而@Resource默认按照Bean实例名称进行装配。@Resource中有两个重要属性:name和type。Spring将name属性解析为Bean实例名称,type属性解析为Bean实例类型。如果指定name属性,则按实例名称进行装配;如果指定type属性,则按Bean类型进行装配;如果都不指定,则先按Bean实例名称装配,如果不能匹配,再按照Bean类型进行装配;如果都无法匹配,则抛出NoSuchBeanDefinitionException异常。
- Qualifier:与@Autowired注解配合使用,会默认的按Bean类型装配修改为按Bean的实例名称装配,Bean的实例名称由@Quailfier注解的参数指定。
基于AspectJ的注解及其描述
- @Aspect:用于定义一个切面。
- @Pointcut:用于定义切入点表达式。
- @Before:用于定义前置通知,相当于BeforeAdvice。
- @AfterReturning:用于定义后置通知,相当于AfterReturningAdvice。
- @Around:用于定义环绕通知,相当于MethodInterceptor。
- @AfterThrowing:用于定义异常通知来处理程序中未处理的异常,相当于ThrowAdvice。
- @After:用于定义最终final通知,不管是否异常,该通知都会执行。
- @DeclareParents:用于定义引介通知,相当于IntroductuinInterceptor。
@Transactional注解的参数及其描述
参数名称 | 描述 |
---|---|
value | 用于指定需要使用的事务管理器,默认为“”,其别名为transactionManager |
transactionManager | 指定事务的限定符值,可用于确定目标事务管理器,匹配特定的限定值(或者Bean的name值),默认为“”,其别名为value |
isolation | 用于指定事务的隔离级别,默认为Isolation.DEFAULT(即底层事务的隔离级别) |
noRollbackFor | 用于指定遇到特定异常时强制不会滚事务 |
noRollbckForClassName | 用于指定遇到的特定的多个异常时强制不回滚事务。其属性值可以指定多个异常类名 |
propagation | 用于指定事务的传播行为,默认为Propagation.REQUIRED |
read-only | 用于指定事务是否可读,默认为false |
rollbackFor | 用于指定遇到特定异常时强制回滚事务 |
rollbackForClassNam | 用于指定特定的多个异常时强制回滚事务。其属性值可以指定多个异常类名 |
timeout | 用于指定事务的超时时长,默认为TransactionDefinitionTIMEOUT_DEFAULT(即底层事务系统的默认时间)> |
@RequestMapping注解的属性
属性名 | 类型 | 描述 |
---|---|---|
name | String | 可选属性,用于映射地址指定别名 |
value | String[] | 可选属性,同时也是默认属性,用于映射一个请求和一种方法 |
method | RequestMethod[] | 可选属性,用于指定该方法用于处理哪种类型的请求方式,其请求方式包括GET、POST、HEAD、OPTIONS、PUT、PATCH、DELET和TRACE |
params | String[] | 可选属性,用于指定Request中必须包含哪些参数的值,才可以通过其标注的方法处理 |
headers | String[] | 可选属性,用于指定Request中必须包含某些指定的header的值,才可以通过其标注的方法处理 |
consumes | String[] | 可选属性,用于指定处理请求的提交内容类型(Content-type),比如application/json、text/html等 |
produces | String[] | 可选属性,用于指定返回的内容类型,返回的内容类型必须是request请求头(Accept)中所包含的类型 |
有时候前端请求中参数名和后台控制器类方法中的形参名不一样,这就会导致后台无法正确绑定并接收到前端请求的参数。为此,Spring MVC提供了@RequestParam注解来进行间接数据绑定。@RequestParam注解主要用于对请求中的参数进行定义,在使用时可以指定它的4个属性。
属性 | 说明 |
---|---|
value | name属性的别名,这里指参数的名字,即入参的请求参数名字,如value="item_id"表示请求的参数中文名字为item_id的参数的值将传入。如果只使用value属性,则可以省略value属性名 |
name | 指定请求头绑定的名称 |
required | 用于指定参数是否必须,默认为true,表示请求中一定要有相应的参数 |
defaultValue | 默认值,表示如果请求中没有同名参数时的默认值 |
JSON数据交互注解及说明
- @RequestBody:用于请求体中的数据绑定到方法的形参中。该注解用在方法的形参上
- @ReSponseBody:用于直接返回return对象(会默认转为JSON格式数据进行响应)。该注解用在方法上