一、@Resource与@Component
SR-250标准注解,推荐使用它来代替Spring专有的@Autowired注解。
@Resource的作用相当于@Autowired,只不过 @Autowired按byType自动注入,而@Resource默认按byName自动注入罢了。
@Resource有两个属性是比较重要的,分别是 name 和 type,Spring将 @Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。
所以如果使用name属性,则使用byName的自 动注入策略,而使用type属性时则使用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动 注入策略。
1、@Resource装配顺序:
(1)如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常
(2)如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常
(3)如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常
(4)如果既没有指定name,又没有指定type,则自动按照byName方式进行装配(见2)。如果没有匹配,则回退为一个原始类型(UserDao)进行匹配,如果匹配则自动装配。
二、@Autowired
在java代码中使用@Autowired或@Resource注解方式进行装配,这两个注解的区别是:@Autowired 默认按类型装配,@Resource默认按名称装配,当找不到与名称匹配的bean才会按类型装配。
@Autowired注解是按类型装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它required属性为false。
三、@PostConstruct注解
@PostConstruct注解好多人以为是Spring提供的,其实是Java自己的注解。
Java中该注解的说明:@PostConstruct 该注解被用来修饰一个非静态的 void() 方法。
被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器执行一次。PostConstruct在构造函数之后执行,init() 方法之前执行。
通常我们会是在Spring框架中使用到@PostConstruct注解,该注解的方法在整个Bean初始化中的执行顺序:
Constructor(构造方法) -> @Autowired(依赖注入) -> @PostConstruct(注释的方法)
@PostConstruct的应用:比如我们在 servlet 里拿token或解析token时需要分不同环境,那么我们就可以利用这个注解,去提前取得这个环境设置的不同的值。(这个是我们在springSecurity里的token处理时用到的,所以查了一下具体是什么意思)
@PostConstruct
public void setSecret() {
if (envService.isProd()) {
SECRET = "TokenSecret";
} else {
SECRET = "TestTokenSecret";
}
}
四、@Mapper注解的作用
1、为了把mapper这个DAO交給Spring管理
我们定义DemoMapper类,但是并没有在该类上定义类似@Service或者@Controller之类的注解,那么为什么可以被Spring管理呢?
(1)方式一:使用@Mapper注解:为了让DemoMapper能够让别的类进行引用,我们可以在DemMapper类上添加@Mapper注解。
@Mapper
public interface DemoMapper {
@Insert("insert into Demo(name) values(#{name})")
@Options(keyProperty="id",keyColumn="id",useGeneratedKeys=true)
public void save(Demo demo);
}
直接在Mapper类上面添加注解@Mapper,这种方式要求每一个mapper类都需要添加此注解,麻烦。
(2)方式二:使用@MapperScan注解:通过使用@MapperScan可以指定要扫描的Mapper类的包的路径,比如:
@SpringBootApplication
@MapperScan("com.kfit.*.mapper")
public class App {
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
可以根据包的结构指定不同的表达式。
使用@MapperScan注解多个包:可以使用如下的方式指定多个包:
@SpringBootApplication
@MapperScan({"com.kfit.*.mapper","org.kfit.*.mapper"})
public class App {
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
2、为了不再写mapper映射文件:从mybatis3.4.0开始加入了@Mapper注解,目的就是为了不再写mapper映射文件。
/**
* 添加了@Mapper注解之后这个接口在编译时会生成相应的实现类
*
* 需要注意的是:这个接口中不可以定义同名的方法,因为会生成相同的id
* 也就是说这个接口是不支持重载的
*/
@Mapper
public interface UserDAO {}
3、为了给mapper接口 自动根据一个添加@Mapper注解的接口生成一个实现类。