alias 设置别名 , 为bean设置别名 , 可以设置多个别名
<alias name="userT" alias="userNew"/>
<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="hello" class="com.loey.Hello">
<property name="str" value="mySpring"/>
bean>
beans>
团队的合作通过import来实现 .
<import resource="{path}/beans.xml"/>
1. User.java
public class User {
private String name;
2. beans.xml
<bean id="user" class="com.loey.User">
<property name="name" value="kuangshen"/>
bean>
3. 测试类
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
UserService userService = (UserService) context.getBean("userServiceImpl");
userService.getUser();
结果可以发现,在调用getUser方法之前,User对象已经通过无参构造初始化了!
beans.xml 有三种方式编写
<bean id="user" class="com.loey.User">
<constructor-arg index="0" value="pcy"/>
bean>
<bean id="user1" class="com.loey.User">
<constructor-arg name="name" value="pcy2"/>
bean>
<bean id="user2" class="com.loey.User">
<constructor-arg type="java.lang.String" value="pcy3"/>
bean>
结论:在配置文件加载的时候。其中管理的对象都已经初始化了!
要求被注入的属性 , 必须有set方法 , set方法的方法名由set + 属性首字母大写 , 如果属性是boolean类型 , 没有set方法 , 是 is .
测试pojo类 :
Address.java
public class Address {
private String address;
Student.java
public class Student {
private String name;
private Address address;
private String[] books;
private List<String> hobbys;
private Map<String,String> card;
private Set<String> games;
private String wife;
private Properties info;
<bean id="address" class="com.loey.pojo.Address" scope="prototype">
<property name="address" value="hanguo">property>
bean>
注意点:这里的值是一个引用,ref
<bean id="address" class="com.loey.pojo.Address" scope="prototype">
<property name="address" value="hanguo">property>
bean>
<bean id="student" class="com.loey.pojo.Student">
<property name="name" value="pcy">property>
<property name="address" ref="address">property>
bean>
<bean id="student" class="com.loey.pojo.Student">
<property name="name" value="pcy">property>
<property name="address" ref="address">property>
<property name="books">
<array>
<value>1value>
<value>2value>
<value>3value>
array>
property>
bean>
<property name="hobbys">
<list>
<value>avalue>
<value>bvalue>
<value>cvalue>
<value>dvalue>
list>
property>
<property name="card">
<map>
<entry key="1" value="11"/>
<entry key="2" value="22"/>
<entry key="3" value="33"/>
map>
property>
<property name="games">
<set>
<value>aavalue>
<value>bbvalue>
set>
property>
<property name="wife">
<null/>
property>
<property name="info">
<props>
<prop key="url">com.mysql.jdbc.Driverprop>
<prop key="username">urlprop>
<prop key="password">1127prop>
props>
property>
User.java : 【注意:这里必须要有参构造器!】
xmlns:p=“http://www.springframework.org/schema/p”
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="stu" class="com.loey.pojo.Student" p:name="pcy" p:address-ref="address" p:books="1,2,3"/>
xmlns:c="http://www.springframework.org/schema/c"
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:c="http://www.springframework.org/schema/c"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="stu1" class="com.loey.pojo.Student" c:name="pcyc" c:address-ref="address"/>
发现问题:爆红了,刚才我们没有写有参构造!
解决:把有参构造器加上,这里也能知道,c 就是所谓的构造器注入
在Spring中,那些组成应用程序的主体及由Spring IoC容器所管理的对象,被称之为bean。简单地讲, bean就是由IoC容器初始化、装配及管理的对象 .
几种作用域中,request、session作用域仅在基于web的应用中使用(不必关心你所采用的是什么web 应用框架),只能用在基于web的Spring ApplicationContext环境
1 Singleton
当一个bean的作用域为Singleton,那么Spring IoC容器中只会存在一个共享的bean实例,并且所有对 bean的请求,只要id与该bean定义相匹配,则只会返回bean的同一实例。Singleton是单例类型,就是 在创建起容器时就同时自动创建了一个bean的对象,不管你是否使用,他都存在了,每次获取到的对象 都是同一个对象。 注意,Singleton作用域是Spring中的缺省作用域。要在XML中将bean定义成 singleton,可以这样配置
<bean id="ServiceImpl" class="cn.csdn.service.ServiceImpl" scope="singleton">
2 Prototype
当一个bean的作用域为Prototype,表示一个bean定义对应多个对象实例。Prototype作用域的bean会 导致在每次对该bean请求(将其注入到另一个bean中,或者以程序的方式调用容器的getBean()方法) 时都会创建一个新的bean实例。Prototype是原型类型,它在我们创建容器的时候并没有实例化,而是当我们获取bean的时候才会去创建一个对象,而且我们每次获取到的对象都不是同一个对象。根据经验,对有状态的bean应该使用prototype作用域,而对无状态的bean则应该使用singleton作用域。在 XML中将bean定义成prototype,可以这样配置:
<bean id="account" class="com.foo.DefaultAccount" scope="prototype"/>
或者
<bean id="account" class="com.foo.DefaultAccount" singleton="false"/>
3 Request
当一个bean的作用域为Request,表示在一次HTTP请求中,一个bean定义对应一个实例; 即每个HTTP 请求都会有各自的bean实例,它们依据某个bean定义创建而成。该作用域仅在基于web的Spring ApplicationContext情形下有效。考虑下面bean定义:
<bean id="loginAction" class="cn.csdn.LoginAction" scope="request"/>
针对每次HTTP请求,Spring容器会根据loginAction bean的定义创建一个全新的LoginAction bean实 例,且该loginAction bean实例仅在当前HTTP request内有效,因此可以根据需要放心的更改所建实例 的内部状态,而其他请求中根据loginAction bean定义创建的实例,将不会看到这些特定于某个请求的 状态变化。当处理请求结束,request作用域的bean实例将被销毁。
4 Session
==当一个bean的作用域为Session,表示在一个HTTP Session中,一个bean定义对应一个实例。该作用域 仅在基于web的Spring ApplicationContext情形下有效。==考虑下面bean定义
<bean id="userPreferences" class="com.foo.UserPreferences" scope="session"/>
针对某个HTTP Session,Spring容器会根据userPreferences bean定义创建一个全新的 userPreferences bean实例,且该userPreferences bean仅在当前HTTP Session内有效。与request作 用域一样,可以根据需要放心的更改所创建实例的内部状态,而别的HTTP Session中根据 userPreferences创建的实例,将不会看到这些特定于某个HTTP Session的状态变化。当HTTP Session 终被废弃的时候,在该HTTP Session作用域内的bean也会被废弃掉。