spring的显示装配bean(1)------通过XML文件装配
1:spring环境的简单搭建
(1)导入spring相关的jar包。
2:准备要进行装配的Java类
这里给出两个举例类
(1)
(2)
3:配置XML文件
(1)在配置文件的顶部声明多个XML模式(xsd)文件,这些文件定义了配置Spring的XML元素,如下图所示
注:可使用Spring Tool Suite(http://spring.io/tools/sts)工具,在其菜单中选择File>new>Spring Bean Configuration File,创建Spring xml文件,
并可选择可用的配置命名空间。
(2)配置一个简单的bean
<bean class="pojo.TestSpring" id="test"></bean>
注:上例中id属性如果没有指定,这个bean将会根据全限定类名命名,在上例中,将会是“pojo.TestSpring#0”。其中#0为一个计数形式,用来区分其他同类型的bean,若声明了
另外一个TestSpring,将会是“pojo.TestSpring#1”。
(3)借助构造器注入属性
constructor-arg节点
上例中constructor-arg节点的顺序即为构造函数中参数列表的参数顺序,一一对应,类型对应错误则会抛出异常
同时,该节点数目与要使用的构造函数的参数列表的参数个数必须一致。上例中注入的是对象类型,若要注入字面
良,讲ref属性改为value即可,如
此外,使用构造器注入属性除了使用constructor-arg节点外,还可以使用c命名空间,使用c命名空间可以减少配置文件的
冗长,但是constructor-arg节点能做到的有些事情,c命名空间无法做到。
c命名空间
1.要使用c命名空间,必须要在xml文件顶部声明其模式,如下图所示。
2.c命名空间格式
c:cdplay-ref="play"
c:c命名空间前缀 cdplay:构造器参数名 -ref:注入bean引用 =“play” :要注入的bean的ID
c命名空间也可根据参数顺序注入属性,即顺序索引,因为XML不支持数字作为属性的第一个字符,所以前数字前加上一个下划线
与constructor-arg参数一样,注入属性类型与数量,必须与使用的构造函数一致。
若要通过c命名空间注入字面量,则如下图所示
笔者所给出的样例类中并没有给出String,int等类型的属性,这里给出的字面量注入方式只作为样例师范,读者若要经行测试需要自己建立更优的样例类。
(4)通过属性的set方法注入属性
<property></property>节点
其中name为属性名,ref为要注入的bean的Id
与construstor-arg节点类似,若要注入字面量,将ref属性改为value
p命名空间
1.要使用p命名空间,需要在XML文件顶部配置其模式,如下图
2.p命名空间格式
p:cdplay-ref="play"
p:p命名空间前缀 cdplay:构造器参数名 -ref:注入bean引用 =“play” :要注入的bean的ID
p命名空间不能通过顺序索引注入属性
与c命名空间类似,若要注入字面量,将-ref去掉。
(5)集合类型属性的注入
如上图所示,给出了list,map,set集合类型的注入方式,此外可借助util命名空间创建集合bean
1.要使用util命名空间,需要在xml文件顶部配置其模式
2.util:list
util命名空间让集合能够像其他的bean一样被注入到其他bean中
3.util-命名空间中的元素
元素 | 描述 |
<util:constant> | 引用某个类型的Public static域,并将其暴露为bean |
<util:list> | 创建一个java.util.list类型的bean,其中包含值或引用 |
<util:map> | 创建一个java.util.map类型的bean,其中包含值或引用 |
<util:properties> | 创建一个java.util.Properties类型的bean |
<util:property-path> | 引用一个bean的属性(或内嵌属性),并将其暴露为bean |
<util:set> | 创建一个java.util.Set类型的bean,其中包含值或引用 |
spring的显示装配bean(1)------通过XML文件装配的更多相关文章
- Spring基础篇——通过Java注解和XML配置装配bean
自动化装配的确有很大的便利性,但是却并不能适用在所有的应用场景,比如需要装配的组件类不是由自己的应用程序维护,而是引用了第三方的类库,这个时候自动装配便无法实现,Spring对此也提供了相应的解决方案 ...
- Spring基础篇——通过Java注解和XML配置装配bean(转载)
作者:陈本布衣 出处:http://www.cnblogs.com/chenbenbuyi 本文版权归作者和博客园共有,欢迎转载分享,但必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留 ...
- spring学习总结——装配Bean学习一(自动装配)
一.Spring配置的可选方案 Spring容器负责创建应用程序中的bean并通过DI来协调这些对象之间的关系.但是,作为开发人员,你需要告诉Spring要创建哪些bean并且如何将其装配在一起.当描 ...
- 【Spring 核心】装配bean(二) JavaConfig装配
前面介绍完了组件扫描和自动装配,这里再来看一下装配bean的另一种方式JavaConfig. 包路径: src/main/java com.bonc-|--config--|--CDPlayerCon ...
- spring学习总结——装配Bean学习二(JavaConfig装配bean)
通过Java代码装配bean 前言:上面梳理了通过注解来隐式的完成了组件的扫描和自动装配,下面来学习下如何通过显式的配置的装配bean: 使用场景:比如说,你想要将第三方库中的组件装配到你的应用中,在 ...
- spring集成jpa【为什么有 persistant.xml 文件呢?】
原文地址: http://www.cnblogs.com/javahuang/archive/2012/12/19/2824633.html spring集成JPA的其中一种方式 JPA和hibern ...
- Spring mybatis源码篇章-Mybatis的XML文件加载
通过阅读源码对实现机制进行了解有利于陶冶情操,承接前文Spring mybatis源码篇章-Mybatis主文件加载 前话 前文主要讲解了Mybatis的主文件加载方式,本文则分析不使用主文件加载方式 ...
- cocos2d-x 显示中文字符和解析XML文件 转载
源地址:http://codingnow.cn/cocos2d-x/1038.html 在cocos2d-x中直接显示中文的时候会出现乱码,虽然在实际开发中把字符串直接写在代码里也不是好的做法,但是有 ...
- 【Spring】如何配置多个applicationContext.xml文件
在web.xml中通过contextConfigLocation配置spring 开发Java Web程序,使用ssh架构时,默认情况下,Spring的配置文件applicationContext.x ...
随机推荐
- TCP/IP三次握手和HTTP过程
1.TCP连接 手机能够使用联网功能是因为手机底层实现了TCP/IP协议,可以使手机终端通过无线网络建立TCP连接.TCP协议可以对上层网络提供接口,使上层网络数据的传输建立在"无差别&qu ...
- php 批量去空格和注释
原理:php自带函数去注释和空格 => php_strip_whitespace如题,新建文件 re_note.php,将文件放入你要批量去除注释和空格的根目录.然后运行就行了 代码如下: & ...
- 关于 Mybatis 的Invalid bound statement (not found):错误
今天遇到一个特别奇怪的问题,最后发现是自己对mybatis的学习还有待提高 返回类型可以用resultType,也可以用resultMap resultType是直接表示返回类型的,而resultMa ...
- HTTPS Web配置举例
http://www.h3c.com.cn/Products___Technology/Technology/Security_Encrypt/Other_technology/Representat ...
- delphi 各新版本特性收集
delphi 各新版本特性收集 http://www.cnblogs.com/dreamszx/p/3602589.html
- Webdriver配合Tesseract-OCR 自动识别简单的验证码
验证码: 如下,在进行自动化测试,遇到验证码的问题,一般有两种方式 1.找开发去掉验证码或者使用万能验证码 2.使用OCR自动识别 使用OCR自动化识别,一般识别率不是太高,处理一般简单验证码还是没问 ...
- 设置windows开机自启某个软件
位置:C:\Users\Administrator\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup 把要启动的软件,放在这个 ...
- 在新机器部署Qt+mysql程序
1.一般情况下需要将Qt5Core.dll,Qt5Gui.dll,Qt5Sql.dll,Qt5Widgets.dll,platforms\qwindows.dll msvcp120.dll,msvcp ...
- SQL入门语句之SELECT和WHERE
一.SQL入门语句之SELECT SELECT语句用于从数据库表中获取数据,结果表的形式返回数据.这些结果表也被称为结果集 1.从数据库表中取部分字段 select 字段A,字段B from tabl ...
- Oracle 11g RAC 卸载CRS步骤
Oracle 11g之后提供了卸载grid和database的脚本,可以卸载的比较干净,不需要手动删除crs ##########如果要卸载RAC,需要先使用dbca删除数据库,在执行下面的操作### ...