day03-Spring管理Bean-IOC-01
Spring管理Bean-IOC
1.Spring配置/管理bean介绍
- Bean管理包括两方面:
- 创建bean对象
- 给bean注入属性
- Bean的配置方式:
- 基于xml文件配置方式
- 基于注解配置方式
2.基于XML配置bean
2.1通过类型来获取bean
通过id来获取bean在Spring基本介绍中已经使用过,这里不再赘叙
2.1.1应用案例
案例说明:
- 通过spring的ioc容器,获取一个bean对象
- 说明:获取bean的方式:按类型
完成步骤:
- 创建一个Java对象Monster.java
- 在beans.xml中配置
Monster.java:
package com.li.bean;
/**
* @author 李
* @version 1.0
* Javabean / Entity
*/
public class Monster {
private Integer monsterId;
private String name;
private String skill;
//无参构造器一定要有,spring底层反射创建对象时需要使用
public Monster() {
}
public Monster(Integer monsterId, String name, String skill) {
this.monsterId = monsterId;
this.name = name;
this.skill = skill;
}
public Integer getMonsterId() {
return monsterId;
}
public void setMonsterId(Integer monsterId) {
this.monsterId = monsterId;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSkill() {
return skill;
}
public void setSkill(String skill) {
this.skill = skill;
}
@Override
public String toString() {
return "Monster{" +
"monsterId=" + monsterId +
", name='" + name + '\'' +
", skill='" + skill + '\'' +
'}';
}
}
beans.xml:
<!--配置Monster,希望通过类型来获取-->
<bean class="com.li.bean.Monster" >
<property name="monsterId" value="10086"/>
<property name="name" value="孙悟空"/>
<property name="skill" value="筋斗云"/>
</bean>
SpringBeanTest:
package com.li.test;
import com.li.bean.Monster;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.testng.annotations.Test;
/**
* @author 李
* @version 1.0
*/
public class SpringBeanTest {
//通过Bean的类型来获取对象
@Test
public void getBeanByType() {
ApplicationContext ioc =
new ClassPathXmlApplicationContext("beans.xml");
//直接传入class对象/类型
Monster bean = ioc.getBean(Monster.class);
System.out.println(bean);
}
}
2.1.2细节说明
按照类型来获取bean,要求ioc容器中的同一个类的bean只能有一个,否则会抛出异常NoUniqueBeanDefinitionException
用类型来获取bean的应用场景:XxxAction/Servlet/Controller或者XxxService,在一个线程中只需要一个对象实例的情况(单例情况)
在容器配置文件(比如beans.xml)中给属性值,底层是通过setter方法完成的,这也是为什么需要在java对象中提供setter方法,否则会报错
2.2通过构造器配置bean
2.2.1应用实例
案例说明:
使用spring的ioc容器,可以通过构造器来来配置bean对象
完整步骤:
- 配置bean.xml
在beans.xml配置:
前提是Monster类中有对应的构造器
<!--配置Monster对象,并指定构造器-->
<!--
1. constructor-arg 标签可以指定使用构造器的参数
2. index 表示构造器的第几个参数,从0开始计算
3. 除了通过index,还可以通过 name/ type 的方式来指定参数
4. 类构造器可以有多个,但是不能有参数完全相同的类型和顺序的构造器,
这就决定了 通过构造器参数type 可以唯一确定一个构造器)
-->
<bean id="monster03" class="com.li.bean.Monster">
<constructor-arg value="200" index="0"/>
<constructor-arg value="白骨精" index="1"/>
<constructor-arg value="吸血" index="2"/>
</bean>
<!--通过 name 的方式来指定参数-->
<bean id="monster04" class="com.li.bean.Monster">
<constructor-arg value="200" name="monsterId"/>
<constructor-arg value="白骨精" name="name"/>
<constructor-arg value="吸血" name="skill"/>
</bean>
<!--通过 type 的方式来指定参数-->
<bean id="monster05" class="com.li.bean.Monster">
<constructor-arg value="200" type="java.lang.Integer"/>
<constructor-arg value="白骨精" type="java.lang.String"/>
<constructor-arg value="吸血" type="java.lang.String"/>
</bean>
SpringBeanTest:
package com.li.test;
import com.li.bean.Monster;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.testng.annotations.Test;
import java.io.File;
/**
* @author 李
* @version 1.0
*/
public class SpringBeanTest {
//通过构造器来设置属性
@Test
public void setBeanConstructor() {
ApplicationContext ioc =
new ClassPathXmlApplicationContext("beans.xml");
Monster monster03 = ioc.getBean("monster03", Monster.class);
System.out.println("monster03=" + monster03);
}
}
2.2.2细节说明
- 通过index属性来区分是第几个参数
- 通过type属性来区分是什么类型(按照顺序)
2.3通过p名称空间配置bean
2.3.1应用实例
案例说明:
在spring的ioc容器,可以通过p名称空间来配置bean对象
完成步骤:
- 在beans.xml配置,增加命名空间配置,如下,点击Create namespace declaration,成功后在配置文件头会自动添加xmlns
beans.xml:
<?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:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--通过p名称空间来配置bean
将光标放在p,输入alt+enter,就会自动添加 xmlns
-->
<bean id="monster06" class="com.li.bean.Monster"
p:monsterId="500"
p:name="红孩儿"
p:skill="风火轮"
/>
</beans>
SpringBeanTest:
package com.li.test;
import com.li.bean.Monster;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.testng.annotations.Test;
/**
* @author 李
* @version 1.0
*/
public class SpringBeanTest {
//通过p名称空间来设置属性
@Test
public void setBeanByP() {
ApplicationContext ioc =
new ClassPathXmlApplicationContext("beans.xml");
Monster monster06 = ioc.getBean("monster06", Monster.class);
System.out.println("monster06=" + monster06);
}
}
2.3.2细节说明
注意要引入p名称空间
2.4引用/注入其他bean对象
2.4.1应用实例
案例说明:
在spring的ioc容器中,可以通过 ref (reference)来实现bean对象的相互应用
完成步骤:
- 创建MemberDAOImpl.java,MemberServiceImpl.java
- 配置beans.xml
beans.xml:
<!--配置MemberDAOImpl对象-->
<bean class="com.li.dao.MemberDAOImpl" id="memberDAO"/>
<!--配置MemberServiceImpl对象
1.ref="memberDAO" 表示
MemberServiceImpl 对象的属性memberDAO 引用的对象是id=memberDAO的对象
2.这就体现了spring容器的依赖注入
3.注意在spring容器中,是作为一个整体来执行的,也就是说如果你引用到了一个bean对象,对你配置的顺序没有要求
(在底层,对spring配置文件进行扫描,将关联的关系自动梳理,并放到beanDefinitionMap中,
也就是说,是从beanDefinitionMap中查找关联关系的。与spring配置文件的配置顺序无关)
4.但是建议按照顺序配置,易于阅读
-->
<bean class="com.li.service.MemberServiceImpl" id="memberService">
<property name="memberDAO" ref="memberDAO"/>
</bean>
MemberDAOImpl:
package com.li.dao;
/**
* @author 李
* @version 1.0
* DAO 对象
*/
public class MemberDAOImpl {
//构造器
public MemberDAOImpl() {
System.out.println("MemberDAOImpl 构造器...");
}
//方法
public void add() {
System.out.println("MemberDAOImpl add()方法被执行");
}
}
MemberServiceImpl:
package com.li.service;
import com.li.dao.MemberDAOImpl;
/**
* @author 李
* @version 1.0
* Service类
*/
public class MemberServiceImpl {
private MemberDAOImpl memberDAO;
public MemberDAOImpl getMemberDAO() {
return memberDAO;
}
public void setMemberDAO(MemberDAOImpl memberDAO) {
this.memberDAO = memberDAO;
}
public void add() {
System.out.println("MemberServiceImpl add() 方法被调用...");
memberDAO.add();
}
}
SpringBeanTest:
package com.li.test;
import com.li.service.MemberServiceImpl;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.testng.annotations.Test;
/**
* @author 李
* @version 1.0
*/
public class SpringBeanTest {
//通过ref 来设置 bean属性
@Test
public void setBeanByRef() {
ApplicationContext ioc =
new ClassPathXmlApplicationContext("beans.xml");
MemberServiceImpl memberService =
ioc.getBean("memberService", MemberServiceImpl.class);
memberService.add();
}
}
2.4.2细节说明
注意:在spring容器中,是作为一个整体来执行的,也就是说如果你引用到了一个bean对象,对你配置的顺序没有要求。例如这里的例子,如果我们将Memb erDAOImpl对象的配置,放到MemberServiceImpl对象的配置之后也是可以的。
因为在底层,会对spring的配置文件进行扫描,将关联的关系自动梳理,并放到beanDefinitionMap中。
也就是说,是从beanDefinitionMap中查找关联关系的。与spring配置文件的配置顺序无关。
但是建议按照顺序配置,易于阅读
2.5引入/注入内部bean对象
2.5.1应用实例
案例说明:
在spring的ioc容器中,可以直接配置内部bean对象
完成步骤:
- 创建MemberDAOImpl.java,MemberServiceImpl.java
- 配置beans.xml
创建MemberDAOImpl.java,MemberServiceImpl.java(见2.4)
beans.xml:
<!--配置MemberService对象(使用内部bean)-->
<bean class="com.li.service.MemberServiceImpl" id="memberService2">
<!--自己配置一个内部bean-->
<property name="memberDAO">
<bean class="com.li.dao.MemberDAOImpl"/>
</property>
</bean>
SpringBeanTest:
package com.li.test;
import com.li.service.MemberServiceImpl;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.testng.annotations.Test;
/**
* @author 李
* @version 1.0
*/
public class SpringBeanTest {
//通过内部 bean来设置 bean属性
@Test
public void setBeanByProper() {
ApplicationContext ioc =
new ClassPathXmlApplicationContext("beans.xml");
MemberServiceImpl memberService2 =
ioc.getBean("memberService2", MemberServiceImpl.class);
memberService2.add();
}
}
2.6引用/注入集合/数组类型
2.6.1应用实例
案例说明
在spring的ioc容器中,看看如何给bean对象的集合/数组类型属性赋值
完成步骤:
- 创建Monster.java
- 创建Master.java
- 配置beans.xml
Monster.java:见2.1
Master.java:
package com.li.bean;
import java.util.*;
/**
* @author 李
* @version 1.0
* Master类
*/
public class Master {
private String name;
private List<Monster> monsterList;
private Map<String, Monster> monsterMap;
private Set<Monster> monsterSet;
//数组
private String[] monsterName;
// Properties 是 Hashtable 的子类,也是k-v形式
// 这里Properties 的key和value都是String类型
private Properties pros;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List<Monster> getMonsterList() {
return monsterList;
}
public void setMonsterList(List<Monster> monsterList) {
this.monsterList = monsterList;
}
public Map<String, Monster> getMonsterMap() {
return monsterMap;
}
public void setMonsterMap(Map<String, Monster> monsterMap) {
this.monsterMap = monsterMap;
}
public Set<Monster> getMonsterSet() {
return monsterSet;
}
public void setMonsterSet(Set<Monster> monsterSet) {
this.monsterSet = monsterSet;
}
public String[] getMonsterName() {
return monsterName;
}
public void setMonsterName(String[] monsterName) {
this.monsterName = monsterName;
}
public Properties getPros() {
return pros;
}
public void setPros(Properties pros) {
this.pros = pros;
}
@Override
public String toString() {
return "Master{" +
"name='" + name + '\'' +
", monsterList=" + monsterList +
", monsterMap=" + monsterMap +
", monsterSet=" + monsterSet +
", monsterName=" + Arrays.toString(monsterName) +
", pros=" + pros +
'}';
}
}
beans.xml:
<!--配置Master对象-->
<!--体会Spring容器配置特点-->
<bean class="com.li.bean.Master" id="master">
<property name="name" value="太上老君"/>
<!--(1)给list属性赋值-->
<property name="monsterList">
<list>
<!--方式1.引用的方式-->
<ref bean="monster01"/>
<ref bean="monster02"/>
<!--方式2.内部bean-->
<bean class="com.li.bean.Monster">
<property name="name" value="黄袍怪"/>
<property name="monsterId" value="1024"/>
<property name="skill" value="吃人"/>
</bean>
</list>
</property>
<!--(2)给map属性赋值-->
<property name="monsterMap">
<map>
<entry>
<key>
<value>monster01</value>
</key>
<!--也可以通过内部 bean来配置,这里使用引用-->
<ref bean="monster01"/>
</entry>
<entry>
<key>
<value>monster02</value>
</key>
<!--也可以通过内部 bean来配置,这里使用引用-->
<ref bean="monster02"/>
</entry>
</map>
</property>
<!--(3)给set属性赋值-->
<property name="monsterSet">
<set>
<!--同理,依然可以使用ref或者内部 bean的方式配置-->
<ref bean="monster05"/>
<bean class="com.li.bean.Monster">
<property name="name" value="金角大王"/>
<property name="monsterId" value="888"/>
<property name="skill" value="有钱"/>
</bean>
</set>
</property>
<!--(4)给数组属性赋值-->
<property name="monsterName">
<array>
<!--这里根据数组的类型来选择对应的标签-->
<value>小猪妖</value>
<value>大鹏妖</value>
<value>老狐狸</value>
<!--同理,依然可以使用ref或者内部 bean的方式配置-->
</array>
</property>
<!--(5)给Properties属性赋值,结构 k(String)-v(String)-->
<property name="pros">
<props>
<prop key="username">root</prop>
<prop key="pwd">1234</prop>
<prop key="ip">127.0.0.1</prop>
</props>
</property>
</bean>
SpringBeanTest:
package com.li.test;
import com.li.bean.Master;
import com.li.bean.Monster;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.testng.annotations.Test;
import java.util.Iterator;
import java.util.Map;
/**
* @author 李
* @version 1.0
*/
public class SpringBeanTest {
//给集合/数组属性进行配置值
@Test
public void setBeanByCollection() {
ApplicationContext ioc =
new ClassPathXmlApplicationContext("beans.xml");
Master master = ioc.getBean("master", Master.class);
System.out.println("========master的list属性=========");
for (Monster monster : master.getMonsterList()) {
System.out.println(monster);
}
System.out.println("\n========master的map属性=========");
Iterator<Map.Entry<String, Monster>> iterator =
master.getMonsterMap().entrySet().iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next());
}
System.out.println("\n========master的set属性=========");
for (Monster monster : master.getMonsterSet()) {
System.out.println(monster);
}
System.out.println("\n========master的数组属性=========");
for (int i = 0; i < master.getMonsterName().length; i++) {
System.out.println(master.getMonsterName()[i]);
}
System.out.println("\n========master的Properties属性=========");
Iterator<Map.Entry<Object, Object>> iterator1
= master.getPros().entrySet().iterator();
while (iterator1.hasNext()) {
System.out.println(iterator1.next());
}
}
}
2.6.2细节说明
主要掌握List/Map/Properties三种集合的使用
Properties集合的特点:
(1)Properties是Hashtable的子类,也是key-value形式
(2)key是String类型,value也是String类型
day03-Spring管理Bean-IOC-01的更多相关文章
- (转)编码剖析Spring管理Bean的原理
http://blog.csdn.net/yerenyuan_pku/article/details/52832434 在Spring的第一个案例中,我们已经知道了怎么将bean交给Spring容器进 ...
- 采用Spring管理Bean和依赖注入
1. 实例化spring容器和从容器获取Bean对象 实例化Spring容器常用的两种方式: 方法一: 在类路径下寻找配置文件来实例化容器 [推荐使用] ApplicationContext ctx ...
- Spring管理bean的生命周期
1: bean的创建: 如果我们默认的scope配置为Singleton的话, bean的创建实在Spring容器创建的时候创建: 如果scope的配置为Prototype的话,bena的创建是在 ...
- Spring、编码剖析Spring管理Bean的原理
引入dom4j jar包 1.新建Person接口和PersonBean public interface PersonIService { public void helloSpring(); } ...
- Spring第三弹—–编码剖析Spring管理Bean的原理
先附一下编写的Spring容器的执行结果: 代码如下: 模拟的Spring容器类: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 ...
- Spring——管理Bean的生命周期
我们可以自定义bean的初始化和销毁方法,这里所指的的初始化和bean的构造不同,初始化是在bean构造完成后,对bean内部的属性或一些逻辑进行初始化. 首先要弄清一些概念: 构造(对象创建) 单实 ...
- 编码剖析Spring管理bean的原理
project目录 MyClassPathXMLApplicationContext读取xml,以及实例化bean. 因为是一开始实例化配置文件所有bean,所以需要构造器完成这些工作. packag ...
- Spring管理Bean的三种创建方式
1.使用类构造器实例化 (90%以上都是使用这种) <bean id=“orderService" class="cn.itcast.OrderServiceBean&qu ...
- 简单模拟Spring管理Bean对象
1: 首先我们要利用dom4j进行xml的解析,将所有的bean的配置读取出来. 2:利用java的反射机制进行对象的实例化. 3: 直接获得对象 package cn.Junit.test; imp ...
- spring 管理bean
目录结构: Person.java package com.wss.entity; import com.wss.service.doHomeWork; public class Person { p ...
随机推荐
- springboot项目中使用shiro实现用户登录以及权限的验证
欢迎大家加入我的社区:http://t.csdn.cn/Q52km 社区中不定时发红包 更加高级的验证用户权限:用户表.角色表.权限表.多表联合:https://blog.csdn.net/weixi ...
- SpringBoot→Maven项目快速搭建
使用软件 :SpringToolSuite4 打开软件后在Package Explorer 栏中点击右键 Spring starter project 等待反应 填写完毕之后点击next fi ...
- 八、Django的组件
8.1.中间件 中间件顾名思义,是介于request与response处理之间的一道处理过程,相对比较轻量级,并且在全局上改变django的输入与输出.因为改变的是全局,所以需要谨慎实用,用不好会影响 ...
- 开源网络协议栈onps诞生记
小孩没娘,说来话长,一切都要从LwIP说起.大约是06年9月,本人在二姨的坛口发布了一篇小文--<uC/OS-II 平台下的 LwIP 移植笔记>.自此一发不可收拾,开启了一段我与LwIP ...
- CH58X/CH57X/V208 Observer(观察者)例程讨论讲解
使用的是沁恒的CH582M的Observer例程与官方的demo板. 本例程的功能是主机扫描到从机的MAC地址并打印出来. 先对宏定义进行理解讨论. 最大响应扫描数为8,在串口调试助手那里可以看到打印 ...
- 【红队技巧】Windows存储的密码获取
[红队技巧]Windows存储的密码获取 免责声明: 使用前提 支持版本 利用方式 参考: 免责声明: 本文章仅供学习和研究使用,严禁使用该文章内容对互联网其他应用进行非法操作,若将其用于非法目的,所 ...
- 为什么Linux需要虚拟内存 [转载好文]
操作系统中的 CPU 和主内存(Main memory)都是稀缺资源,所有运行在当前操作系统的进程会共享系统中的 CPU 和内存资源,操作系统会使用 CPU 调度器分配 CPU 时间1并引入虚拟内存系 ...
- (C++) C++ template笔记 -- template关键字及typename关键字
在调用C++ template函数时,有时候语法会存在歧义. 调用函数时,使用 obj.template func<...>() 形式的语法,避免歧义: 调用类型时,使用嵌入子类型时,使用 ...
- C++编程笔记(QT)
目录 入门基础 模态对话框 消息提示框(messagebox) 文件和目录 字体选择框 输入对话框 进度条 工具栏 控件布局 Windows托盘案例 控件 button 下拉菜单按钮 `radioBu ...
- go-carbon 1.5.2版本发布, 修复已知 bug 和新增功能及葡萄牙语翻译文件
carbon 是一个轻量级.语义化.对开发者友好的golang时间处理库,支持链式调用. 目前已被 [awesome-go](https://github.com/avelino/awesome-go ...