• SpringBoot常用注解:@Resource/@Component与@Autowired的使用、@PostConstruct注解、@Mapper注解的作用


    一、@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) {  
               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注解的接口生成一个实现类。

  • 相关阅读:
    从0开始学Swift笔记整理(二)
    从0开始学Swift笔记整理(一)
    JAVA反射机制
    Spring基础知识汇总
    关于类和对象的进一步讨论 C++
    C++ 共用体 枚举类型 所有
    自定义数据类型 C++ 结构体类型 共同体类型 枚举类型 类类型{}
    C++ 指针 引用 变量引用
    函数和指针 C++
    C++字符串与指针 所有的内容也就这么多了。
  • 原文地址:https://www.cnblogs.com/goloving/p/14902767.html
Copyright © 2020-2023  润新知