Spring 常用注解(绝对经典),非科班面试之旅
@Bean
public ColorFactoryBean colorFactoryBean(){
return new ColorFactoryBean();
}
//创建一个 spring 定义的 FactoryBean
public class ColorFactoryBean implements FactoryBean<Color> {
//返回一个 Color 对象,并将 Color 添加到容器中
public Color getObject() throws Exception {
System.out.println("ColorFactoryBean,getObject()");
return new Color();
}
public Class<?> getObjectType() {
return Color.class;
}
public boolean isSingleton() {
return false;
}
}
2、注入 bean 的注解
@Autowired:由 bean 提供
@Autowired 可以作用在变量、setter 方法、构造函数上;
有个属性为 required,可以配置为 false;
@Inject:由 JSR-330 提供
@Inject 用法和 @Autowired 一样。
@Resource:由 JSR-250 提供
@Autowired、@Inject 是默认按照类型匹配的,@Resource 是按照名称匹配的,@Autowired 如果需要按照名称匹配需要和 @Qualifier 一起使用,@Inject 和 @Name 一起使用。
@Primary
让 spring 进行自动装配的时候,默认使用首选的 bean,和 @Qualifier 一个效果。
3、@JsonIgnore
(1)作用
在 json 序列化时将 java bean 中的一些属性忽略掉,序列化和反序列化都受影响。
(2)使用方法
一般标记在属性或者方法上,返回的 json 数据即不包含该属性。
(3)注解失效
如果注解失效,可能是因为你使用的是 fastJson,尝试使用对应的注解来忽略字段,注解为:@JSONField(serialize = false),使用方法一样。
4、初始化和销毁方法
(1)通过 @Bean(initMethod="init",destoryMethod="destory")方法
(2)通过 bean 实现 InitializingBean 来定义初始化逻辑,DisposableBean 定义销毁逻辑
(3)可以使用 JSR250:@PostConstruct:初始化方法;@PreDestory:销毁方法。
(4)BeanPostProcessor:bean 的后置处理器,在 bean 初始化前后进行一些处理工作
postProcessBeforeInitialization:在初始化之前工作;
postProcessAfterInitialization:在初始化工作之后工作;
5、Java 配置类相关注解
@Configuration
声明当前类为配置类;
@Bean
注解在方法上,声明当前方法的返回值为一个 bean,替代 xml 中的方式;
@ComponentScan
用于对 Component 进行扫描;
6、切面(AOP)相关注解
Spring 支持 AspectJ 的注解式切面编程。
@Aspect 声明一个切面
@After 在方法执行之后执行(方法上)
@Before 在方法执行之前执行(方法上)
@Around 在方法执行之前与之后执行(方法上)
@PointCut 声明切点
在 java 配置类中使用 @EnableAspectJAutoProxy 注解开启 Spring 对 AspectJ 代理的支持
7、@Bean 的属性支持
@Scope 设置类型包括:
设置 Spring 容器如何新建 Bean 实例(方法上,得有 @Bean)
① Singleton
(单例,一个 Spring 容器中只有一个 bean 实例,默认模式),
② Protetype
(每次调用新建一个 bean),
③ Request
(web 项目中,给每个 http request 新建一个 bean),
④ Session
(web 项目中,给每个 http session 新建一个 bean),
⑤ GlobalSession
(给每一个 global http session 新建一个 Bean 实例)
8、@Value 注解
(1)支持如下方式的注入:
注入普通字符
注入操作系统属性
注入表达式结果
注入其它 bean 属性
注入文件资源
注入网站资源
注入配置文件
(2)@Value 三种情况的用法。
${}是去找外部配置的参数,将值赋过来
#{}是 SpEL 表达式,去寻找对应变量的内容
#{}直接写字符串就是将字符串的值注入进去
9、环境切换
@Profile
指定组件在哪个环境的情况下才能被注册到容器中,不指定,任何环境下都能注册这个组件。
@Conditional
通过实现 Condition 接口,并重写 matches 方法,从而决定该 bean 是否被实例化。
10、异步相关
@EnableAsync
配置类中通过此注解开启对异步任务的支持;
@Async
在实际执行的 bean 方法使用该注解来声明其是一个异步任务(方法上或类上所有的方法都将异步,需要 @EnableAsync 开启异步任务)
11、定时任务相关
@EnableScheduling
在配置类上使用,开启计划任务的支持(类上)
@Scheduled
来申明这是一个任务,包括 cron,fixDelay,fixRate 等类型(方法上,需先开启计划任务的支持)
12、Enable***注解说明
这些注解主要是用来开启对 xxx 的支持:
@EnableAspectAutoProxy:开启对 AspectJ 自动代理的支持;
@EnableAsync:开启异步方法的支持;
@EnableScheduling:开启计划任务的支持;
@EnableWebMvc:开启 web MVC 的配置支持;
@EnableConfigurationProperties:开启对 @ConfigurationProperties 注解配置 Bean 的支持;
@EnableJpaRepositories:开启对 SpringData JPA Repository 的支持;
@EnableTransactionManagement:开启注解式事务的支持;
@EnableCaching:开启注解式的缓存支持;
13、测试相关注解
@RunWith
运行器,Spring 中通常用于对 JUnit 的支持
@ContextConfiguration
用来加载配置配置文件,其中 classes 属性用来加载配置类。
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath*:/*.xml"})
public class CDPlayerTest {
}
@ContextConfiguration 这个注解通常与 @RunWith(SpringJUnit4ClassRunner.class)联合使用用来测试。
@ContextConfiguration 括号里的 locations = {"classpath*:/*.xml"}就表示将 classpath 路径里所有的 xml 文件都包括进来,自动扫描的 bean 就可以拿到,此时就可以在测试类中使用 @Autowired 注解来获取之前自动扫描包下的所有 bean。
14、@EqualsAndHashCode
任意类的定义都可以添加@EqualsAndHashCode
注解,让 lombok 帮你生成equals(Object other)
和hashCode()
方法的实现。默认情况下会使用非静态和非 transient 型字段来生成,但是你也通过在字段上添加 @EqualsAndHashCode.Include 或者 @EqualsAndHashCode.Exclude 修改你使用的字段(甚至指定各种方法的输出)。或者你也可以通过在类上使用 @EqualsAndHashCode(onlyExplicitlyIncluded = true) ,且在特定字段或特定方法上添加 @EqualsAndHashCode.Include 来指定他们。
如果将@EqualsAndHashCode
添加到继承于另一个类的类上,这个功能会有点棘手。一般情况下,为这样的类自动生成equals
和hashCode
方法是一个坏思路,因为超类也有定义了一些字段,他们也需要 equals/hashCode 方法但是不会自动生成。通过设置 callSuper=true,可以在生成的equals
和hashCode
方法里包含超类的方法。对于hashCode
,·super.hashCode()·会被包含在 hash 算法内,而对于equals
,如果超类实现认为它与传入的对象不一致则会返回 false。注意:并非所有的equals
都能正确的处理这样的情况。然而刚好 lombok 可以,若超类也使用 lombok 来生成 equals 方法,那么你可以安全的使用它的 equals 方法。如果你有一个明确的超类, 你得在 callSuper 上提供一些值来表示你已经斟酌过,要不然的话就会产生一条警告信息。
当你的类没有继承至任何类(非java.lang.Object
, 当然任何类都是继承于 Object 类的),而你却将 callSuer 置为 true, 这会产生编译错误(译者注: java: Generating equals/hashCode with a supercall to java.lang.Object is pointless. )。因为这会使得生成的equals
和hashCode
方法实现只是简单的继承至 Object 类的方法,只有相同的对象并且相同的 hashCode 才会判定他们相等。若你的类继承至另一个类又没有设置 callSuper, 则会产品一个告警,因为除非超类没有(或者没有跟相等相关的)字段,否则 lombok 无法为你生成考虑超类声明字段的实现。
15、XmlAccessorType
类级别的注解
定义这个类中何种类型需要映射到 XML。
XmlAccessType.FIELD:映射这个类中的所有字段到 XML
XmlAccessType.PROPERTY:映射这个类中的属性(get/set 方法)到 XML
XmlAccessType.PUBLIC_MEMBER:将这个类中的所有 public 的 field 或 property 同时映射到 XML(默认)
XmlAccessType.NONE:不映射
16、@SuppressWarnings
Suppress ?抑制;镇压;废止 Warnings 警告?
@SuppressWarnings("resource")是 J2SE 提供的一个批注。该批注的作用是给编译器一条指令,告诉它对被批注的代码元素内部的某些警告保持静默。
@SuppressWarnings 批注允许您选择性地取消特定代码段(即,类或方法)中的警告。其中的想法是当您看到警告时,您将调查它,如果您确定它不是问题,您就可以添加一个 @SuppressWarnings 批注,以使您不会再看到警告。
虽然它听起来似乎会屏蔽潜在的错误,但实际上它将提高代码安全性,因为它将防止您对警告无动于衷 — 您看到的每一个警告都将值得注意。
三、SpringMVC 常用注解
1、@EnableWebMvc
在配置类中开启 Web MVC 的配置支持。
2、@Controller
3、@RequestMapping
用于映射 web 请求,包括访问路径和参数。
4、@ResponseBody
支持将返回值放到 response 内,而不是一个页面,通常用户返回 json 数据。
5、@RequestBody
允许 request 的参数在 request 体中,而不是在直接连接的地址后面。(放在参数前)
6、@PathVariable
用于接收路径参数,比如 @RequestMapping(“/hello/{name}”)声明的路径,将注解放在参数前,即可获取该值,通常作为 Restful 的接口实现方法。
7、@RestController
该注解为一个组合注解,相当于 @Controller 和 @ResponseBody 的组合,注解在类上,意味着,该 Controller 的所有方法都默认加上了 @ResponseBody。
8、@ControllerAdvice
全局异常处理
全局数据绑定
全局数据预处理
9、@ExceptionHandler
用于全局处理控制器里的异常。
10、@InitBinder
用来设置 WebDataBinder,WebDataBinder 用来自动绑定前台请求参数到 Model 中。
11、@ModelAttribute
(1)@ModelAttribute 注释方法?
如果把 @ModelAttribute 放在方法的注解上时,代表的是:该 Controller 的所有方法在调用前,先执行此 @ModelAttribute 方法。可以把这个 @ModelAttribute 特性,应用在 BaseController 当中,所有的 Controller 继承 BaseController,即可实现在调用 Controller 时,先执行 @ModelAttribute 方法。比如权限的验证(也可以使用 Interceptor)等。
(2)@ModelAttribute 注释一个方法的参数?
当作为方法的参数使用,指示的参数应该从模型中检索。如果不存在,它应该首先实例化,然后添加到模型中,一旦出现在模型中,参数字段应该从具有匹配名称的所有请求参数中填充。
hellorWord 方法的 userLogin 参数的值来源于 getUserLogin()方法中的 model 属性。
12、@Transactional?
@Transactional 注解放在类级别时,表示所有该类的公共方法都配置相同的事务属性信息。EmployeeService 的所有方法都支持事务并且是只读。当类级别配置了 @Transactional,方法级别也配置了 @Transactional,应用程序会以方法级别的事务属性信息来管理事务,换言之,方法级别的事务属性信息会覆盖类级别的相关配置信息。
@Transactional(propagation= Propagation.SUPPORTS,readOnly=true)
@Service(value ="employeeService")
public class EmployeeService
@Transactional 注解的属性信息
| 属性名 | 说明 |
| --- | --- |
| name | 当在配置文件中有多个 TransactionManager , 可以用该属性指定选择哪个事务管理器。 |
| propagation | 事务的传播行为,默认值为 REQUIRED。 |
| isolation | 事务的隔离度,默认值采用 DEFAULT。 |
| timeout | 事务的超时时间,默认值为-1。如果超过该时间限制但事务还没有完成,则自动回滚事务。 |
| read-only | 指定事务是否为只读事务,默认值为 false;为了忽略那些不需要事务的方法,比如读取数据,可以设置 read-only 为 true。 |
| rollback-for | 用于指定能够触发事务回滚的异常类型,如果有多个异常类型需要指定,各类型之间可以通过逗号分隔。 |
| no-rollback- for |
抛出 no-rollback-for 指定的异常类型,不回滚事务。
|
四、其它注解
1、@JsonIgnore
(1)作用
在 json 序列化时将 java bean 中的一些属性忽略掉,序列化和反序列化都受影响。
(2)使用方法
一般标记在属性或者方法上,返回的 json 数据即不包含该属性。
(3)注解失效
如果注解失效,可能是因为你使用的是 fastJson,尝试使用对应的注解来忽略字段,注解为:@JSONField(serialize = false),
使用方法一样。
2、@Schema
@schema 注解标注在 class 上,表示此类对应的数据库表对应的 schema。
可以用如下语句判断某个实体类上是否带有 @schema 注解,从而得到 schema。
bean.getClass().isAnnotationPresent(Schema.class)
五、json 常用注解
1、@JsonIgnoreProperties
此注解是类注解,作用是 json 序列化时将 java bean 中的一些属性忽略掉,序列化和反序列化都受影响。
写法将此标签加在 user 类的类名上 ,可以多个属性也可以单个属性。
//生成 json 时将 name 和 age 属性过滤
@JsonIgnoreProperties({"name"},{"age"})
public class user {
private String name;
private int age;
}
2、@JsonIgnore
此注解用于属性或者方法上(最好是属性上),作用和上面的 @JsonIgnoreProperties 一样。
//生成 json 时不生成 age 属性
public class user {
private String name;
@JsonIgnore
private int age;
}
3、@JsonFormat
此注解用于属性或者方法上(最好是属性上),可以方便的把 Date 类型直接转化为我们想要的模式,比如:
public class User{
@JsonFormat(pattern = “yyyy-MM-dd HH-mm-ss”)
private Date date;
}
评论