您好,登錄后才能下訂單哦!
本篇內容主要講解“Spring中怎么利用IOC實現注入”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Spring中怎么利用IOC實現注入”吧!
maven依賴:
<dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.2.0.RELEASE</version> </dependency> </dependencies>
在resources文件夾下創建xml文件:
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="xxx" class="XXX"> ...... </bean> </beans>
項目結構:
在xml中使用property標簽,調用set方法進行注入。
實體類:
使用set方法注入,實體類中必須存在set方法,否則會注入失敗。
package com.eryi.beans; public class User { private String username; private String password; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } @Override public String toString() { return "User{" + "username='" + username + '\'' + ", password='" + password + '\'' + '}'; } }
xml文件:
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="user" class="com.eryi.beans.User"> <property name="username" value="admin"></property> <property name="password" value="123"></property> </bean> </beans>
測試:
public static void main(String[] args) { ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml"); User user=applicationContext.getBean("user",User.class); System.out.println(user.toString()); }
在xml文件中使用constructor-arg標簽,調用構造器進行注入。
實體類:
使用構造器注入,實體類中必須存在構造器,否則會注入失敗。
package com.eryi.beans; public class User { private String username; private String password; public User(String username, String password) { this.username = username; this.password = password; } @Override public String toString() { return "User{" + "username='" + username + '\'' + ", password='" + password + '\'' + '}'; } }
xml:
<bean id="user" class="com.eryi.beans.User"> <constructor-arg value="admin" type="java.lang.String"></constructor-arg> <constructor-arg value="123" type="java.lang.String"></constructor-arg> </bean>
測試:
public static void main(String[] args) { ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml"); User user=applicationContext.getBean("user",User.class); System.out.println(user.toString()); }
Spring支持通過注解的方式將注入實體注入IOC,然后通過注解去IOC中獲取實體。
注入IOC的注解有:
@Component、@Repository、@Service、@Controller
@Component是通用的,后面三個只是為了細化層次為各個分層上的實體推出的,功能上來說都具有將實體注入IOC的能力。
從IOC中獲取實體的注解有:
@Autowired
代碼示例:
開啟注解掃描:
需要首先在Spring的配置文件中開啟注解掃描,這樣Spring才回去配置的路徑下掃描帶有注解的Bean將其納入IOC。
public static void main(String[] args) { ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml"); User user=applicationContext.getBean("user",User.class); System.out.println(user.toString()); }
dao層:
package com.eryi.beans; import org.springframework.stereotype.Component; @Component public class UserDao { public String findAll(){ return "find all users"; } }
service:
@Component public class UserService { private UserDao userDao; @Autowired public UserService(UserDao userDao) { this.userDao = userDao; } public String findAll(){ return userDao.findAll(); } }
測試:
package com.eryi.beans; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class test { public static void main(String[] args) { ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml"); UserService userService=applicationContext.getBean("userService",UserService.class); System.out.println(userService.findAll()); } }
有兩種獲取方式:
通過id
通過類型
通過id:
UserService userService=applicationContext.getBean("userService",UserService.class);
通過類型:
UserService userService=applicationContext.getBean(UserService.class);
在Spring框架中,配置文件除了可以描述類以外,還可以描述Bean的依賴關系。
繼承關系:
<bean id="parentBean" class="com.eryi.beans.User"> <property name="username" value="father"></property> <property name="password" value="123"></property> </bean> <!--使用parent來指向父類--> <bean id="childBean" class="com.eryi.beans.User" parent="parentBean"> <property name="username" value="son"></property> </bean>
抽象:
<bean>標簽中的“abstract”屬性用于指定當前Bean是否為抽象Bean,其取值為“true”或“false”,默認為“false”。當一個Bean被指定為抽象Bean時,它不能被直接實例化,而只能作為其他Bean的父類或者模板。這個抽象Bean只是一個模板,其中可以定義一些通用的屬性或方法,供其他Bean繼承或者引用。
ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml"); User user_01=applicationContext.getBean("childBean",User.class); System.out.println(user_01); User user_02=applicationContext.getBean("parentBean",User.class); System.out.println(user_02);
一個bean在完整生命周期中會觸發的方法順序:
構造器
注入屬性(set、構造、或者命名空間)
init-method方法
生成實例對象
destroy-method(容器關閉觸發該方法)
注意:init-method、destroy-method需要配置才會生效。
配置:
<bean id="user" class="com.eryi.beans.User" init-method="init" destroy-method="destroy"> <property name="username" value="admin"></property> <property name="password" value="123"></property> </bean>
實體類:
public class User { private String username; private String password; public User() { System.out.println("construction......"); } public String getUsername() { return username; } public void setUsername(String username) { System.out.println("set......"); this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } private void init(){ System.out.println("init......"); } private void destroy(){ System.out.println("destroy......"); } @Override public String toString() { return "User{" + "username='" + username + '\'' + ", password='" + password + '\'' + '}'; } }
測試:
ClassPathXmlApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml"); User user=context.getBean("user",User.class); context.close();
四種作用域:
singleton,默認的,在IOC初始化時創建容器中的實例,全局訪問的是同一個實例。
prototype,IOC初始化時不生成實例,每次請求生成一個實例。
session,同一個Session共享一個Bean實例。不同Session使用不同的實例。
request 該屬性僅對HTTP請求產生作用,每次HTTP請求都會創建一個新的實例
global-session 所有的Session共享一個Bean實例。
到此,相信大家對“Spring中怎么利用IOC實現注入”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。