Spring入門系列-使用註解開發
阿新 • • 發佈:2021-06-27
使用註解開發
在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的注入,但是在實際的開發過程中,我們一般都會使用註解!
- 制定註解掃描包
<!--指定註解掃描包-->
<context:component-scan base-package="com.kuang.pojo"/>
- 在指定的包下編寫類,增加註解
package com.dreamcold.demo.pojo; import org.springframework.stereotype.Component; @Component("user") //相當於在配置檔案中<bean id="user" class="當前註解的類"/> public class User { private String name="dreammcold"; }
- 測試
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); } }
屬性注入
使用註解注入屬性
- 可以不使用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;
}
- 如果提供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的核心功能
- 編寫一個實體類,Dog
package com.dreamcold.demo.pojo;
import org.springframework.stereotype.Component;
@Component
public class Dog {
public String name="dog";
}
- 新建一個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();
}
}
- 測試
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);
}
}
匯入其他配置
- 我們再編寫一個配置類
package com.dreamcold.demo.config;
import org.springframework.context.annotation.Configuration;
@Configuration
public class MyConfig2 {
}
- 在之前的配置類中我們來選擇匯入這個配置類
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中還會大量看到,我們需要知道這些註解的作用即可!
學習自連結:狂神說