Java的反射机制可以说是在Spring中发挥的淋漓尽致,下面要看的代码就是通过反射机制来实现向一个类注入其实际依赖的类型,这个过程的实现会交由Spring容器来帮我们完成。

JavaBean中针对属性一般都有一组设置/获取方法(setXXX/getXXX),这两个方法可以由IDE给我们自动产生,当然你也可以手动进行编写,这是你的自由,下面的例子就是Spring中利用setter方法来实现依赖注入。

源代码如下:

package com.pp;
//一个普通的JavaBean
public class Person {
//人的名字
private String S_name;
private String S_addr;
private int age;
//getter方法
public int getS_Age() {
return age;
}
//setter方法
public void setS_Age(int age) {
this.age = age;
}
//setter方法
public String getaddr() {
return S_addr;
}
//getter方法
public void setaddr(String addr) {
S_addr = addr;
}
//构造函数
public Person(){}
//getter方法
public String getName() {
return S_name;
}
//setter方法
public void setName(String name) {
S_name = name;
};
}

有了这个普通的JavaBean,我们要利用Spring容器来实现属性的注入,这里就需要Spring的配置文件,Spring的配置文件如下:

<?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-3.0.xsd">
<bean id="sentence" class="com.pp.Sentence"/>
<bean id="person" class="com.pp.Person">
<!-- 从这里可以看出的是属性名是setter方法里去掉set的部分,即setXXX中的XXX而与具体的属性无关 -->
<property name="name" value="pptest"></property>
<!-- 这里你完全可以把setaddr里的参数改成setaddr(String name),并不会报错,因为判断的依据是setXXX即XXX -->
<!-- 但如果你改成setS_addr这里就要错了,不信你可以试,如果改成setS_addr,则下面的name需要改成S_addr -->
<property name="addr" value="Beijing"></property>
<!-- 这里就是上面的一个例子,类的属性名为age,但这里的name却为S_Age -->
<!-- 同时这里也要说明的一个问题是类里面为int,但这里却是字符串类型,这个你不用担心,Spring在进行注入时会自动根据参数的类型进行类型 的转化 -->
<property name="S_Age" value="22"></property>
</bean>
</beans>

配置文件中我已经注释的很清楚了,就不做说明了

下面是一个测试文件

import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.ClassPathResource;
public class MainTest {
public static void main(String[] args) {
BeanFactory factory=new XmlBeanFactory(new ClassPathResource("person.xml"));
Person person=(Person)factory.getBean("person");
System.out.println(person.getName());
System.out.println(person.getaddr());
System.out.println(person.getS_Age());
}
}

如果一切正常的话,应该会打印出如下的结果:

pptest
Beijing

22

上面向类里面注入的均是内置类型,其实不仅可以注入内置类型,还可以向里面注入外部类对象,下面就是一个例子,只显示增加的部份,增加的部分,是假设每一个人均有说一句话,这句话的实际内容是由Sentence这个类决定的

源代码:

//这是一个普通的类,当然这样设计不好,在此仅为说明一下
public class Sentence{
//类里面的方法,表示每一个人均说的是同样的一句话
public void say() {
System.out.println("Hello");
}
}

下面是在类Person使用刚才的Sentence这个类,以下只列出新增代码

	//代表要说的话
private Sentence sce;
//setter方法
public Sentence getSce() {
return sce;
}
//getter方法
public void setSce(Sentence sce) {
this.sce = sce;
}

以下是配置文件,同样也只列出新增的一部份

	<bean id="sentence" class="com.pp.Sentence"/>
<bean id="person" class="com.pp.Person">
<!-- 从这里可以看出的是属性名是setter方法里去掉set的部分,即setXXX中的XXX而与具体的属性无关 -->
<property name="name" value="pptest"></property>
<!-- 这里你完全可以把setaddr里的参数改成setaddr(String name),并不会报错,因为判断的依据是setXXX即XXX -->
<!-- 但如果你改成setS_addr这里就要错了,不信你可以试,如果改成setS_addr,则下面的name需要改成S_addr -->
<property name="addr" value="Beijing"></property>
<!-- 这里就是上面的一个例子,类的属性名为age,但这里的name却为S_Age -->
<!-- 同时这里也要说明的一个问题是类里面为int,但这里却是字符串类型,这个你不用担心,Spring在进行注入时会自动根据参数的类型进行类型 的转化 -->
<property name="S_Age" value="22"></property>
<!-- 引入在外部定义的bean,这里就是上面的一个bean的id -->
<property name="Sce" ref="sentence"></property>
</bean>

测试文件里里面只需填加一行即可:

person.getSce().say();

最终的结果如下:

pptest
Beijing

22

Hello

上面的配置文件中,是用外部Bean注入的,我们也可以使用内部Bean注入,所谓内部Bean注入,是直接把Bean的定义写在property属性里,如下是更改后的配置文件

	<!--
<bean id="sentence" class="com.pp.Sentence"/>
-->
<bean id="person" class="com.pp.Person">
<!-- 从这里可以看出的是属性名是setter方法里去掉set的部分,即setXXX中的XXX而与具体的属性无关 -->
<property name="name" value="pptest"></property>
<!-- 这里你完全可以把setaddr里的参数改成setaddr(String name),并不会报错,因为判断的依据是setXXX即XXX -->
<!-- 但如果你改成setS_addr这里就要错了,不信你可以试,如果改成setS_addr,则下面的name需要改成S_addr -->
<property name="addr" value="Beijing"></property>
<!-- 这里就是上面的一个例子,类的属性名为age,但这里的name却为S_Age -->
<!-- 同时这里也要说明的一个问题是类里面为int,但这里却是字符串类型,这个你不用担心,Spring在进行注入时会自动根据参数的类型进行类型 的转化 -->
<property name="S_Age" value="22"></property>
<!-- 引入在外部定义的bean,这里就是上面的一个bean的id
<property name="Sce" ref="sentence"></property>-->
<property name="Sce">
<!-- 内部的Bean不能被外部的Bean引用,因此在里面加入id属性,是没有什么用的,内部Bean只能供本类使用,这里就是Person类的一个对象 -->
<bean class="com.pp.Sentence"></bean>
</property>
</bean>

测试文件可以不加任何改动,但最终的运行结果是一样的

[置顶] Spring中DI设置器注入的更多相关文章

  1. [置顶] Spring中自定义属性编辑器

    Spring中的属性编辑器能够自动的将String类型转化成需要的类型,例如一个类里面的一个整型属性,在配置文件中我们是通过String类型的数字进行配置的,这个过程中就需要一个转化操作,当然这个转化 ...

  2. [置顶] Spring的DI依赖实现分析

    DI(依赖注入)是Spring最底层的核心容器要实现的功能之一,利用DI可以实现程序功能的控制反转(控制反转即程序之间之间的依赖关系不再由程序员来负责,而是由Spring容器来负责) 一个简单的例子( ...

  3. Quartz在Spring中动态设置cronExpression (spring设置动态定时任务)

    什么是动态定时任务:是由客户制定生成的,服务端只知道该去执行什么任务,但任务的定时是不确定的(是由客户制定).      这样总不能修改配置文件每定制个定时任务就增加一个trigger吧,即便允许客户 ...

  4. (转)spring中的拦截器(HandlerInterceptor+MethodInterceptor)

    1.  过滤器跟拦截器的区别 在说拦截器之前,不得不说一下过滤器,有时候往往被这两个词搞的头大. 其实我们最先接触的就是过滤器,还记得web.xml中配置的<filter>吗~ 你应该知道 ...

  5. Quartz在Spring中动态设置cronExpression

    什么是动态定时任务:是由客户制定生成的,服务端只知道该去执行什么任务,但任务的定时是不确定的(是由客户制定). 这样总不能修改配置文件每定制个定时任务就增加一个trigger吧,即便允许客户修改配置文 ...

  6. spring中bean配置和注入场景分析

    bean与spring容器的关系 Bean配置信息定义了Bean的实现及依赖关系,Spring容器根据各种形式的Bean配置信息在容器内部建立Bean定义注册表,然后根据注册表加载.实例化Bean,并 ...

  7. Spring中如何向 Bean注入系统属性或环境变量

    [转自] http://unmi.cc/spring-injection-system-properties-env/ 在 Spring 中为 javabean 注入属性文件中的属性值一般人都知道的, ...

  8. [置顶] spring集成mina 实现消息推送以及转发

    spring集成mina: 在学习mina这块时,在网上找了很多资料,只有一些demo,只能实现客户端向服务端发送消息.建立长连接之类.但是实际上在项目中,并不简单实现这些,还有业务逻辑之类的处理以及 ...

  9. SSM-Spring-04:Spring的DI的构造注入,P命名注入,和集合注入

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- DI和IOC相比,DI更偏向于实现 DI的set方式注入在前面入门案例里有写,所以此处不多啰嗦,直接开搞,先说 ...

随机推荐

  1. WebLogic部署集群和代理服务器

    应公司要求,最近在学习weblogic集群这块的知识,下面我把我这几天学到的,以及过程中遇到的问题及如何解决的,分享给大家.首先,weblogic是Orcale公司的一款产品,至于其作用,我想就不用我 ...

  2. 解决Nginx的connect() to 127.0.0.1:8080 failed (13: Permission denied) while connect

    在进行Nginx+Tomcat 负载均衡的时候遇到了这个权限问题,在error.log日志中.我们能够看到例如以下: connect() to 127.0.0.1:8080 failed (13: P ...

  3. Scrapy系列教程(2)------Item(结构化数据存储结构)

    Items 爬取的主要目标就是从非结构性的数据源提取结构性数据,比如网页. Scrapy提供 Item 类来满足这种需求. Item 对象是种简单的容器.保存了爬取到得数据. 其提供了 类似于词典(d ...

  4. Axis2 -POJO

    POJO,Plain Old Java Object,简单Java物. 通告Webservice 1.书写Hello.java public class Hello { public String s ...

  5. WebAPI 15 CORS

    WebAPI 15 CORS 同源策略 首先基于安全的原因,浏览器是存在同源策略这个机制的,同源策略阻止从一个源加载的文档或脚本获取或设置另一个源加载的文档的属性. 对于同源必须要求URL在如下几个方 ...

  6. Swift1_关闭

    // main.swift // swift1_关闭 // Created by beyond on 15/6/12. // Copyright (c) 2015年 beyond.com All ri ...

  7. 玩转Web之JavaScript(三)-----javaScript语法总结(三) 窗口/滚动条/文本的相关语法

    JS语法集锦(三) 窗口/滚动条/文本 alert("文本")    警告框:警告框经常用于确保用户可以得到某些信息,当警告框出现后,用户需要点击确定按钮才能继续进行操作. con ...

  8. ORACLE 实验一

    实验一:数据定义 实验学时:4学时 实验类型:综合型 实验要求:必修 一.实验目的 1.熟悉Oracle的client配置: 2.掌握SQL Plus的使用: 3.掌握SQL模式定义语句,定义相关的表 ...

  9. HDU 4333 Revolving Digits 扩张KMP

    标题来源:HDU 4333 Revolving Digits 意甲冠军:求一个数字环路移动少于不同数量 等同 于的数字 思路:扩展KMP求出S[i..j]等于S[0..j-i]的最长前缀 推断 nex ...

  10. CreateEvent、SetEvent、ResetEvent和WaitForSingleObject

    事件对象就像一个开关:它仅仅有两种状态---开和关.当一个事件处于"开"状态.我们称其为"有信号".否则称为"无信号". 能够在一个线程的运 ...