企业面试题总结SSH框架技术运用.docx

上传人:b****5 文档编号:3439808 上传时间:2022-11-23 格式:DOCX 页数:21 大小:33.92KB
下载 相关 举报
企业面试题总结SSH框架技术运用.docx_第1页
第1页 / 共21页
企业面试题总结SSH框架技术运用.docx_第2页
第2页 / 共21页
企业面试题总结SSH框架技术运用.docx_第3页
第3页 / 共21页
企业面试题总结SSH框架技术运用.docx_第4页
第4页 / 共21页
企业面试题总结SSH框架技术运用.docx_第5页
第5页 / 共21页
点击查看更多>>
下载资源
资源描述

企业面试题总结SSH框架技术运用.docx

《企业面试题总结SSH框架技术运用.docx》由会员分享,可在线阅读,更多相关《企业面试题总结SSH框架技术运用.docx(21页珍藏版)》请在冰豆网上搜索。

企业面试题总结SSH框架技术运用.docx

企业面试题总结SSH框架技术运用

Struts1+Struts2+Spring+Hibernate+iBatis

一.Struts

1.谈谈你mvc的理解

MVC是Model—View—Controler的简称。

即模型—视图—控制器。

MVC是一种设计模式,它强制性的把应用程序的输入、处理和输出分开。

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

视图:

视图是用户看到并与之交互的界面。

视图向用户显示相关的数据,并接受用户的输入。

视图不进行任何业务逻辑处理。

模型:

模型表示业务数据和业务处理。

相当于JavaBean。

一个模型能为多个视图提供数据。

这提高了应用程序的重用性

控制器:

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

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

MVC的处理过程:

首先控制器接受用户的请求,调用相应的模型来进行业务处理,并返回数据给控制器。

控制器调用相应的视图来显示处理的结果。

并通过视图呈现给用户。

2.struts1.2和struts2.0的区别?

如何控制两种框架中的单例模式?

struts1.2和struts2.0的对比

a、Action类:

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

struts2.0Action要求继承ActionSupport基类

b、线程模式

struts1.2Action是单例模式的并且必须是线程安全的,因为仅有一个Action的实例来处理所有的请求。

单例策略限制了Struts1.2Action能做的事情,并且开发时特别小心。

Action资源必须是线程安全的或同步的。

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

c、Servlet依赖

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

struts2.0Action不依赖于容器,允许Action脱离容器单独测试。

如果需要,Struts2Action仍然可以访问初始的Request和Response。

但是,其他的元素减少或者消除了直接访问HttpServletRequest和HttpServletResponse的必要性。

d、可测性

测试struts1.2Action的一个主要问题是execute方法暴露了ServletAPI(这使得测试要依赖于容器)。

一个第三方扩展:

strutsTestCase

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

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

3.项目中为什么使用SSH

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

2.使用Hibernate:

因为hibernate为Java应用提供了一个易用的、高效率的对象关系映射框架。

hibernate是个轻量级的持久性框架,功能丰富。

3.使用Spring:

因为spring基于IoC(InversionofControl,反向控制)和AOP构架多层j2ee系统的框架,但它不强迫你必须在每一层中必须使用Spring,因为它模块化的很好,允许你根

据自己的需要选择使用它的某一个模块;

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

4.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-encodinggb2312ApplicationResource_temp.propertiesApplicationResource_zh_CN.properties

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

显示信息:

messagekey="label.welcome.china">

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

5.struts2.0的常用标签

1.往action里传值:

2.显示标签property用于输出指定值:

propertyvalue="userName"/>

  3.用于从页面往action中(user)的对象内传值:

textname="user.userName"id="username"/>

4.判断

if>

if>用于在页面中判断指定数据

iftest="userName==admin">….

if>

else>….

else>

5.迭代

iterator>用于将List、Map、ArrayList等集合进行循环遍历

iteratorvalue="userList"id="user"status="u">

propertyvalue="userName"/>

iterator>

6.struts1中怎么配置?

form-bean配置:

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

name:

指定form的名字;type指定form的类型:

包名+类名;

action配置:

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

attribute=""

input=""

name=""

parameter=""

scope="request"

type=""

>

path:

请求Action的名字;attribute:

form的名字,与form-bean中的name对应;input:

输入页的路径;

name:

如果配置了attribute,name不起作用,与attribute一样;parameter:

使用分发Action时,指定调用分发Action中的方法名;

scope:

Action的范围;type:

Action的类型:

包名+类名;

8.action是单实例还是多实例,为什么?

action是单实例的。

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

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

这样一个action实例,如果存在,则使用这个实例,如果不存在,则创建一个action实例。

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

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

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

10.struts2.0的mvc模式?

struts2的mvc模式:

当用户在页面提交用户请求时,该请求需要提交给struts2的控制器处理。

struts2的控制器根据处理结果,

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

11.struts的处理流程。

一、ActionServlet的初始化

ActionServlet作为Struts组件的前端控制器,由于web.xml的相应配置:

0

在应用一加载时即会被实例化并调用其init方法,init方法所做的主要工作有二:

1.加载struts配置文件,并创建用于封装配置信息的ModuleConfig对象

2.加载资源文件,并创建用于封装资源文件的MessageResources对象

需要注意两点:

如果web.xml有多模块配置,将创建多个ModuleConfig对象和MessageResources对象分别

用于封装各个模块的struts配置文件和资源文件。

针对各个模块所创建的ModuleConfig对象和MessageResources对象将存储在ServletContext中,对应的属

性名中有该模块名称的相应标识。

另外,如果有相应配置的话,init方法还将初始化数据源和PlugIn

二、ActionServlet的process

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

process方法的主要工作有三:

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

象,并存储到request中。

2.根据模块信息获得相应的RequestProcessor对象,一个模块对应一个RequestProcessor对象,

RequestProcessor对象将关联与所属模块对应的ModuleConfig对象。

3.调用RequestProcessor对象的process方法,将request和response作为参数传递给它。

三、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

所封装的地址。

二.Hibernate

1.Hibernate工作原理?

hibernate,通过对jdbc进行封装,对java类和关系数据库进行mapping,实现了对关系数据库的面向对象方式的操作,改变了传统的jdbc+sql操作数据的方式,从而使开发人员可以话更多精力进行对象方面的开发

1.读取并解析配置文件

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

3.打开Sesssion

4.创建事务Transation

5.持久化操作

6.提交事务

7.关闭Session

8.关闭SesstionFactory

2.为什么要用Hibernate?

对JDBC访问数据库的代码做了封装,对java类和关系数据库进行mapping,实现了对关系数据库的面向对象方式的操作,改变了传统的jdbc+sql操作数据的方式,大大简化了数据访问层繁琐的重复性代码。

Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。

他很大程度的简化DAO层的编码工作。

hibernate的性能非常好,因为它是个轻量级框架。

映射的灵活性很出色。

它支持各种关系数据库,从一对一到多对多的各种复杂关系。

3.什么是Hibernate的并发机制?

怎么去处理并发问题?

Hibernate并发机制:

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

然后就丢弃。

如果一个Session实例允许共享的话,那些支持并发运行的,例如Httprequest,sessionbeans将会导致出现资源争用。

如果在HttpSession中有hibernate的Session的话,就可能会出现同步访问HttpSession。

只要用户足够快的点击浏览器的“刷新”,

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

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

解决方案:

设置事务隔离级别。

Serializable:

串行化。

隔离级别最高

RepeatableRead:

可重复读

ReadCommitted:

已提交数据读

ReadUncommitted:

未提交数据读。

隔离级别最差

设置锁:

乐观锁和悲观锁。

乐观锁:

使用版本号或时间戳来检测更新丢失,在的映射中设置optimistic-lock="all"可以在没有版本或者时间戳属性映射的情况下实现版本检查,此时Hibernate将

比较一行记录的每个字段的状态行级悲观锁:

Hibernate总是使用数据库的锁定机制,从不在内存中锁定对象!

只要为JDBC连接指定一下隔离级别,然后让数据库去搞定一切就够了。

LockMode定义了Hibernate所需的不同的锁定级别:

LockMode.UPGRADE,LockMode.UPGRADE_NOWAIT,LockMode.READ;

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

org.springframework.beans.factory.BeanCreationException:

Errorcreatingbeanwithname'sessionFactory'definedinServletContextresource[/WEB-INF/applicationContext.xml]:

Initializationofbeanfailed;nestedexceptionisorg.hibernate.MappingException:

Repeatedcolumninmappingforentity:

com.xindeco.myregister.pojo.MyRegisterInfocolumn:

password(shouldbemappedwithinsert="false"update="false")

出错原因:

password和repassword同时对应数据库表中的password一列,同时update和insert都设为true。

xml文件如下:

type="java.lang.String"

update="true"

insert="true"

access="property"

column="password"

length="32"

/>

type="java.lang.String"

update="false"

insert="false"

access="property"

column="password"

length="32"

/>

解决方法:

将repassword的insert和update设为false。

org.springframework.beans.factory.BeanCreationException:

Errorcreatingbeanwithname'sessionFactory'definedinServletContextresource[/WEB-INF/applicationContext.xml]:

Initializationofbeanfailed;nestedexceptionisorg.hibernate.PropertyNotFoundException:

CouldnotfindagetterforIDinclass

错误原因:

hibernate的映射文件中ID是大写的,而pojo的类中id是小写的

解决方法:

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

4.Hibernate与jdbc的联系

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

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

在po类中就是praviteLongid;publicLonggetId();publicsetId(Longid);

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

5.Hibernate与spring的联系

hibernate中的一些对象可以给Spring来管理,让Spring容器来创建hibernate中一些对象实例化。

例如:

SessionFactory,HibernateTemplate等。

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

6.Hibernate自带的分页机制是什么?

如果不使用Hibernate自带的分页,则采用什么方式分页?

1、hibernate自带的分页机制:

获得Session对象后,从Session中获得Query对象。

用Query.setFirstResult():

设置要显示的第一行数据,

Query.setMaxResults():

设置要显示的最后一行数据。

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

如:

5:

为每页显示的记录,2为当前页:

select*top5fromtablewheretabIdnotin(selecttabIdtop(2-1)*5fromtable);

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

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

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

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

例如:

一个student和classes表的关系。

一个学生只能是一个班的,一个班可以有多个学生。

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

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

update()方法操作的对象必须是持久化了的对象。

也就是说,如果此对象在数据库中不存在的话,就不能使用update()方法。

saveOrUpdate()方法操作的对象既可以使持久化了的,也可以使没有持久化的对象。

如果是持久化了的对象调用saveOrUpdate()则会

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

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

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

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

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

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

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

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

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

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

11.hibernate拒绝连接、服务器崩溃的原因?

最少写5个

1.db没有打开

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

3.连接配置错了

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

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

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

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

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

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

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

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

12.Hibernate介绍

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。

Hibernate可以应用在任何使用

JDBC的场合,既可以在Java的客户端程序使用,也可以在Servle

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 人文社科 > 教育学心理学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1