spring面试大全

来源:互联网 发布:ppt无法编辑数据 编辑:程序博客网 时间:2024/05/20 13:06

一、spring如何实现资源管理? 

使用 
applicationContext.getResource(“classpath:文件名”):在src根目录下,在类路径下 
applicationContext.getResource(“classpath:/chap01/文件名”): 以src根目录下的基准往下走。 
applicationContext.getResource(“file:c:/a.properties”):在系统文件目录下。 

二、请介绍一下Spring框架中Bean的作用域 
在spring2.0之前bean只有2种作用域即:singleton(单例)、non-singleton(也称 prototype),Spring2.0以后,增加了session、request、global session三种专用于Web应用程序上下文的Bean。因此,默认情况下Spring2.0现在有五种类型的Bean。 

<bean id=”role” class=”spring.chapter2.maryGame.Role” scope=”singleton”/> 

这里的scope就是用来配置spring bean的作用域,它标识bean的作用域。 

在spring2.0之前bean只有2种作用域即:singleton(单例)、non-singleton(也称 prototype),Spring2.0以后,增加了session、request、global session三种专用于Web应用程序上下文的Bean。因此,默认情况下Spring2.0现在有五种类型的Bean。当然,Spring2.0对 Bean的类型的设计进行了重构,并设计出灵活的Bean类型支持,理论上可以有无数多种类型的Bean,用户可以根据自己的需要,增加新的Bean类型,满足实际应用需求。 

1、singleton作用域 

当一个bean的作用域设置为singleton,那么Spring IOC容器中只会存在一个共享的bean实例,并且所有对bean的请求,只要id与该bean定义相匹配,则只会返回bean的同一实例。换言之,当把一个bean定义设置为singleton作用域时,Spring IOC容器只会创建该bean定义的唯一实例。这个单一实例会被存储到单例缓存(singleton cache)中,并且所有针对该bean的后续请求和引用都将返回被缓存的对象实例,这里要注意的是singleton作用域和GOF设计模式中的单例是完全不同的,单例设计模式表示一个ClassLoader中只有一个class存在,而这里的singleton则表示一个容器对应一个bean,也就是说当一个bean被标识为singleton时候,spring的IOC容器中只会存在一个该bean。 

配置实例: 

<bean id=”role” class=”spring.chapter2.maryGame.Role” scope=”singleton”/> 

或者 

<bean id=”role” class=”spring.chapter2.maryGame.Role” singleton=”true”/> 

2、prototype 

prototype作用域部署的bean,每一次请求(将其注入到另一个bean中,或者以程序的方式调用容器的getBean()方法)都会产生一个新的bean实例,相当于一个new的操作,对于prototype作用域的bean,有一点非常重要,那就是Spring不能对一个 prototype bean的整个生命周期负责,容器在初始化、配置、装饰或者是装配完一个prototype实例后,将它交给客户端,随后就对该prototype实例不闻不问了。不管何种作用域,容器都会调用所有对象的初始化生命周期回调方法,而对prototype而言,任何配置好的析构生命周期回调方法都将不会被调用。清除prototype作用域的对象并释放任何prototype bean所持有的昂贵资源,都是客户端代码的职责。(让Spring容器释放被singleton作用域bean占用资源的一种可行方式是,通过使用 bean的后置处理器,该处理器持有要被清除的bean的引用。) 

配置实例: 

<bean id=”role” class=”spring.chapter2.maryGame.Role” scope=”prototype”/> 

或者 

<beanid=”role” class=”spring.chapter2.maryGame.Role” singleton=”false”/> 

3、request 

request表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP request内有效,配置实例: 

request、session、global session使用的时候,首先要在初始化web的web.xml中做如下配置: 

如果你使用的是Servlet 2.4及以上的web容器,那么你仅需要在web应用的XML声明文件web.xml中增加下述ContextListener即可: 

<web-app> 
… 
<listener> 
<listener-class>org.springframework.web.context.request.RequestContextListener</listener-class> 
</listener> 
… 
</web-app> 

如果是Servlet2.4以前的web容器,那么你要使用一个javax.servlet.Filter的实现: 

<web-app> 
.. 
<filter> 
<filter-name>requestContextFilter</filter-name> 
<filter-class>org.springframework.web.filter.RequestContextFilter</filter-class> 
</filter> 
<filter-mapping> 
<filter-name>requestContextFilter</filter-name> 
<url-pattern>/*</url-pattern> 
</filter-mapping> 
… 
</web-app> 

接着既可以配置bean的作用域了: 

<bean id=”role” class=”spring.chapter2.maryGame.Role” scope=”request”/> 
4、session 

session作用域表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP session内有效,配置实例: 

配置实例: 

和request配置实例的前提一样,配置好web启动文件就可以如下配置: 

<bean id=”role” class=”spring.chapter2.maryGame.Role” scope=”session”/> 

5、global session 

global session作用域类似于标准的HTTP Session作用域,不过它仅仅在基于portlet的web应用中才有意义。Portlet规范定义了全局Session的概念,它被所有构成某个 portlet web应用的各种不同的portlet所共享。在global session作用域中定义的bean被限定于全局portlet Session的生命周期范围内。如果你在web中使用global session作用域来标识bean,那么,web会自动当成session类型来使用。 

配置实例: 

和request配置实例的前提一样,配置好web启动文件就可以如下配置: 

<bean id=”role” class=”spring.chapter2.maryGame.Role” scope=”global session”/> 

6、自定义bean装配作用域 

在spring 2.0中作用域是可以任意扩展的,你可以自定义作用域,甚至你也可以重新定义已有的作用域(但是你不能覆盖singleton和 prototype),spring的作用域由接口org.springframework.beans.factory.config.Scope来定义,自定义自己的作用域只要实现该接口即可,下面给个实例: 

我们建立一个线程的scope,该scope在表示一个线程中有效,代码如下: 

publicclass MyScope implements Scope …{ 
privatefinal ThreadLocal threadScope = new ThreadLocal() …{ 
protected Object initialValue() …{ 
returnnew HashMap(); 

}; 
public Object get(String name, ObjectFactory objectFactory) …{ 
Map scope = (Map) threadScope.get(); 
Object object = scope.get(name); 
if(object==null) …{ 
object = objectFactory.getObject(); 
scope.put(name, object); 

return object; 

public Object remove(String name) …{ 
Map scope = (Map) threadScope.get(); 
return scope.remove(name); 

publicvoid registerDestructionCallback(String name, Runnable callback) …{ 

public String getConversationId() …{ 
// TODO Auto-generated method stub 
returnnull; 



三、Spring如何配置一个bean来从JNDI得到DataSource 
<bean id=”dataSource” class=”org.springframework.jndi.JndiObjectFactoryBean”> 
<property name=”jndiName”> <value>Java:comp/env/jdbc/myDatasource</value> 
</property> 
</bean> 

四、Spring如何创建一个数据连接池 
<bean id=”dataSource” class=”org.apache.commons.dbcp.BasicDataSource”> 
<property name=”driver”> 
<value>db.driver</value></property><propertyname=”url”><value>{db.url}</value> 
</property> 
<property name=”username”> 
<value>db.username</value></property><propertyname=”password”><value>{db.password}</value> 
</property> 
</bean> 

五、在Spring框架中如何更加高效的使用JDBC 
使用Spring框架提供的模板类JdbcTemplete可以是JDBC更加高效 

代码如下:JdbcTemplate template = new JdbcTemplate(myDataSource); 

DAO类的例子: 

public class StudentDaoJdbc implements StudentDao { 
private JdbcTemplate jdbcTemplate; 

public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { 
this.jdbcTemplate = jdbcTemplate; 

more.. 


配置文件: 

<bean id=”jdbcTemplate” class=”org.springframework.jdbc.core.JdbcTemplate”> 
<property name=”dataSource”> 
<ref bean=”dataSource”/> 
</property> 
</bean> 
<bean id=”studentDao” class=”StudentDaoJdbc”> 
<property name=”jdbcTemplate”> 
<ref bean=”jdbcTemplate”/> 
</property> 
</bean> 
<bean id=”courseDao” class=”CourseDaoJdbc”> 
<property name=”jdbcTemplate”> 
<ref bean=”jdbcTemplate”/> 
</property> 
</bean> 

六、请你谈谈SSH整合 
SSH: 
Struts(表示层)+Spring(业务层)+hibernate(持久层) 
Struts: 
Struts是一个表示层框架,主要作用是界面展示,接收请求,分发请求。 
在MVC框架中,Struts属于VC层次,负责界面表现,负责MVC关系的分发。(View:沿用JSP,HTTP,Form,Tag,Resourse ;Controller:ActionServlet,struts-config.xml,Action) 
Hibernate: 
Hibernate是一个持久层框架,它只负责与关系数据库的操作。 
Spring: 
Spring是一个业务层框架,是一个整合的框架,能够很好地黏合表示层与持久层。 

七、一些Spring和Hibernate的面试题(附答案) 
1、 简述你对IoC(Inversion of Control)的理解,描述一下Spring中实现DI(Dependency Injection)的几种方式。 

2、 Spring的Bean有多种作用域,包括: 

singleton、prototype、request、session、global session、application、自定义 

3、 简单描述Spring framework与Struts的不同之处,整合Spring与Struts有哪些方法,哪种最好,为什么? 

4、 Hibernate中的update()和saveOrUpdate()的区别 

5、 Spring对多种ORM框架提供了很好的支持,简单描述在Spring中使用Hibernate的方法,并结合事务管理。 

答案: 

1、好莱坞原则????不要打电话找我,我会打给你的。IoC将创建的职责从应用程序代码搬到了框架中。Spring对Setter注入和构造方法注入提供支持。(详见http://martinfowler.com/articles/injection.html,以及http: //www.redsaga.com/spring_ref/2.0/html/beans.html#beans-factory- collaborators) 

2、 除application(详见Spring framework 2.0 Reference的3.4节bean的作用域) 

3、 Spring是完整的一站式框架,而Struts仅是MVC框架,且着重于MVC中的C。Spring有三种方式整合Struts:使用 Spring 的 ActionSupport 类整合 Struts;使用 Spring 的 DelegatingRequestProcessor 覆盖 Struts 的 RequestProcessor;将 Struts Action 管理委托给 Spring 框架,动作委托最好。(详见使用Spring 更好地处理Struts 动作) 

Spring 2.0新增一种方式:AutowiringRequestProcessor。(详见http://www.javaeye.com/topic/24239) 

4、 saveOrUpdate()方法可以实现update()的功能,但会多些步骤,具体如下: 

如果对象在该session中已经被持久化,不进行操作; 

对象的标识符属性(identifier property)在数据库中不存在或者是个暂时的值,调用save()方法保存它; 

如果session中的另一个对象有相同的标识符抛出一个异常; 

以上皆不符合则调用update()更新之。 

5、 在context中定义DataSource,创建SessionFactoy,设置参数;DAO类继承HibernateDaoSupport,实现具体接口,从中获得HibernateTemplate进行具体操作。 

在使用中如果遇到OpenSessionInView的问题,可以添加OpenSessionInViewFilter或OpenSessionInViewInterceptor。(详见Spring framework 2.0 Reference的12.2节Hibernate) 

声明式事务需声明事务管理器,在context中设置指定属性,用确定和。 

八、Struts,Spring,Hibernate面试题总结 
转载地址:http://blog.csdn.net/David8631/archive/2008/07/19/2676615.aspx 

Hibernate工作原理及为什么要用? 

原理: 

1. 读取并解析配置文件 
2. 读取并解析映射信息,创建SessionFactory 
3. 打开Sesssion 
4. 创建事务Transation 
5. 持久化操作 
6. 提交事务 
7. 关闭Session 
8. 关闭SesstionFactory 

为什么要用: 

* 对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。 
* Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作
* hibernate使用Java反射机制,而不是字节码增强程序来实现透明性。 
* hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。 

Hibernate是如何延迟加载? 

* Hibernate2延迟加载实现:a)实体对象  b)集合(Collection) 
* Hibernate3 提供了属性的延迟加载功能 

当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内存开销,从而提高了服务器的性能。 
Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系) 
类与类之间的关系主要体现在表与表之间的关系进行操作,它们都市对对象进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one、one-to-many、many-to-many、 

说下Hibernate的缓存机制 

* 内部缓存存在Hibernate中又叫一级缓存,属于应用事物级缓存 
* 二级缓存: 

a)应用及缓存 

b)分布式缓存 

条件:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同一数据被系统频繁使用、非              关键数据 

c)  第三方缓存的实现 
Hibernate的查询方式 
Sql、Criteria,object comptosition 
Hql: 

* 属性查询 
* 参数查询、命名参数查询 
* 关联查询 
* 分页查询 
* 统计函数 

如何优化Hibernate? 

* 使用双向一对多关联,不使用单向一对多 
* 灵活使用单向一对多关联 
* 不用一对一,用多对一取代 
* 配置对象缓存,不使用集合缓存 
* 一对多集合使用Bag,多对多集合使用Set 
* 继承类使用显式多态 
* 表字段要少,表关联不要怕多,有二级缓存撑腰 

Struts工作机制?为什么要使用Struts? 
工作机制: 
Struts的工作流程: 
在web应用启动时就会加载初始化ActionServlet,ActionServlet从struts-config.xml文件中读取配置信息,把它们存放到各种配置对象当ActionServlet接收到一个客户请求时,将执行如下流程. 
(1)检索和用户请求匹配的ActionMapping实例,如果不存在,就返回请求路径无效信息; 
(2)如果ActionForm实例不存在,就创建一个ActionForm对象,把客户提交的表单数据保存到ActionForm对象中; 
(3)根据配置信息决定是否需要表单验证.如果需要验证,就调用ActionForm的validate()方法; 
(4)如果ActionForm的validate()方法返回null或返回一个不包含ActionMessage的ActuibErrors对象, 就表示表单验证成功; 
(5)ActionServlet根据ActionMapping所包含的映射信息决定将请求转发给哪个Action,如果相应的Action实例不存在,就先创建这个实例,然后调用Action的execute()方法; 
(6)Action的execute()方法返回一个ActionForward对象,ActionServlet在把客户请求转发给ActionForward对象指向的JSP组件; 
(7)ActionForward对象指向JSP组件生成动态网页,返回给客户; 

为什么要用: 
JSP、Servlet、JavaBean技术的出现给我们构建强大的企业应用系统提供了可能。但用这些技术构建的系统非常的繁乱,所以在此之上,我们需要一个规则、一个把这些技术组织起来的规则,这就是框架,Struts便应运而生。 

基于Struts开发的应用由3类组件构成:控制器组件、模型组件、视图组件 
Struts的validate框架是如何验证的? 
在struts配置文件中配置具体的错误提示,再在FormBean中的validate()方法具体调用。 

说下Struts的设计模式 
MVC模式:  web应用程序启动时就会加载并初始化ActionServler。用户提交表单时,一个配置好的ActionForm对象被创建,并被填入表单相应的数据,ActionServler根据Struts-config.xml 文件配置好的设置决定是否需要表单验证,如果需要就调用ActionForm的Validate()验证后选择将请求发送到哪个Action,如果 Action不存在,ActionServlet会先创建这个对象,然后调用Action的execute()方法。Execute()从 ActionForm对象中获取数据,完成业务逻辑,返回一个ActionForward对象,ActionServlet再把客户请求转发给 ActionForward对象指定的jsp组件,ActionForward对象指定的jsp生成动态的网页,返回给客户。 

单例模式 

Factory(工厂模式): 

定义一个基类===》实现基类方法(子类通过不同的方法)===》定义一个工厂类(生成子类实例) 

===》开发人员调用基类方法 

Proxy(代理模式) 

spring工作机制及为什么要用? 
1.spring mvc请所有的请求都提交给DispatcherServlet,它会委托应用系统的其他模块负责负责对请求进行真正的处理工作。 
2.DispatcherServlet查询一个或多个HandlerMapping,找到处理请求的Controller. 
3.DispatcherServlet请请求提交到目标Controller 
4.Controller进行业务逻辑处理后,会返回一个ModelAndView 
5.Dispathcher查询一个或多个ViewResolver视图解析器,找到ModelAndView对象指定的视图对象 
6.视图对象负责渲染返回给客户端。 

为什么用: 
AOP 让开发人员可以创建非行为性的关注点,称为横切关注点,并将它们插入到应用程序代码中。使用 AOP 后,公共服务   (比 如日志、持久性、事务等)就可以分解成方面并应用到域对象上,同时不会增加域对象的对象模型的复杂性。 

IOC 允许创建一个可以构造对象的应用环境,然后向这些对象传递它们的协作对象。正如单词 倒置 所表明的,IOC 就像反      过来的 JNDI。没有使用一堆抽象工厂、服务定位器、单元素(singleton)和直接构造(straight construction),每一个对象都是用     其协作对象构造的。因此是由容器管理协作对象(collaborator)。 

Spring即使一个AOP框架,也是一IOC容器。 Spring 最好的地方是它有助于您替换对象。有了 Spring,只要用 JavaBean 属性和配置文件加入依赖性(协作对象)。然后可以很容易地在需要时替换具有类似接口的协作对象。 

九、什么是Spring, 它有什么特点 
Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。 

◆轻量——从大小与开销两方面而言Spring都是轻量的。完整的Spring框架可以在一个大小只有1MB多的JAR文件里发布。并 且Spring所需的处理开销也是微不足道的。此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于Spring的特定类。 

◆控制反转——Spring通过一种称作控制反转(IoC)的技术促进了松耦 合。当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象。你可以认为IoC与JNDI相反——不 是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它。 
◆面向切面——Spring提供了面向切面编程的丰富支持,允许通过分离应用的 业务逻辑与系统级服务(例如审计(auditing)和事务()管理)进行内聚性的开发。应用对象只实现它们应该做的——完成业务逻辑——仅此而已。它们 并不负责(甚至是意识)其它的系统级关注点,例如日志或事务支持。 
◆容器——Spring包含并管理应用对象的配置和生命周期,在这个意义上它是 一种容器,你可以配置你的每个bean如何被创建——基于一个可配置原型(prototype),你的bean可以创建一个单独的实例或者每次需要时都生 成一个新的实例——以及它们是如何相互关联的。然而,Spring不应该被混同于传统的重量级的EJB容器,它们经常是庞大与笨重的,难以使用。 
◆框架——Spring可以将简单的组件配置、组合成为复杂的应用。在Spring中,应用对象被声明式地组合,典型地是在一个XML文件里。Spring也提供了很多基础功能(事务管理、持久化框架集成等等),将应用逻辑的开发留给了你。 

十、使用Spring有什么好处 
◆Spring能有效地组织你的中间层对象,无论你是否选择使用了EJB。如果你仅仅使用了Struts或其他的包含了J2EE特有APIs的framework,你会发现Spring关注了遗留下的问题,。 

◆Spring能消除在许多工程上对Singleton的过多使用。根据我的经验,这是一个主要的问题,它减少了系统的可测试性和面向对象特性。 
◆Spring能消除使用各种各样格式的属性定制文件的需要,在整个应用和工程中,可通过一种 一致的方法来进行配置。曾经感到迷惑,一个特定类要查找迷幻般的属性关键字或系统属性,为此不得不读Javadoc乃至源编码吗?有了Spring,你可 很简单地看到类的JavaBean属性。倒置控制的使用(在下面讨论)帮助完成这种简化。 
◆Spring能通过接口而不是类促进好的编程习惯,减少编程代价到几乎为零。 
◆Spring被设计为让使用它创建的应用尽可能少的依赖于他的APIs。在Spring应用中的大多数业务对象没有依赖于Spring。 
◆使用Spring构建的应用程序易于单元测试。 
◆Spring能使EJB的使用成为一个实现选择,而不是应用架构的必然选择。你能选择用POJOs或local EJBs来实现业务接口,却不会影响调用代码。 
◆Spring帮助你解决许多问题而无需使用EJB。Spring能提供一种EJB的替换物,它们适于许多web应用。例如,Spring能使用AOP提供声明性事务而不通过使用EJB容器,如果你仅仅需要与单个的数据库打交道,甚至不需要JTA实现。 
■Spring为数据存取提供了一致的框架,不论是使用JDBC或O/R mapping产品(如Hibernate)。 
Spring确实使你能通过最简单可行的解决办法解决你的问题。这些特性是有很大价值的。 
总结起来,Spring有如下优点: 
◆低侵入式设计,代码污染极低 
◆ 独立于各种应用服务器,可以真正实现Write Once,Run Anywhere的承诺 
◆Spring的DI机制降低了业务对象替换的复杂性 
◆Spring并不完全依赖于Spring,开发者可自由选用Spring框架的部分或全部 

十一、Spring框架有哪几部分组成? 
Spring框架有七个模块组成组成,这7个模块(或组件)均可以单独存在,也可以与其它一个或多个模块联合使用,主要功能表现如下: 

? Spring 核心容器(Core):提供Spring框架的基本功能。核心容器的主要组件是BeanFactory,她是工厂模式的实现。BeanFactory使用控制反转(Ioc)模式将应用程序的配置和依赖性规范与实际的应用代码程序分开。 

? Spring AOP:通过配置管理特性,Spring AOP模块直接面向方面的编程功能集成到了Spring框架中,所以可以很容易的使Spring框架管理的任何对象支持 AOP。Spring AOP模块为基于Spring的应用程序中的对象提供了事务管理服务。通过使用Spring AOP,不用依赖于EJB组件,就可以将声明性事务管理集成到应用程序中。 

? Spring ORM:Spring框架集成了若干ORM框架,从而提供了ORM的对象关系工具,其中包括 JDO、Hibernate、iBatis和TopLink。所有这些都遵从Spring的通用事务和DAO异常层结构。 

? Spring DAO:JDBC DAO抽象层提供了有意义的异常层次的结构,可用该结构来管理异常处理和不同数据供应商抛出的异常错误信息。异常层次结构简化了错误处理,并且大大的降低 了需要编写的异常代码数量(例如,打开和关系连接)。Spring DAO的面向JDBC的异常遵从通用的DAO异常层结构。 

? Spring WEB:Web上下文模块建立在上下文模块(Context)的基础之上,为基于Web服务的应用程序提供了上下文的服务。所以Spring框架支持 Jakarta Struts的集成。Web模块还简化了处理多部分请求及将请求参数绑定到域对象的工作。 

? Spring上下文(Context):Spring上下文是一个配置文件,向Spring框架提供上下文信息。Spring上下文包括企业服务,例如 JNDI、EJB、电子邮件、国际化校验和调度功能。 

? Spring MVC:Spring的MVC框架是一个全功能的构建Web应用程序的MVC实现。通过策略接口,MVC框架变成为高度可配置的,MVC容纳的大量视图技术,包括JSP、Velocity、Tiles、iText和Pol 

十二、Spring如何获取Bean 
通过xml配置文件 

bean配置在xml里面,spring提供多种方式读取配置文件得到ApplicationContext. 

第一种方式:FileSystemXmlApplicationContext 

通过程序在初始化的时候,导入Bean配置文件,然后得到Bean实例: 
ApplicationContext ac = new FileSystemXmlApplicationContext(”applicationContext.xml”) 
ac.getBean(”beanName”); 

第二种方式:WebApplicationContextUtil 

在B/S系统中,通常在web.xml初始化bean的配置文件,然后由WebAppliCationContextUtil得到ApplicationContext.例如: 
ApplicationContext ctx = WebApplicationContextUtils.getRequiredWebApplicationContext(ServletContext sc); 
ApplicationContext ctx =   WebApplicationContextUtils.getWebApplicationContext(ServletContext sc); 

其中 servletContext sc 可以具体 换成 servlet.getServletContext()或者 this.getServletContext() 或者 request.getSession().getServletContext(); 

另外,由于spring是注入的对象放在ServletContext中的,所以可以直接在ServletContext取出WebApplicationContext 对象: 

WebApplicationContext webApplicationContext = (WebApplicationContext) servletContext.getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE); 

十三、请介绍一下Spring框架中Bean的生命周期 
一、Bean的定义 
Spring通常通过配置文件定义Bean。如: 

<?xml version=”1.0″ encoding=”UTF-8″?> 
<beans xmlns=”http://www.springframework.org/schema/beans” 
xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance” 
xsi:schemaLocation=”http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd”> 
<bean id=”HelloWorld” class=”com.pqf.beans.HelloWorld”> 
<property name=”msg”> 
<value>HelloWorld</value> 
</property> 
</bean> 
</beans> 

这个配置文件就定义了一个标识为 HelloWorld 的Bean。在一个配置文档中可以定义多个Bean。 

二、Bean的初始化 
有两种方式初始化Bean。 
1、在配置文档中通过指定init-method 属性来完成 
在Bean的类中实现一个初始化Bean属性的方法,如init(),如: 
public class HelloWorld{ 
public String msg=null; 
public Date date=null; 

public void init() { 
msg=”HelloWorld”; 
date=new Date(); 

…… 

然后,在配置文件中设置init-mothod属性: 
<bean id=”HelloWorld” class=”com.pqf.beans.HelloWorld” init-mothod=”init” > 
</bean> 

2、实现 org.springframwork.beans.factory.InitializingBean接口 
Bean实现InitializingBean接口,并且增加 afterPropertiesSet() 方法: 

public class HelloWorld implement InitializingBean { 
public String msg=null; 
public Date date=null; 

public void afterPropertiesSet() { 
msg=”向全世界问好!”; 
date=new Date(); 

…… 


那么,当这个Bean的所有属性被Spring的BeanFactory设置完后,会自动调用afterPropertiesSet()方法对Bean进行初始化,于是,配置文件就不用指定 init-method属性了。 

三、Bean的调用 
有三种方式可以得到Bean并进行调用: 
1、使用BeanWrapper 
HelloWorld hw=new HelloWorld(); 
BeanWrapper bw=new BeanWrapperImpl(hw); 
bw.setPropertyvalue(”msg”,”HelloWorld”); 
system.out.println(bw.getPropertyCalue(”msg”)); 

2、使用BeanFactory 
InputStream is=new FileInputStream(”config.xml”); 
XmlBeanFactory factory=new XmlBeanFactory(is); 
HelloWorld hw=(HelloWorld) factory.getBean(”HelloWorld”); 
system.out.println(hw.getMsg()); 

3、使用ApplicationConttext 
ApplicationContext actx=new FleSystemXmlApplicationContext(”config.xml”); 
HelloWorld hw=(HelloWorld) actx.getBean(”HelloWorld”); 
System.out.println(hw.getMsg()); 

四、Bean的销毁 
1、使用配置文件中的 destory-method 属性 
与初始化属性 init-methods类似,在Bean的类中实现一个撤销Bean的方法,然后在配置文件中通过 destory-method指定,那么当bean销毁时,Spring将自动调用指定的销毁方法。 

2、实现 org.springframwork.bean.factory.DisposebleBean接口 
如果实现了DisposebleBean接口,那么Spring将自动调用bean中的Destory方法进行销毁,所以,Bean中必须提供Destory方法。 

十四、简述Hibernate的工作原理? 
1.读取并解析配置文件 
2.读取并解析映射信息,创建SessionFactory 
3.打开Sesssion 
4.创建事务Transation 
5.持久化操作 
6.提交事务 
7.关闭Session 
8.关闭SesstionFactory 

十五.简述Spring的工作原理? 
1.spring mvc请所有的请求都提交给DispatcherServlet,它会委托应用系统的其他模块负责负责对请求进行真正的处理工作。 
2.DispatcherServlet查询一个或多个HandlerMapping,找到处理请求的Controller. 
3.DispatcherServlet请请求提交到目标Controller 
4.Controller进行业务逻辑处理后,会返回一个ModelAndView 
5.Dispathcher查询一个或多个ViewResolver视图解析器,找到ModelAndView对象指定的视图对象 
6.视图对象负责渲染返回给客户端。

原创粉丝点击