Struts+Hibernate+Spring面试题合集及答案

Struts+Hibernate+Spring面试题合集及答案

Struts+Hibernate+Spring面试题合集 1html

1. Hibernate部分 2前端

1.1. Hibernate工做原理 2java

1.2. 什么是Hibernate的并发机制?怎么处理并发问题? 2web

1.3. Hibernate自带的分页机制是什么?若是不使用Hibernate自带的分页,则采用什么方式分页? 3面试

1.4. hibernate的对象的三种持久化状态,并给出解释? 3spring

1.5. hibernate的三种状态之间如何转换 3sql

1.6. hibernate中一对多配置文件返回的是什么? 4数据库

1.7. update()和saveOrUpdate()的区别? 4express

1.8. hibernate拒绝链接、服务器崩溃的缘由?最少写5 4apache

1.9. hibernate如何管理缓存 4

1.10. 使用Hibernate的优势: 6

1.11. Hibernate是如何延迟加载? 6

1.12. Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系) 6

1.13. Hibernate的查询方式 7

1.14. 如何优化Hibernate 7

2 Struts部分 7

4.1. Struts1.x工做机制? 7

4.2. 为何要用Struts1.x 8

4.3. Struts1.xvalidate框架是如何验证的? 8

4.4. 说下Struts的设计模式 8

4.5. 谈谈你mvc的理解 8

4.6. struts1.2struts2.0的区别?如何控制两种框架中的单例模式? 9

4.7. struts如何实现国际化 9

4.8. struts2.0的经常使用标签有哪些 10

4.9. struts中怎么配置form-beanactiontiles 10

4.10. logic标签有哪几个? 12

4.11. action是单实例仍是多实例,为何? 13

4.12. dispatchAction是用什么技术实现的? 13

4.13. struts2.0mvc模式?与struts1.0的区别? 13

4.14. struts的处理流程。 13

4.15. Struts/webwork 的工做机制,它有哪些标签 18

3 Spring部分 18

4.1. spring工做机制 18

4.2. 使用Spring的好处 19

4.3. spring是什么?根据你的理解详细谈谈你的看法。 19

4.4. 项目中如何体现Spring中的切面编程,具体说明。 20

4.5. spring在项目中如何充当粘合剂 20

4.6. spring的事务如何配置 20

4.7. transaction有那几种实现 21

4 综合部分 21

4.1. Hibernatespring中常出现的几个异常 21

4.2. Hibernatejdbc的联系 22

4.3. Hibernatespring的联系 22

4.4. 项目中为何使用SSH 23

 

1. Hibernate部分

1.1. Hibernate工做原理 

1.读取并解析配置文件

2.读取并解析映射信息,建立SessionFactory

3.打开Sesssion

4.建立事务Transation

5.持久化操做

6.提交事务

7.关闭Session

8.关闭SesstionFactory

1.2. 什么是Hibernate的并发机制?怎么处理并发问题?

  • Hibernate并发机制:

   a、Hibernate的Session对象是非线程安全的,对于单个请求,单个会话,单个的工做单元(即单个事务,单个线程),它一般只使用一次,

      而后就丢弃。

      若是一个Session 实例容许共享的话,那些支持并发运行的,例如Http request,session beans将会致使出现资源争用。

      若是在Http Session中有hibernate的Session的话,就可能会出现同步访问Http Session。只要用户足够快的点击浏览器的“刷新”,

      就会致使两个并发运行的线程使用同一个Session。

   b、多个事务并发访问同一块资源,可能会引起第一类丢失更新,脏读,幻读,不可重复读,第二类丢失更新一系列的问题。

 

  • 解决方案:设置事务隔离级别。

     Serializable:串行化。隔离级别最高

             Repeatable Read:可重复读

             Read Committed:已提交数据读

             Read Uncommitted:未提交数据读。隔离级别最差

             设置锁:乐观锁和悲观锁。

             乐观锁:使用版本号或时间戳来检测更新丢失,在<class>的映射中设置 optimistic-lock="all"能够在没有版本或者时间戳属性映射的状况下实现 版本检查,此时Hibernate将比较一行记录的每一个字段的状态 行级悲观锁:Hibernate老是使用数据库的锁定机制,从不在内存中锁定对象!只要为JDBC链接指定一下隔 离级别,而后让数据库去搞定一切就够了。类LockMode 定义了Hibernate所需的不一样的锁定级别:LockMode.UPGRADE,LockMode.UPGRADE_NOWAIT,LockMode.READ;

 

 

1.3. Hibernate自带的分页机制是什么?若是不使用Hibernate自带的分页,则采用什么方式分页?

    一、hibernate自带的分页机制:得到Session对象后,从Session中得到Query对象。用Query.setFirstResult():设置要显示的第一行数据,

       Query.setMaxResults():设置要显示的最后一行数据。

    二、不使用hibernate自带的分页,可采用sql语句分页,

       如:5:为每页显示的记录,2为当前页: select * top 5 from table where tabId not in (select tabId top (2-1)*5 from table);

   

1.4. hibernate的对象的三种持久化状态,并给出解释?

    不清楚hibernate的对象的三种持久化状态,只知道hibernate对象的三种状态,下面有介绍。

 

1.5. hibernate的三种状态之间如何转换

    当对象由瞬时状态(Transient)一save()时,就变成了持久化状态。

    当咱们在Session里存储对象的时候,实际是在Session的Map里存了一份,

    也就是它的缓存里放了一份,而后,又到数据库里存了一份,在缓存里这一份叫持久对象(Persistent)。

    Session 一 Close()了,它的缓存也都关闭了,整个Session也就失效了,

    这个时候,这个对象变成了游离状态(Detached),但数据库中仍是存在的。

    当游离状态(Detached)update()时,又变为了持久状态(Persistent)。

    当持久状态(Persistent)delete()时,又变为了瞬时状态(Transient),

    此时,数据库中没有与之对应的记录。

 

1.6. hibernate中一对多配置文件返回的是什么?

    hibernate中一对多配置文件会相应的映射为两张表,而且它们之间的关系是一对多的。

例如:一个student和classes表的关系 。一个学生只能是一个班的,一个班能够有多个学生。

 

1.7. update()和saveOrUpdate()的区别?

    update()和saveOrUpdate()是用来对跨Session的PO进行状态管理的。

    update()方法操做的对象必须是持久化了的对象。也就是说,若是此对象在数据库中不存在的话,就不能使用update()方法。

    saveOrUpdate()方法操做的对象既可使持久化了的,也可使没有持久化的对象。若是是持久化了的对象调用saveOrUpdate()则会

    更新数据库中的对象;若是是未持久化的对象使用此方法,则save到数据库中。

 

 

1.8. hibernate拒绝链接、服务器崩溃的缘由?最少写5个

1. db没有打开  

2. 网络链接可能出了问题

3. 链接配置错了

4. 驱动的driver,url是否都写对了

5. LIB下加入相应驱动,数据链接代码是否有误

6. 数据库配置可能有问题

7. 当前联接太多了,服务器都有访问人数限制的

8. 服务器的相应端口没有开,即它不提供相应的服务

9  hibernate有哪些缓存,分别怎么使用?

10  你对hibernate的了解到了一个什么样的程度?

11 写出一个sql语句体现hibernate中一对多的关系

 

1.9. hibernate如何管理缓存

  Hibernate 中提供了两级Cache,第一级别的缓存是Session级别的缓存,它是属于事务范围的缓存。这一级别的缓存由hibernate管理的,通常状况下无需进行干预;第二级别的缓存是SessionFactory级别的缓存,它是属于进程范围或群集范围的缓存。这一级别的缓存能够进行配置和更改,而且能够动态加载和卸载。 Hibernate还为查询结果提供了一个查询缓存,它依赖于第二级缓存。

  1. 一级缓存和二级缓存的比较:第一级缓存 第二级缓存 存放数据的形式 相互关联的持久化对象 对象的散装数据 缓存的范围 事务范围,每一个事务都有单独的第一级缓存进程范围或集群范围,缓存被同一个进程或集群范围内的全部事务共享 并发访问策略因为每一个事务都拥有单独的第一级缓存,不会出现并发问题,无需提供并发访问策略因为多个事务会同时访问第二级缓存中相同数据,所以必须提供适当的并发访问策略,来保证特定的事务隔离级别 数据过时策略没有提供数据过时策略。处于一级缓存中的对象永远不会过时,除非应用程序显式清空缓存或者清除特定的对象必须提供数据过时策略,如基于内存的缓存中的对象的最大数目,容许对象处于缓存中的最长时间,以及容许对象处于缓存中的最长空闲时间 物理存储介质内存内存和硬盘。对象的散装数据首先存放在基于内在的缓存中,当内存中对象的数目达到数据过时策略中指定上限时,就会把其他的对象写入基于硬盘的缓存中。缓存的软件实现 在Hibernate的Session的实现中包含了缓存的实现由第三方提供,Hibernate仅提供了缓存适配器(CacheProvider)。用于把特定的缓存插件集成到Hibernate中。启用缓存的方式只要应用程序经过Session接口来执行保存、更新、删除、加载和查询数据库数据的操做,Hibernate就会启用第一级缓存,把数据库中的数据以对象的形式拷贝到缓存中,对于批量更新和批量删除操做,若是不但愿启用第一级缓存,能够绕过Hibernate API,直接经过JDBC API来执行指操做。用户能够在单个类或类的单个集合的粒度上配置第二级缓存。若是类的实例被常常读但不多被修改,就能够考虑使用第二级缓存。只有为某个类或集合配置了第二级缓存,Hibernate在运行时才会把它的实例加入到第二级缓存中。 用户管理缓存的方式第一级缓存的物理介质为内存,因为内存容量有限,必须经过恰当的检索策略和检索方式来限制加载对象的数目。Session的evit()方法能够显式清空缓存中特定对象,但这种方法不值得推荐。 第二级缓存的物理介质能够是内存和硬盘,所以第二级缓存能够存放大量的数据,数据过时策略的maxElementsInMemory属性值能够控制内存中的对象数目。管理第二级缓存主要包括两个方面:选择须要使用第二级缓存的持久类,设置合适的并发访问策略:选择缓存适配器,设置合适的数据过时策略。

  2. 一级缓存的管理: 当应用程序调用Session的save()、update()、savaeOrUpdate()、get()或load(),以及调用查询接口的 list()、iterate()或filter()方法时,若是在Session缓存中还不存在相应的对象,Hibernate就会把该对象加入到第一级缓存中。当清理缓存时,Hibernate会根据缓存中对象的状态变化来同步更新数据库。 Session为应用程序提供了两个管理缓存的方法: evict(Object obj):从缓存中清除参数指定的持久化对象。 clear():清空缓存中全部持久化对象。

  3. 二级缓存的管理:

  3.1. Hibernate的二级缓存策略的通常过程以下:

  1) 条件查询的时候,老是发出一条select * from table_name where …. (选择全部字段)这样的SQL语句查询数据库,一次得到全部的数据对象。

  2) 把得到的全部数据对象根据ID放入到第二级缓存中。

  3) 当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查;查不到,若是配置了二级缓存,那么从二级缓存中查;查不到,再查询数据库,把结果按照ID放入到缓存。

  4) 删除、更新、增长数据的时候,同时更新缓存。

  Hibernate的二级缓存策略,是针对于ID查询的缓存策略,对于条件查询则毫无做用。为此,Hibernate提供了针对条件查询的Query Cache。

  3.2. 什么样的数据适合存放到第二级缓存中? 1 不多被修改的数据 2 不是很重要的数据,容许出现偶尔并发的数据 3 不会被并发访问的数据 4 参考数据,指的是供应用参考的常量数据,它的实例数目有限,它的实例会被许多其余类的实例引用,实例极少或者历来不会被修改。

  3.3. 不适合存放到第二级缓存的数据? 1 常常被修改的数据 2 财务数据,绝对不容许出现并发 3 与其余应用共享的数据。

  3.4. 经常使用的缓存插件 Hibernater 的二级缓存是一个插件,下面是几种经常使用的缓存插件:

  EhCache:可做为进程范围的缓存,存放数据的物理介质能够是内存或硬盘,对Hibernate的查询缓存提供了支持。

  OSCache:可做为进程范围的缓存,存放数据的物理介质能够是内存或硬盘,提供了丰富的缓存数据过时策略,对Hibernate的查询缓存提供了支持。

  SwarmCache:可做为群集范围内的缓存,但不支持Hibernate的查询缓存。

  JBossCache:可做为群集范围内的缓存,支持事务型并发访问策略,对Hibernate的查询缓存提供了支持。

  3.5. 配置二级缓存的主要步骤:

  1) 选择须要使用二级缓存的持久化类,设置它的命名缓存的并发访问策略。这是最值得认真考虑的步骤。

  2) 选择合适的缓存插件,而后编辑该插件的配置文件。

 

 

1.10. 使用Hibernate的优势: 

1. 对JDBC访问数据库的代码作了封装,大大简化了数据访问层繁琐的重复性代码。

2. Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工做

3. hibernate使用Java反射机制,而不是字节码加强程序来实现透明性。

4. hibernate的性能很是好,由于它是个轻量级框架。映射的灵活性很出色。它支持各类关系数据库,从一对一到多对多的各类复杂关系。

 

1.11. Hibernate是如何延迟加载? 

1. Hibernate2延迟加载实现:a)实体对象 b)集合(Collection)

2. Hibernate3 提供了属性的延迟加载功能

Hibernate在查询数据的时候,数据并无存在与内存中,当程序真正对数据的操做时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内存开销,从而提升了服务器的性能。

 

1.12. Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系) 

类与类之间的关系主要体如今表与表之间的关系进行操做,它们都是对对象进行操做,咱们程序中把全部的表与类都映射在一块儿,它们通 过配置文件中的many-to-one、one-to-many、many-to-many、

 

1.13. Hibernate的查询方式 

Sql、Criteria,object comptosition

Hql:

一、 属性查询

二、 参数查询、命名参数查询

三、 关联查询

四、 分页查询

五、 统计函数

 

1.14. 如何优化Hibernate? 

1.使用双向一对多关联,不使用单向一对多

2.灵活使用单向一对多关联

3.不用一对一,用多对一取代

4.配置对象缓存,不使用集合缓存

5.一对多集合使用Bag,多对多集合使用Set

6. 继承类使用显式多态

7. 表字段要少,表关联不要怕多,有二级缓存撑腰

 

Struts部分

4.1. Struts1.x工做机制? 

工做机制:

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组件生成动态网页,返回给客户;

 

4.2. 为何要用Struts1.x

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

 

基于Struts开发的应用由3类组件构成:控制器组件、模型组件、视图组件

 

4.3. Struts1.x的validate框架是如何验证的? 

struts配置文件中配置具体的错误提示,再在FormBean中的validate()方法具体调用。

 

4.4. 说下Struts的设计模式 

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

 

4.5. 谈谈你mvc的理解

    MVC是Model—View—Controler的简称。即模型—视图—控制器。MVC是一种设计模式,它强制性的把应用程序的输入、处理和输出分开。

    MVC中的模型、视图、控制器它们分别担负着不一样的任务。

    视图: 视图是用户看到并与之交互的界面。视图向用户显示相关的数据,并接受用户的输入。视图不进行任何业务逻辑处理。

    模型: 模型表示业务数据和业务处理。至关于JavaBean。一个模型能为多个视图提供数据。这提升了应用程序的重用性

    控制器: 当用户单击Web页面中的提交按钮时,控制器接受请求并调用相应的模型去处理请求。

            而后根据处理的结果调用相应的视图来显示处理的结果。

    MVC的处理过程:首先控制器接受用户的请求,调用相应的模型来进行业务处理,并返回数据给控制器。控制器调用相应的视图来显示处理的结果。并经过视图呈现给用户。

4.6. struts1.2和struts2.0的区别?如何控制两种框架中的单例模式?

   struts1.2和struts2.0的对比

   a、Action类:

      struts1.2要求Action类继承一个基类。struts2.0 Action要求继承ActionSupport基类

   b、线程模式

      struts1.2 Action是单例模式的而且必须是线程安全的,由于仅有一个Action的实例来处理全部的请求。

      单例策略限制了Struts1.2 Action能作的事情,而且开发时特别当心。Action资源必须是线程安全的或同步的。

      struts2.0 Action为每个请求产生一个实例,所以没有线程安全问题。

   c、Servlet依赖

      struts1.2 Action依赖于Servlet API,由于当一个Action被调用时HttpServletRequest和HttpServletResponse被传递给execut方法。

      struts2.0 Action不依赖于容器,容许Action脱离容器单独测试。若是须要,Struts2 Action仍然能够访问初始的Request和Response。

      可是,其余的元素减小或者消除了直接访问HttpServletRequest和HttpServletResponse的必要性。

   d、可测性

      测试struts1.2 Action的一个主要问题是execute方法暴露了Servlet API(这使得测试要依赖于容器)。一个第三方扩展:struts TestCase

      提供了一套struts1.2的模拟对象来进行测试。

      Struts2.0 Action能够经过初始化、设置属性、调用方法来测试,“依赖注入”也使得测试更容易。

4.7. struts如何实现国际化

    如下以两国语言(中文,英文)为例:

    1. 在工程中加入Struts支持

    2. 编辑ApplicationResource.properties文件,在其中加入要使用国际化的信息, 例如: lable.welcome.china=Welcome!!!

    3. 建立英文资源文件ApplicationResource_en.properites

    4. 建立临时中文资源文件ApplicationResource_temp.properites 例如:lable.welcom.china=中国欢迎您!

    5. 对临时中文资源文件进行编码转换。可使用myeclipse的插件,也能够在dos下执行:

       native2ascii -encoding gb2312 ApplicationResource_temp.properties ApplicationResource_zh_CN.properties

    6. 在jsp中加入struts的bean标记库 <%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean"%>

       显示信息: <bean:message key="label.welcome.china">

能够在struts-config.xml文件中定义多个资源包,而每一个资源包可以使用key属性指定包的名称。

4.8. struts2.0的经常使用标签有哪些

    1. 往action里传值:<input name="userName" type="text" class="input6" size="15">

    2. 显示标签 property 用于输出指定值:<s:property value="userName "/>

  3. 用于从页面往action中(user)的对象内传值:<s:text name="user.userName " id="username"/>

    4. 判断<s:if> </s:if> 用于在页面中判断指定数据 <s:if test="userName == admin">…. </s:if> <s:else>…. </s:else>

    5. 迭代<s:iterator>用于将List、Map、ArrayList等集合进行循环遍历

       <s:iterator value="userList" id="user" status="u">

          <s:property value="userName"/></a>

       </s:iterator>

    6. URL地址标签,<s:url>用于生成一个URL地址,能够经过URL标签指定的<s:param>子元素向URL地址发送请求参数

       <s:url action=" ">

          <s:param name=" " value=""></s:param>

       </s:url>

    7. 超连接 <a href >通常和<s:url>标签一块儿使用,用于带多个参数。

       <a href="

          <s:url action=" ">

             <s:param name=" " value=""></s:param>

             <s:param name=" " value=""></s:param>

             <s:param name=" " value=""></s:param>

          </s:url>

       ">超连接</a>

    8. set标签,用于将某个值放入指定的范围内。例如application,session等。

       <s:set name="user" value="userName" scope=”request”/>

 

4.9. struts中怎么配置form-bean、action、tiles

    此处配置的是struts1.2的

    form-bean配置:(在配置文件struts-config.xml中):

    <form-beans >

   <form-bean name="" type=""></form-bean>

   </form-beans>

    name: 指定form的名字; type指定form的类型:包名+类名;

   action配置:(在配置文件struts-config.xml中)

   <action-mappings >

   <action path=""

           attribute=""

           input=""

           name=""

           parameter=""

           scope="request"

           type=""

           ></action>

   </action-mappings>

   path:请求Action的名字;   attribute:form的名字,与form-bean中的name对应;   input:输入页的路径;

   name:若是配置了attribute,name不起做用,与attribute同样;   parameter:使用分发Action时,指定调用分发Action中的方法名;

   scope:Action的范围;    type:Action的类型:包名+类名;

   

   tites配置:

   1. 新建一个 tiles-defs.xml文件,并在其中作以下配置:

      <?xml version="1.0" encoding="UTF-8"?>

      <!DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 1.1//EN" "http://jakarta.apache.org/struts/dtds/tiles-config_1_1.dtd">

      <tiles-definitions>

        <definition name="member-definition" path="/Jsp/layout.jsp">  

          <put name="top" value="/mTop.do"/>  

          <put name="left" value="/mLeft.do"/>

          <put name="main" value="/defaultMmain.do"/>

        </definition>

     </tiles-definitions>

   2. 在web.xml和struts-config.xml和web.xml中作相应配置:

      struts-config.xml中配置以下:

      ************

      <plug-in className="org.apache.struts.tiles.TilesPlugin">

         <set-property property="definitions-config" value="/WEB-INF/tiles-defs.xml"/>   

         <set-property property="definitions-parser-validate" value="true"/>

      </plug-in>

      ************

      web.xml中配置以下:

      ************

      <init-param>    

         <param-name>definitions-config</param-name>    

         <param-value>/WEB-INF/tiles-defs.xml</param-value>

      </init-param>

      *************

   3. 调用Tiles组件

      Tiles组件是经过Struts Action来调用的,在struts-config.xml中作以下action配置:

      *************

      <action

        path="/member"

        parameter="member-definition"

        type="org.apache.struts.actions.ForwardAction"/>

     **************

4.10. logic标签有哪几个?

    此标签库能够分为三种类型:条件、循环、转发/重定向。

    1. 条件类型 (没标注的都比较简单)

       logic:empty, logic:notEmpty;

       logic:equal, logic:notEqual, logic:lessThan, logic:greaterThan,logic:lessEqual, logic:greaterEqual;

       logic:present, logic:notPresent;

       logic:match, logic:notMatch; 比较两字符串是否相等,能够比较字符串的开始的、结尾的或其中的某个部分。location属性:指定从某个位置开始进行比较。

    

    2. 循环类型

       logic:iterate

    

    3. 转发/重定向类型

       logic:forward和logic:redirect

       logic:forward标签和jsp:forward标签类似,但它可使用global forward中的一个ActionForward

       例如:<logic:forward name="login" />

       ------------------------------------------------------------------------------

       与上面相关的global forward中的代码:

       <global-forwards>

          <forward name="login" path="/loginForm.jsp"/>

       </global-forwards>

       logic:redirect标签和上面的标签相似,但它默认调用的方法是response.sendRedirect(),

       取代了上面的requestDispatcher.forward()。最大的不一样是它支持全部html:link标签的属性,因此你可以指定request参数:

       <logic:redirect name="login" paramId="employeeId" paramName="employee" property="id" />

       MVC框架下,不推荐使用这两个标签,你应该是从controller中选择下一个view,而不是从view中选择.在Jsp页面中不要过多的使用logic标签。

 

4.11. action是单实例仍是多实例,为何?

    action是单实例的。当多个用户访问一个请求的时候,服务器内存中只有一个与之对应的action类对象。

    由于当服务器第一次加载struts的配置文件的时候,建立了一个Action后,每发送一个请求,服务器都会先去检索相应的范围内(request,session)是否存在

    这样一个action实例,若是存在,则使用这个实例,若是不存在,则建立一个action实例。

 

4.12. dispatchAction是用什么技术实现的?

    DispatchAction 是Aciton的一个子类,主要解决了一个请求处理多个功能的问题

    普通的Action你只能写execute方法来处理业务,而想用这一个Action处理多个任务,你必需要请求参数进行解析,用if语句块来处理

    举一个小例子:

    有以下一个url:  http://localhost:8080/myApp/addUserAction.do

    若是你处理这个url的是一个普通的Action,那么就只能在execute里面执行插入的相关操做,若是换成一下url:

    http://localhost:8080/myApp/UserAction.do?method=add

    你就应该根据method对象的值来执行相应的操做,如再有一个路径http://localhost:8080/myApp/UserAction.do?method=delete

    这个还可使用那个Action来处理的,只是多判断一下而已.

若是你用DispatchAction,就简单多了,因此dispatchAction仍是用的Action的这么一个技术。

 

4.13. struts2.0的mvc模式?与struts1.0的区别?

    struts2的mvc模式:当用户在页面提交用户请求时,该请求须要提交给struts2的控制器处理。struts2的控制器根据处理结果,

    决定将哪一个页面呈现给客户端。

    struts1最大的不一样是:struts2的控制器。struts2的控制器再也不像struts1的控制器,须要继承一个Action父类,甚至能够无需实现

    任何接口,struts2的Action就是一个普通的POJO。实际上,Struts2 的Action就是一个包含execute方法的普通Java类

    该类里包含的多个属性用于封装用户的请求参数。

 

4.14. struts的处理流程。

1、ActionServlet的初始化
ActionServlet做为Struts组件的前端控制器,因为web.xml的相应配置:

<load-on-startup>0</load-on-startup>
在应用一加载时即会被实例化并调用其init方法,init方法所作的主要工做有二:

1. 加载struts配置文件,并建立用于封装配置信息的ModuleConfig对象
2. 加载资源文件,并建立用于封装资源文件的MessageResources对象
须要注意两点:若是web.xml有多模块配置,将建立多个ModuleConfig对象和MessageResources对象分别

用于封装各个模块的struts配置文件和资源文件。
针对各个模块所建立的ModuleConfig对象和MessageResources对象将存储在ServletContext中,对应的属

性名中有该模块名称的相应标识。
另外,若是有相应配置的话,init方法还将初始化数据源和PlugIn

2、ActionServlet的process
全部形如*.do的请求(根据web.xml中的相关配置)将提交给ActionServlet,最终将调用其process方法

process方法的主要工做有三:

1.  根据请求信息获知所请求的模块名称,从ServletContext中得到与请求模块对应的的ModuleConfig对

象,并存储到request中。
2.  根据模块信息得到相应的RequestProcessor对象,一个模块对应一个RequestProcessor对象,

RequestProcessor对象将关联与所属模块对应的ModuleConfig对象。
3.  调用RequestProcessor对象的process方法,将request和response做为参数传递给它。

3、RequestProcessor的process
RequestProcessor对象的process方法的主要工做有五步:
1.  调用本身的 processPreprocess(request, response)方法,该方法不进行任何操做,用于子类重写

扩展其功能。
2.  得到与请求地址所匹配的ActionMapping对象,AcionMapping对象用于封装一个特定acion的配置信息


3.  根据ActionMapping中的配置信息得到ActionForm对象(该对象将缓存到request或session中),并

将表单数据填充到ActionForm中,而后根据ActionMapping的配置决定是否验证ActionForm,若是验证,

将调用ActionForm的 validate方法,若其返回的ActionErros对象中包含ActionMessage对象则表示验证

失败,将转向action配置信息 input属性所指示的地址。
4.  若是ActionForm无需验证或验证经过将建立并缓存与请求地址匹配的Action对象,将ActionMapping

对象、ActionForm对象、request和response做为参数调用其execute方法。
5.  根据Action对象的execute方法返回的ActionForward对象,将请求转发或重定向到该ActionForward

所封装的地址。

Struts2.0与Struts1.x有何区别。

Feature特征

Struts 1 Struts的一

Struts 2 Struts的2

Action classes行动班

Struts 1 requires Action classes to extend an abstract base class. Struts的一要求采起行动班,以延长一个抽象的基类。 A common problem in Struts 1 is programming to abstract classes instead of interfaces.一个共同的问题在Struts的一,是编程抽象类而不是接口。

An Struts 2 Action may implement an Action interface, along with other interfaces to enable optional and custom services. 1 2 Struts的行动, 可能实施一项行动的界面,随着其余接口,使可选和定制服务。 Struts 2 provides a base ActionSupport class to implement commonly used interfaces. Struts的2提供了相应的actionsupport一流的执行经常使用的接口。 Albeit, the Action interface is not required.虽然,这项行动的界面是否是必需的 。 Any POJO object with a execute signature can be used as an Struts 2 Action object.任何波霍对象与执行的签名能够被用来做为一个Struts的二行动的对象。

Threading Model线程模型

Struts 1 Actions are singletons and must be thread-safe since there will only be one instance of a class to handle all requests for that Action. Struts的一行动是单身,必须线程安全的,由于将只有一个实例一类来处理全部的请求采起行动。 The singleton strategy places restrictions on what can be done with Struts 1 Actions and requires extra care to develop.单身人士策略地方的限制,能够作些什么与Struts的一行动,并要求加倍当心发展。 Action resources must be thread-safe or synchronized.行动的资源,必须线程安全的或同步。

Struts 2 Action objects are instantiated for each request, so there are no thread-safety issues. 2 Struts的行动对象是实例对于每一个请求,所以没有线程安全问题。 (In practice, servlet containers generate many throw-away objects per request, and one more object does not impose a performance penalty or impact garbage collection.) (在实践中, Servlet的容器,产生许多扔离家出走的对象,每次请求,并多一个对象不施加表现罚款,或影响垃圾收集) 。

Servlet Dependency Servlet的依赖

Struts 1 Actions have dependencies on the servlet API since the HttpServletRequest and HttpServletResponse is passed to the execute method when an Action is invoked. Struts的一行动,依赖于该Servlet的空气污染指数以来, httpservletrequest和httpservletresponse传递给Execute方法,当一个行动是引用。

Struts 2 Actions are not coupled to a container. Struts的行动,二是不耦合的一个货柜。 Most often the servlet contexts are represented as simple Maps, allowing Actions to be tested in isolation.最常常的Servlet的背景是派表明做为简单的地图,让行动,以测试陷入孤立的境地。 Struts 2 Actions can still access the original request and response, if required. 2 Struts的行动仍然可使用原来的请求和响应,若是须要。 However, other architectural elements reduce or eliminate the need to access the HttpServetRequest or HttpServletResponse directly.不过,其余建筑元素,减小或消除须要访问httpservetrequest或httpservletresponse直接。

Testability测试

A major hurdle to testing Struts 1 Actions is that the execute method exposes the Servlet API.一个主要障碍,以测试Struts的一行动是Execute方法暴露了Servlet的空气污染指数。 A third-party extension, Struts TestCase, offers a set of mock object for Struts 1.第三党的扩展, Struts的testcase ,提供了一套模拟对象的Struts 1 。

Struts 2 Actions can be tested by instantiating the Action, setting properties, and invoking methods. 2 Struts的行动能够测试实例化的行动,设置属性,引用的方法。 Dependency Injection support also makes testing simpler.依赖注入的支持也使测试更简单。

Harvesting Input收获的投入

Struts 1 uses an ActionForm object to capture input. Struts的一使用actionform对象捕获输入。 Like Actions, all ActionForms must extend a base class.同样的行动,全部actionforms必须扩大基地,一流的。 Since  other JavaBeans cannot be used as ActionForms, developers often create redundant classes to capture input.因为其余的JavaBeans不能被用来做为actionforms ,开发商经常形成多余的班,以捕捉的投入。 DynaBeans can used as an alternative to creating conventional ActionForm classes, but, here too, developers may be redescribing existing JavaBeans. dynabeans能够用来做为一种替代创造常规actionform班,但这里太,发展商可能会redescribing现有的JavaBeans 。

Struts 2 uses Action properties as input properties, eliminating the need for a second input object. Struts的2使用性能的行动做为输入属性,再也不须要第二个输入对象。 Input properties may be rich object types which may have their own properties.输入属性多是丰富的对象类型可能有本身的属性。 The Action properties can be accessed from the web page via the taglibs.行动性质能够从网页上经过taglibs 。 Struts 2 also supports the ActionForm pattern, as well as POJO form objects and POJO Actions. Struts的2还支持actionform模式,以及波霍形式,对象和波霍行动。 Rich object types, including business or domain objects, can be used as input/output objects.丰富的对象类型,其中包括商业利益或域对象,能够被用来做为输入/输出对象。 The ModelDriven feature simplifies taglb references to POJO input objects.该modeldriven功能简化taglb的提述,波霍投入对象。

Expression Language语言表达

Struts 1 integrates with JSTL, so it uses the JSTL EL. Struts的一整合与jstl ,因此它使用jstl下午。 The EL has basic object graph traversal, but relatively weak collection and indexed property support.的El已基本对象图遍历,但相对薄弱的收集和索引财产的支持。

Struts 2 can use JSTL, but the framework also supports a more powerful and flexible expression language called "Object Graph Notation Language" (OGNL). Struts的二可使用jstl ,但框架也支持一个更强大和灵活的语言表达所谓的“对象图形符号语言” ( ognl ) 。

Binding values into views有约束力的价值观归入意见

Struts 1 uses the standard JSP mechanism for binding objects into the page context for access. Struts的一使用标准的JSP机制,有约束力的物体进入该网页的背景下访问。

Struts 2 uses a "ValueStack" technology so that the taglibs can access values without coupling your view to the object type it is rendering. Struts的2使用“ valuestack ”技术,使该taglibs能够访问的价值观没有耦合您的见解,以对象类型,这是渲染。 The ValueStack strategy allows reuse of views across a range of types which may have the same property name but different property types.该valuestack策略容许重用的意见覆盖的类型可能有相同的属性名称,但不一样的属性类型。

Type Conversion类型转换

Struts 1 ActionForm properties are usually all Strings. Struts的一actionform属性一般是全部字符串。 Struts 1 uses Commons-Beanutils for type conversion. Struts的一用途的商品- beanutils为类型转换。 Converters are per-class, and not configurable per instance.转换器每级的,而不是配置的每一个实例。

Struts 2 uses OGNL for type conversion. Struts的2使用ognl为类型转换。 The framework includes converters for basic and common object types and primitives.该框架包括转换为基本和共同的对象类型和原始。

Validation验证

Struts 1 supports manual validation via a validate method on the ActionForm, or through an extension to the Commons Validator. Struts的一支持手册审定经过验证方法对actionform ,或经过一个扩展到商品校验。 Classes can have different validation contexts for the same class, but cannot chain to validations on sub-objects.班级能够有不一样的验证背景为同一阶层,但不能链,以验证就分对象。

Struts 2 supports manual validation via the validate method and the XWork Validation framework. Struts的2支持手册审定经过验证的方法和xwork的验证框架。 The Xwork Validation Framework supports chaining validation into sub-properties using the validations defined for the properties class type and the validation context.该xwork的验证框架支持连接验证分为分性能的使用验证的定义为性能一流的类型和验证。

Control Of Action Execution控制行动的执行

Struts 1 supports separate Request Processors (lifecycles) for each module, but all the Actions in the module must share the same lifecycle. Struts的一支持独立的请求处理器(生命周期)为每一个单元,但全部的行动,在该模块必须共用相同的生命周期。

Struts 2 supports creating different lifecycles on a per Action basis via Interceptor Stacks. 2 Struts的支持,创造不一样的生命周期对每行动的基础上经过拦截堆叠。 Custom stacks can be created and used with different Actions, as needed.自定义栈,才能创造和使用不一样的行动,视须要。

 

4.15. Struts/webwork 的工做机制,它有哪些标签

Struts 2框架的大体处理流程以下:

 浏览器发送请求,例如请求/mypage.action、/reports/myreport.pdf等。

 核心控制器FilterDispatcher根据请求决定调用合适的Action。

 WebWork的拦截器链自动对请求应用通用功能,例如workflow、validation或文件上传等功能。

 回调Action的execute方法,该execute方法先获取用户请求参数,而后执行某种数据库操做,既能够是将数据保存到数据库,也能够从数据库中检索信息。实际上,由于Action只是一个控制器,它会调用业务逻辑组件来处理用户的请求。

 Action的execute方法处理结果信息将被输出到浏览器中,能够是HTML页面、图像,也能够是PDF文档或者其余文档。此时支持的视图技术很是多,既支持JSP,也支持Velocity、FreeMarker等模板技术。

Spring部分

4.1. spring工做机制 

1.spring mvc请全部的请求都提交给DispatcherServlet,它会委托应用系统的其余模块负责负责对请求进行真正的处理工做。

2.DispatcherServlet查询一个或多个HandlerMapping,找处处理请求的Controller.

3.DispatcherServlet请请求提交到目标Controller

4.Controller进行业务逻辑处理后,会返回一个ModelAndView

5.Dispathcher查询一个或多个ViewResolver视图解析器,找到ModelAndView对象指定的视图对象

6.视图对象负责渲染返回给客户端。

4.2. 使用Spring的好处

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

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

Spring即便一个AOP框架,也是一IOC容器。 Spring 最好的地方是它有助于您替换对象。有了 Spring,只要用 JavaBean 属性和配置文件加入依赖性(协做对象)。而后能够很容易地在须要时替换具备相似接口的协做对象。}

 

 

4.3. spring是什么?根据你的理解详细谈谈你的看法。

目的:解决企业应用开发的复杂性

  功能:使用基本的JavaBean代替EJB,并提供了更多的企业应用功能

  范围:任何Java应用

  简单来讲,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中的各类模块提供了基础支持。

 

4.4. 项目中如何体现Spring中的切面编程,具体说明。

   面向切面编程:主要是横切一个关注点,将一个关注点模块化成一个切面。在切面上声明一个通知(Advice)和切入点(Pointcut); 通知: 是指在切面的某个特定的链接点(表明一个方法的执行。经过声明一个org.aspectj.lang.JoinPoint类型的参数可使通知(Advice)的主体部分得到链接点信息。)上执行的动做。通知中定义了要插入的方法。切入点:切入点的内容是一个表达式,以描述须要在哪些对象的哪些方法上插入通知中定义的方法。

   项目中用到的Spring中的切面编程最多的地方:声明式事务管理。

   a、定义一个事务管理器

   b、配置事务特性(至关于声明通知。通常在业务层的类的一些方法上定义事务)

   c、配置哪些类的哪些方法须要配置事务(至关于切入点。通常是业务类的方法上)

   

 

4.5. spring在项目中如何充当粘合剂

    一、在项目中利用spring的IOC(控制反转或依赖注入),明确地定义组件接口(如UserDAO),开发者能够独立开发各个组件, 而后根据组件间的依赖关系组装(UserAction依赖于UserBiz,UserBiz依赖于UserDAO)运行,很好的把Struts(Action)和hibernate(DAO的实现)结合起来了。

    二、spring的事务管理把hibernate对数据库的操做进行了事务配置。

 

4.6. spring的事务如何配置

    spring的声明式事务配置:

    1. <!-- 配置sessionFactory -->

<bean id="sessionFactory"

class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">

<property name="configLocation">

<value>/WEB-INF/classes/hibernate.cfg.xml</value>

</property>

</bean>  

    2. 配置事务管理器

       <!-- 配置事务管理器 -->

<bean id="transactionManager"

class="org.springframework.orm.hibernate3.HibernateTransactionManager">

<property name="sessionFactory">

<ref local="sessionFactory" />

</property>

</bean>

    3. 配置事务特性

       <tx:advice id="txAdvice"  transaction-manager="transactionManager">

<tx:attributes>

             <tx:method name="add*" propagation="REQUIRED"/>

                    <tx:method name="update*" propagation="REQUIRED"/>

                    <tx:method name="del*" propagation="REQUIRED"/>

                    <tx:method name="*" read-only="true"/>

                </tx:attributes>

       </tx:advice>

    4. 配置哪些类的哪些方法配置事务

       <aop:config>

           <aop:pointcut id="allManagerMethod" ession="execution(* com.yyaccp.service.impl.*.*(..))"/>

           <aop:advisor advice-ref="txAdvice" pointcut-ref="allManagerMethod">

       </aop:config>

 

 

4.7. transaction有那几种实现

   Spring中,事务处理主要有两种方式

(1) 代码控制事务  

在程序中引入新的模版类,这个类封装了事务管理的功能

(2) 参数配置控制事务,在Application-Context.xml增长一个事务代理(UserDAOProxy)配置

 

IBATIS中的事物属性怎么配置

SQL MAP XML配置文件中的transactionManager

 

综合部分

4.1. Hibernate和spring中常出现的几个异常

   org.springframework.beans.factory.BeanCreationException:

       Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]:

       Initialization of bean failed; nested exception is org.hibernate.MappingException: Repeated column in mapping for entity: com.xindeco.myregister.pojo.MyRegisterInfo column:

       password (should be mapped with insert="false" update="false")

       出错缘由:password 和repassword同时对应数据库表中的password一列,同时update和insert都设为true。xml文件以下:

      <property name="password"

                          type="java.lang.String"

                          update="true"

                          insert="true"

                          access="property"

                          column="password"

                          length = "32"

                          />

 

                         <property name="repassword"

                          type="java.lang.String"

                          update="false"

                          insert="false"

                          access="property"

                          column="password"

                          length = "32"

                          />

       解决方法:将repassword的insert和update设为false。

 

   org.springframework.beans.factory.BeanCreationException:

       Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]:

       Initialization of bean failed;nested exception is org.hibernate.PropertyNotFoundException: Could not find a getter for ID in class

      错误缘由:hibernate的映射文件中ID是大写的,而pojo的类中id是小写的

      解决方法:要么将pojo类中的id改称大写,要么把hibernate的映射文件中的ID改称小写。

 

4.2. Hibernate与jdbc的联系

    hibernate是jdbc的轻量级封装,包括jdbc的与数据库的链接(用hibernate.property的配置文件实现固然本质是封装了jdbc的forname),

    和查询,删除等代码,都用面向对象的思想用代码联系起来,hibernate经过hbm 配置文件把po类的字段和数据库的字段关联起来好比数据库的id,

    po类中就是pravite Long id; public Long getId() ;public setId(Long id);

    而后hql语句也是面向对象的,它的查询语句不是查询数据库而是查询类的,这些实现的魔法就是xml文件,其实hibernate=封装的jdbc+xml文件

4.3. Hibernate与spring的联系

    hibernate中的一些对象能够给Spring来管理,让Spring容器来建立hibernate中一些对象实例化。例如:SessionFactory,HibernateTemplate等。

    Hibernate原本是对数据库的一些操做,放在DAO层,而Spring给业务层的方法定义了事务,业务层调用DAO层的方法,很好的将Hibernate的操做也加入到事务中来了。

 

4.4. 项目中为何使用SSH

    1. 使用Struts是由于struts是基于MVC模式的,很好的将应用程序进行了分层,使开发者更关注于业务逻辑的实现;第二,struts有着丰富的taglib,如能灵活运用,则能大大提升开发效率。

    2. 使用Hibernate:由于hibernate为Java应用提供了一个易用的、高效率的对象关系映射框架。hibernate是个轻量级的持久性框架,功能丰富。

    3. 使用Spring:由于spring基于IoC(Inversion of Control,反向控制)和AOP构架多层j2ee系统的框架,但它不强迫你必须在每一层中必须使用Spring,由于它模块化的很好,容许你根据本身的须要选择使用它的某一个模块;

       采用IoC使得能够很容易的实现bean的装配,提供了简洁的AOP并据此实现事务管理(Transcation Managment),等等

相关文章
相关标签/搜索