SpringBoot常⽤注解:@Resource@Component与
@Autowired。。。
⼀、@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处理时⽤到的,所以查了⼀下具体是什么意思)
private static String SECRET;
@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) {
resource和autowired注解的区别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注解的接⼝⽣成⼀个实现类。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论