1. 程式人生 > 其它 >Spring入門系列-使用註解開發

Spring入門系列-使用註解開發

使用註解開發

在spring4之後,想要使用註解形式,必須得要引入aop的包

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xmlns:context="http://www.springframework.org/schema/context"
      xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context.xsd">

</beans>

Bean的實現

我們之前一直都是使用bean的標籤來進行bean的注入,但是在實際的開發過程中,我們一般都會使用註解!

  1. 制定註解掃描包
<!--指定註解掃描包-->
<context:component-scan base-package="com.kuang.pojo"/>
  1. 在指定的包下編寫類,增加註解
package com.dreamcold.demo.pojo;

import org.springframework.stereotype.Component;

@Component("user")
//相當於在配置檔案中<bean id="user" class="當前註解的類"/>
public class User {
    private String name="dreammcold";
}
  1. 測試
package com.dreamcold.demo;

import com.dreamcold.demo.pojo.User;
import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class HelloTest {

    @Test
    public void test(){
        ApplicationContext context=new ClassPathXmlApplicationContext("beans.xml");
        //我們的物件都在Spring中管理
        User user=(User)context.getBean("user");
        System.out.println(user.name);
    }
}

屬性注入

使用註解注入屬性

  1. 可以不使用set方法,直接在直接名上新增@value("值")
package com.dreamcold.demo.pojo;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component("user")
//相當於在配置檔案中<bean id="user" class="當前註解的類"/>
public class User {
   
   @Value("dreamcold")
   public String name;
}

  1. 如果提供set方法,在set方法上新增@value("值");
package com.dreamcold.demo.pojo;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component("user")
//相當於在配置檔案中<bean id="user" class="當前註解的類"/>
public class User {

   public String name;

   @Value("dreamcold")
   public void setName(String name) {
      this.name = name;
   }
}

衍生註解

我們這些註解就是替代了在配置檔案當中配置步驟而已,更加的方便快捷!

為了更好的進行分層,spring提供了可以使用的其他三個註解,功能一樣,目前使用哪一個功能都一樣。

  • controller:web層
  • service層:service層
  • repository:dao層

寫上這些註解,就相當於將這個類交給spring管理裝配了

自動裝配註解

在bean的自動裝配已經講過了,可以回顧!

作用域

@scope

  • singleton;預設的,spring會採用單例的模式建立這個物件,關閉工程,所有的物件都會銷燬

  • prototype:多例模式,關閉工程,所有的物件都不會銷燬。內部的垃圾回收機制會回收

package com.dreamcold.demo.pojo;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;

@Component("user")
//相當於在配置檔案中<bean id="user" class="當前註解的類"/>
@Scope("prototype")
public class User {

   public String name;

   @Value("dreamcold")
   public void setName(String name) {
      this.name = name;
   }
}

小結

  • xml可以應用於任何的常見,結構清晰,方便維護
  • 註解不是自己提供的類使用不了,開發簡單方便

xml與註解整合開發:推薦最佳實踐

  • xml管理bean
  • 註解完成屬性注入
  • 使用過程中,可以不用掃描,掃描是為了類上加註解
<context:annotation-config/>  

作用:

  • 進行註解驅動註冊,從而使得註解生效
    -用於啟用那些已經在spring容器註解過的bean上面的註解,也就是顯示的向spring註冊
  • 如果不掃描包,就需要手動的配置bean
  • 如果不加註解驅動,就注入的值為null

基於Java類進行配置

  • JavaConfig是Spring的一個子專案
  • 它通過Java類的方式提供Bean的定義資訊,在Spring4的版本,JavaConfig已經成為Spring4的核心功能
  1. 編寫一個實體類,Dog
package com.dreamcold.demo.pojo;


import org.springframework.stereotype.Component;

@Component
public class Dog {
    public String name="dog";
}

  1. 新建一個config配置包,編寫一個MyConig配置類
package com.dreamcold.demo.config;

import com.dreamcold.demo.pojo.Dog;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MyConfig {
    
    //通過方法註冊一個bean,這裡的返回值就是Bean的型別,方法名就是bean的id
    @Bean
    public Dog dog(){
        return  new Dog();
    }
}

  1. 測試
package com.dreamcold.demo;

import com.dreamcold.demo.config.MyConfig;
import com.dreamcold.demo.pojo.Dog;
import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class TestDemo02 {

    @Test
    public void test2(){
        ApplicationContext applicationContext=new AnnotationConfigApplicationContext(MyConfig.class);
        Dog dog=(Dog)applicationContext.getBean("dog");
        System.out.println(dog.name);
    }
}

匯入其他配置

  1. 我們再編寫一個配置類
package com.dreamcold.demo.config;

import org.springframework.context.annotation.Configuration;

@Configuration
public class MyConfig2 {
}

  1. 在之前的配置類中我們來選擇匯入這個配置類
package com.dreamcold.demo.config;

import com.dreamcold.demo.pojo.Dog;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;

@Configuration
@Import(MyConfig.class)
public class MyConfig {

    //通過方法註冊一個bean,這裡的返回值就是Bean的型別,方法名就是bean的id
    @Bean
    public Dog dog(){
        return  new Dog();
    }
}

關於這種Java類的配置方式,我們在之後的SpringBoot 和 SpringCloud中還會大量看到,我們需要知道這些註解的作用即可!

學習自連結:狂神說