spring 第1天 IOC,DI,国际化,容器事件

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());
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring in Action 第三版》是一本经典的技术书籍,详细介绍了Spring框架的核心概念、特性和应用实践。该书由Craig Walls撰写,并通过丰富的示例代码和清晰的讲解,向读者深入解释了Spring框架的各个方面。 该书首先介绍了Spring框架的背景和基本概念,包括控制反转(IoC)和面向切面编程(AOP),探讨了Spring容器、Bean和依赖注入(DI)的工作原理。随后,书中深入讲解了如何使用Spring框架进行Web开发,包括使用Spring MVC开发Web应用程序、Spring Web Flow进行流程管理和使用Spring Security处理安全性问题。 此外,该书还介绍了Spring的数据访问和集成测试等关键主题。读者将学习如何使用Spring对数据库进行访问,包括使用JDBC、Hibernate和JPA进行数据访问。此外,书中还介绍了如何使用Spring进行事务管理、缓存、消息队列和调度等高级功能。 最后,该书还介绍了Spring Boot的基本概念和使用方法。Spring Boot是Spring框架的快速应用开发工具,它通过自动配置和约定优于配置的方式,简化了Spring应用程序的开发和部署过程。读者将了解如何使用Spring Boot来创建独立的Spring应用程序,并通过配置文件和命令行参数等方式进行灵活的配置。 总之,《Spring in Action 第三版》通过全面而详细的内容,帮助读者全面了解和掌握Spring框架的核心知识和实战技巧。无论是对于初学者还是有经验的开发人员,都是一本值得阅读和参考的优秀书籍。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值