Spring常用註解(註解對應的XML標籤)
項目結構
配置文件
-
pom.xml
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.xiaoge</groupId> <artifactId>annotation_ioc</artifactId> <version>1.0-SNAPSHOT</version> <packaging>jar</packaging> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.0.2.RELEASE</version> </dependency> </dependencies> </project>
-
bean.xml注意這裏的約束–這裏使用註解來開發
<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"> <!-- 告知spring在創建容器時要掃描的包, 配置所需要的標籤不是在bean的約束中, 而是一個名稱爲context名稱空間和約束中 --> <!-- base-package: 指定了包, 它就會掃描這個包下及其子包, 所有類上和接口上的註解 --> <context:component-scan base-package="com.xiaoge"></context:component-scan> </beans>
持久層
-
AccountDao接口
package com.xiaoge.dao; /** * @Author: 瀟哥 * @DateTime: 2020/3/19 下午7:31 * @Description: TODO */ public interface AccountDao { public void saveAccount(); }
-
AccountDaoImpl實現類
package com.xiaoge.dao.impl; import com.xiaoge.dao.AccountDao; import org.springframework.stereotype.Repository; /** * @Author: 瀟哥 * @DateTime: 2020/3/19 下午7:31 * @Description: TODO */ @Repository("accountDao1") public class AccountDaoImpl implements AccountDao { public void saveAccount() { System.out.println("保存成功11111!"); } }
-
AccountDaoImpl2實現類
package com.xiaoge.dao.impl; import com.xiaoge.dao.AccountDao; import org.springframework.stereotype.Repository; /** * @Author: 瀟哥 * @DateTime: 2020/3/19 下午7:31 * @Description: TODO * * 這樣 AccountDaoImpl 和 AccountDaoImpl2都瞞足 */ @Repository("accountDao2") public class AccountDaoImpl2 implements AccountDao { public void saveAccount() { System.out.println("保存成功22222!"); } }
業務層
-
AccountService接口
package com.xiaoge.service; /** * @Author: 瀟哥 * @DateTime: 2020/3/19 下午7:26 * @Description: 賬戶業務層接口 */ public interface AccountService { /** * 模擬保存 */ public void saveAccount(); }
-
AccountServiceImpl實現類(重點註釋中的註解對應的xml標籤)
package com.xiaoge.service.impl; import com.xiaoge.dao.AccountDao; import com.xiaoge.service.AccountService; import org.springframework.context.annotation.Scope; import org.springframework.stereotype.Service; import javax.annotation.PostConstruct; import javax.annotation.PreDestroy; import javax.annotation.Resource; /** * @Author: 瀟哥 * @DateTime: 2020/3/19 下午7:28 * @Description: 賬戶業務層實現類 * * XML的配置 * <bean id="accountService" class="com.xiaoge.service.impl.AccountServiceImpl" * scope="" init-method="" destroy-method=""> * <property name="" value="" ref=""></property> * </bean> * * 用於創建對象的 * 他們的作用就和在XML配置文件中編寫一個<bean>標籤實現的功能是一樣的 * @Component * 作用: 用於把當前類對象存入spring容器中 * 屬性: * value: 用於指定bean的id. 當我們不寫時, 它的默認值是當前類名, 且首字母改小寫. * @Controller: 一般用在表現層 * @Service: 一般用在業務層 * @Respository: 一般用在持久層 * 以上三個註解他們的作用和屬性與Component是一模一樣. * 他們三個是spring框架爲我們提供明確的三層使用的註解, 使我們三層對象更加清晰 * * * * * * 用於注入數據的 * 他們的作用就和在XML配置文件中的bean標籤中寫一個<property>標籤的作用是一樣的 * @Autowired: * 作用: 自動按照類型注入. 只要容器中有唯一的一個bean對象類型和要注入的變量類型匹配. 就可以注入成功. * 如果IOC容器中沒有任何bean的類型和要注入的變量類型匹配, 則報錯. * 如果IOC容器中有多個類型匹配時: * 出現位置: * 可以在變量上, 也可以是方法上. * 細節: * 在使用註解注入時, set方法就不是必須的了. * * @Qualifier:(不能獨立使用, 依賴@Autowired) * 作用: 在按照類中注入的基礎之上在按照名稱注入. 它在給類成員注入時不能單獨使用. 但是在給方法參數注入時可以 * 屬性: * value: 用於指定注入bean的id. * * @Resource * 作用: 直接按照bean的id注入. 它可以獨立使用 * 屬性: * name: 用於指定bean的id. * * 以上三個注入都只能注入其他bean類型的數據, 而基本類型和String類型無法使用上述註解實現. * 另外, 集合類型的注入只能通過XML實現. * * @Value * 作用: 用於注入基本類型和String類型的數據 * 屬性: * value: 用於指定數據的值. 它可以使用spring中SpEL(也就是spring的el表達式) * SpEL的寫法: ${表達式} * * * 用於改變作用範圍的 * 他們的作用就和在bean標籤中使用scope屬性實現的功能是一樣的 * @Scope: 跟XML裏一樣 5 個取值 默認是singleton(單例) * 作用: 用於指定bean的作用範圍 * 屬性: * value: 指定範圍的取值. 常用取值: singleton prototype * * * 和生命週期相關 * 他們的作用就和在bean標籤中使用init-method和destroy-method的作用是一樣的 * @PreDestroy * 作用: 用於指定銷燬方法 * @PostConstruct * 作用: 用於指定初始化方法 */ @Service("accountService") @Scope("singleton") public class AccountServiceImpl implements AccountService { // @Autowired // 它會自動取核心容器(map集合 找值, 鍵都不會匹配的)中找AccountDao類型匹配的唯一個bean, 那就是我們用註解修飾了的@Repository AccountDaoImpl類 // @Qualifier("accountDao1") @Resource(name = "accountDao2") private AccountDao accountDao; @PostConstruct public void init(){ System.out.println("初始化成功!"); } @PreDestroy public void destroy(){ System.out.println("銷燬成功!"); } public void saveAccount() { accountDao.saveAccount(); } }
入口
-
Client
package com.xiaoge.ui; import com.xiaoge.service.AccountService; import com.xiaoge.service.impl.AccountServiceImpl; import org.springframework.context.support.ClassPathXmlApplicationContext; /** * @Author: 瀟哥 * @DateTime: 2020/3/19 下午7:35 * @Description: 模擬表現層, 調用業務層 */ public class Client { /** * @param args */ public static void main(String[] args) { // 1. 獲取核心容器對象 ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml"); // 2. 獲取service對象 AccountService as = ac.getBean("accountService", AccountServiceImpl.class); // System.out.println(as); as.saveAccount(); // 釋放容器 ac.close(); // AccountDao ad = ac.getBean("accountDao", AccountDaoImpl.class); // System.out.println(ad); // 運行結果 初始化成功! 保存成功22222! 銷燬成功! } }