`
Luob.
  • 浏览: 1588767 次
  • 来自: 上海
社区版块
存档分类
最新评论
阅读更多
1.构造注入(就是使用 构造方法)
2,设值注入(就是使用setXX()方法)

package cn.sh.springmvc.service.user;

import cn.sh.springmvc.dao.UserDAO;


public class UserService {
	private String name;
	private int age;
	
	private UserDAO userdao;
	
	public void info(){
		System.out.println("名称为:"+name+"年龄:"+age);
	}
	//设值注入
	public void setName(String name) {
		this.name = name;
	}
	public UserService() {
		System.out.println("调用servie:service初始化");
	}

	//采用构造注入
	public UserService(int age) {
		this.age = age;
	}
	public UserService(UserDAO userdao) {
		super();
		this.userdao = userdao;
	}
	public UserDAO getUserdao() {
		return userdao;
	}
	public void setUserdao(UserDAO userdao) {
		this.userdao = userdao;
	}
}

<bean id="userService" class="cn.sh.springmvc.service.user.UserService" >
                <!--构造注入-->
		<constructor-arg name="age" value="18" type="int"/>
                <!--设值注入-->
		<property name="name" value="wawa"/>
	</bean>



Spring 容器:最基本的接口就是BeanFactory,BeanFactory负责配置,创建,管理Bean,它有一个子接口ApplicationContext,被称为"上下文",spring 还负责管理Bean和Bean之间的关系

//BeanFactory接口包含如下几个基本方法
boolean containsBean(String name); //判断spring容器中是否保航id为name的bean实例
<T> T getBean(Class<T> requiredType);//获取Spring容器中属于requiredType类型的唯一实例.
Object getBean(String name); //返回容器中ID为name的Bean实例
<T> T getBean(String name,Class requiredType) ;//返回容器中ID为name,并且类型为requiredType的Bean.
Class<?> getType(String name);//返回容器中指定Bean的实例类型.

//BeanFactory 有一个常用的实现类:XmlBeanFactory
//BeanFactory 有一个子接口:ApplicationContext 该接口的实现类有:
//1:FileSystemXmlApplicationContent
//2:ClassPathXmlApplicationContext
//3:XmlWebApplicationContext  (web中常用)
//4:AnnotaionConfigXmlApplicationContext (web中常用)

//一般的java应用程序  非web 
InputStreamResource isr=new FileSystemResource("applicationContext.xml");
XmlBeanFactory factory=new XmlBeanFactory(isr);

//或者

ClassPathResource res=new ClassPathResource("appliactionContext.xml");
XmlBeanFactory factory=new XmlBeanFactory(res);


//如果有多个配置文件采用BeanFactory的子接口
ApplicationContext act=new ClassPathXmlApplicationContext(new String[]{"bean.xml","bean1.xml"});

//或者
ApplicationContext act=new FileSystemApplicationContext(new String[]{"bean.xml","bean1.xml"});



Spring 的配置文件

<!--采用 XML Schema 来定义配置文件-->
<?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:tx="http://www.springframework.org/schema/tx"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="http://www.springframework.org/schema/beans   
    http://www.springframework.org/schema/beans/spring-beans-3.2.xsd   
    http://www.springframework.org/schema/tx   
    http://www.springframework.org/schema/tx/spring-tx-3.2.xsd  
    http://www.springframework.org/schema/context  
    http://www.springframework.org/schema/context/spring-context-3.2.xsd  
    http://www.springframework.org/schema/mvc  
    http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd" 
    default-autowire-candidates="*abc" default-lazy-init="true">

...bean
</beans>

<!--采用DTD来定义配置文件 :-->
<!--如果用DTD方式:配置文件中就不能使用spring2.X Spring3.0新增的配置标签 
比如:2.x dependency-check 属性
3.0 JSP 标签,  Hibernate标签, Tiles 2.2 标签
-->
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN 2.0//EN" "http://www.springframework.org/dtd/spring-beans-2.0.dtd">
<beans>
  
...bean
</beans>




applicatoinContext:一般不会使用 BeanFactory的实例,而是使用 ApplicationContext,因为 它包含了BeanFactory的所有功能功能,而且还提供了额外的功能:
//1:ApplicatonContext 继承了MessageSource接口,因此提供了国际化支持
//2:提供了资源访问,比如URL和文件
//3:事件机制
//4:载入多个配置文件
//5:以声明的方式启动,并创建Spring容器

//当系统初始化ApplicaitonContext容器的时候,会初始化所有的singletion Bean.因此刚开始的时候可能需要消耗较大的系统开销.


ApplicationContext支持的国际化
<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
		<property name="basenames">
			<list>
				<value>message</value>
				<!-- 多个开头的资源文件.... -->
			</list>
		</property>
</bean>

<!--message_en_US.properties-->
hello=welcom,{0}
now=now is:{0}
<!--message_zh_CN.properties-->
hello=欢迎你,{0}
now=现在时间是:{0}

<!--native2ascii message.properties message_zh_CN.properties-->

@Test
	public void test1() {
		ApplicationContext act=new ClassPathXmlApplicationContext("classpath*:applicationContent.xml");
		
		String [] args={"读者"};
		Object [] args1={new Date()};
		String hello=act.getMessage("hello", args, Locale.getDefault());
		String now=act.getMessage("now", args1, Locale.getDefault());
		System.out.println(hello);
		System.out.println(now);
	}

//syso:
//欢迎你,读者
//现在时间是:14-8-4 下午10:14



ApplicationContext的事件机制 :采用的是观察者设计模式,通过ApplicationEvent和ApplicationListener,就可以对ApplicationContext的事件处理
//定义容器事件
package cn.sh.springmvc.applicationContext;

import org.springframework.context.ApplicationEvent;

/**
 * spring 的applicationEvent 事件机制 主要采用 观察者模式
 * 
 *  1、  ContextRefreshedEvent:ApplicationContext容器初始化或者刷新时触发该事件。
    2、  ContextStartedEvent:当使用ConfigurableApplicationContext接口的start()方法启动ApplicationContext容器时触发该事件。
    3、  ContextClosedEvent:当使用ConfigurableApplicationContext接口的close()方法关闭ApplicationContext容器时触发该事件。
    4、  ContextStopedEvent: 当使用ConfigurableApplicationContext接口的stop()方法停止ApplicationContext容器时触发该事件。
    5、 RequestHandledEvent:Web相关时间,只能应用与使用DispatcherServet 的Web应用,
    	在使用spring作为前端的MVC控制器是,当spring处理用户请求后,系统会自动触发 该事件
    
 *
 */
public class EmailEvent extends ApplicationEvent {

	private String address;
	private String text;
	public EmailEvent(Object source) {
		super(source);
	}
	
	public EmailEvent(Object source, String address, String text) {
		super(source);
		this.address = address;
		this.text = text;
	}

	public String getAddress() {
		return address;
	}

	public void setAddress(String address) {
		this.address = address;
	}

	public String getText() {
		return text;
	}

	public void setText(String text) {
		this.text = text;
	}	

}

//定义一个容器监听
package cn.sh.springmvc.applicationContext;

import org.springframework.context.ApplicationEvent;
import org.springframework.context.ApplicationListener;

public class EmailNotifier implements ApplicationListener {

	@Override
	public void onApplicationEvent(ApplicationEvent evt) {
		if(evt instanceof EmailEvent){
			EmailEvent emevt=(EmailEvent)evt;
			System.out.println("需要发送邮件的接收地址:"+emevt.getAddress());
			System.out.println("需要发送邮件的邮件正文:"+emevt.getText());
		}else {
			System.out.println("容器本身的事件:"+evt);
		}
	}
}

//在applicationContext.xml中加入一个监听bean
<bean class="cn.sh.springmvc.applicationContext.EmailNotifier"/>

//测试spring容器事件
	@Test
	public void test2() {
		ApplicationContext act=new ClassPathXmlApplicationContext("classpath*:applicationContent.xml");
		
		EmailEvent ele=new EmailEvent("hello","spring_test@163.com","this is a test");
		act.publishEvent(ele);//主动触发容器事件
	}


让Bean获取spring容器:只需要实现 ApplicationContextAware 接口就可以获取spring容器了
package cn.sh.springmvc.applicationContextAware;

import org.springframework.beans.BeansException;
import org.springframework.beans.factory.BeanNameAware;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;

/**
 * 让Bean获取Spring容器
 */
public class MyContent implements ApplicationContextAware,BeanNameAware,InitializingBean,DisposableBean{

	private ApplicationContext act;
	private String beanName;
	@Override
	public void setApplicationContext(ApplicationContext act)
			throws BeansException {
		System.out.println("ApplicationContextAware 接口的 获取容器对象方法");
		this.act=act;
	}

	public ApplicationContext getContext(){
		return act;
	}

	@Override
	public void destroy() throws Exception {
		System.out.println("DisposableBean 接口的方法:即将被销毁");
	}

	@Override
	public void afterPropertiesSet() throws Exception {
		System.out.println("InitializingBean 接口的方法:Bean所有属性初始化完成后,执行的一个初始化方法");
	}

	@Override
	public void setBeanName(String name) {
		System.out.println("BeanNameAware接口,获取 Bean的name");
		beanName=name;
	}

	public String getBeanName() {
		return beanName;
	}
	
}

	<!--定义一个能够获取spring容器的bean  -->
	<bean id="myContent" name="CH,CN" class="cn.sh.springmvc.applicationContextAware.MyContent" lazy-init="true">
	</bean>
	<alias name="CH" alias="ZG"/>
	
	<alias name="chinese" alias="ZH"/>
	<!-- 别名之间还可以传承 -->
	<alias name="ZH" alias="HH"/>

//使用bean 获取 spring容器 ,一般不建议这样使用,除非有特别必要
	@Test
	public void test3() {
		ApplicationContext act=new ClassPathXmlApplicationContext("classpath*:applicationContent.xml");
		MyContent p=act.getBean("chinese",MyContent.class);
		System.out.println(p.getContext());
		System.out.println(act==p.getContext());
	}
分享到:
评论

相关推荐

    Spring的IOC原理

    为了解决这种问题,Michael Mattson提出了IOC(Inversion of Control)理论,也称为控制反转或控制倒置,它旨在通过"第三方"(即IOC容器)来降低对象间的耦合。 **二、什么是控制反转(IOC)** IOC的核心思想是将...

    spring4讲义-第二章spring与IoC

    本章主要介绍Spring框架中的控制反转(Inversion of Control,IoC)思想,以及依赖注入(Dependency Injection,DI)与依赖查找(Dependency Lookup,DL)两种实现IoC的方式。此外,还涉及了Spring程序开发的基本...

    手写IOC,DI,servlet

    1. **容器**:一个基础的容器类,负责管理对象的生命周期,包括实例化、装配和管理对象之间的依赖关系。 2. **bean定义**:每个需要管理的对象都会有一个对应的bean定义,包含对象的类型、构造函数、属性值等信息。 ...

    Spring与IoC系列三:基于XML的依赖注入测试程序di.rar

    在运行时,Spring IoC容器会读取这个配置文件,创建并初始化所有的bean,然后根据这些配置将依赖注入到相应的bean中。这样,当我们使用`exampleBean`时,无需手动创建`dependencyBean`,因为它已经在启动时被注入了...

    Spring自学笔记-Ioc(控制反转)容器

    这种方式比较简单易用,但可能导致Bean的初始化延迟到第一次使用时才完成。 ```xml ``` 3. **示例** - **XML格式定义的Setter DI示例** ```xml ``` - **构造器注入...

    【框架源码篇 01】Spring源码-手写IOC

    在本系列的第一篇中,我们将深入探讨Spring框架的核心特性——依赖注入(Dependency Injection,简称DI),并通过手动实现一个简易的IOC容器来理解其工作原理。Spring框架是Java开发中的基石,它提供了许多功能,如...

    springioc的搭建和配置

    - **ApplicationContext**: 提供了一种更为强大的 IoC 容器实现,除了 BeanFactory 的所有功能外,还提供了更多的特性,如国际化支持、事件传播机制等。其常见的实现包括 `ClassPathXmlApplicationContext` 和 `...

    Spring2.0(一)第一个Spring程序、IoC的应用

    本文将深入探讨Spring 2.0的第一个程序以及IoC(Inversion of Control,控制反转)的应用。 Spring 2.0的发布标志着该框架的重大进步,它引入了对Java 5和Java EE 5的支持,增强了AOP(面向切面编程)功能,并且...

    spring培训笔记第一天

    ### Spring培训笔记第一天:深入理解Spring框架的核心概念与实践 #### Spring框架简介 Spring框架是企业级应用开发中广泛使用的轻量级框架,它通过提供一系列的开发模式和最佳实践来简化Java应用的开发过程。...

    Spring第一天.pdf

    - **含义**:传统的对象创建方式是由程序员主动通过`new`关键字来实例化对象,而在Spring框架中,这种对象创建的责任被反转给了Spring容器,即程序员不再直接控制对象的创建过程。 - **作用**:解耦,使得程序员...

    spring第一天课堂笔记

    1. **方便解耦,简化开发**:通过Spring提供的IoC容器,开发者可以将对象之间的依赖关系交由Spring进行管理,从而避免因硬编码而造成的程序耦合问题。同时,Spring还提供了一系列底层需求的解决方案,如单例模式类和...

    Spring IoC实现

    Spring 框架中的 IoC (Inversion of Control) 概念,也被称作依赖注入(Dependency Injection, DI),是 Spring 框架的核心功能之一。它实现了对应用程序组件间的解耦,并允许容器管理对象的生命周期和依赖关系。 ...

    手写springIoC

    手写Spring IoC的第一步是建立一个容器。这个容器需要能够读取配置信息,如XML或Java注解,来了解哪些类需要被实例化以及它们之间的依赖关系。例如,我们可以创建一个`BeanFactory`接口,用于管理和存储bean,然后...

    java练习之模拟SPRING IOC,我的SUMMER

    在本Java练习中,我们将深入理解并实现Spring框架的核心组件——IoC(Inversion of Control,控制反转)容器。这个练习分为三个主要部分,旨在帮助我们掌握XML配置文件的读取,模拟Spring的IoC机制,以及对Struts...

    IOC控制反转机制的讲解

    然而,IOC通过引入一个第三方,通常是容器,如Spring框架,来管理对象的生命周期和它们之间的依赖关系,从而降低了耦合度。 在Spring框架中,IOC的核心是Bean容器,它负责创建、配置和管理对象。开发者只需定义对象...

    spring6pdf详细讲解

    Spring 的 IoC 容器是框架的核心组件,它负责管理和实例化 Bean,并提供了依赖注入和控制反转的功能。 Spring 的 IoC 容器可以自动装配 Bean,包括通过 XML 文件和注解来配置 Bean。 在 Spring 中,AOP(Aspect-...

    Spring-MyBatis-Ajax重点详解

    懒惰初始化可以使用 lazy-init 属性来设置对象“懒惰”初始化,bean 对象在容器启动时候不会初始化,在第一次使用时候才初始化。 在 Spring 框架中,工厂方法是一种封装了复杂的对象创建过程,提供一个简单方法作为...

    Spring面试专题及答案.pdf

    - 轻量级、松耦合的容器:Spring的IoC容器是一种轻量级的控制反转容器,它负责创建对象、管理对象的生命周期,并通过依赖注入减少代码的依赖性。 - 集成现有的技术:Spring集成了许多第三方库如Hibernate、JPA、...

Global site tag (gtag.js) - Google Analytics