事理:

1.读取并解析配置文件

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

stutsjsp类名属性Springhibernatestruts经典面试笔试题含谜底 Node.js

3.打开Sesssion

4.创建事务Transation

5.持久化操作

6.提交事务

7.关闭Session

8.关闭SesstionFactory

为什么要用:

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

② . Hibernate是一个基于JDBC的主流持久化框架,是一个精良的ORM实现。
他很大程度的简化DAO层的编码事情

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

④ . hibernate的性能非常好,由于它是个轻量级框架。
映射的灵巧性很出色。
它支持各种关系数据库,从一对一到多对多的各种繁芜关系。

2. Hibernate是如何延迟加载?

① . Hibernate2延迟加载实现:a)实体工具 b)凑集(Collection)

② . Hibernate3 供应了属性的延迟加载功能

当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,工具才存在与内存中,就实现了延迟加载,他节省了做事器的内存开销,从而提高了做事器的性能。

3.Hibernate中若何实现类之间的关系?(如:一对多、多对多的关系)

类与类之间的关系紧张表示在表与表之间的关系进行操作,它们都邑对工具进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one、one-to-many、many-to-many、

4. 说下Hibernate的缓存机制

① . 内部缓存存在Hibernate中又叫一级缓存,属于运用事物级缓存

② . 二级缓存:

a) 运用及缓存

b) 分布式缓存

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

c) 第三方缓存的实现

5. Hibernate的查询办法

Sql、Criteria,object comptosition

Hql:

1、 属性查询

2、 参数查询、命名参数查询

3、 关联查询

4、 分页查询

5、 统计函数

6. 如何优化Hibernate?

①.利用双向一对多关联,不该用单向一对多

②.灵巧利用单向一对多关联

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

④.配置工具缓存,不该用凑集缓存

⑤.一对多凑集利用Bag,多对多凑集利用Set

⑥. 继续类利用显式多态

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

7. 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类组件构成:掌握器组件、模型组件、视图组件

8. Struts的validate框架是如何验证的?

在struts配置文件中配置详细的缺点提示,再在FormBean中的validate()方法详细调用。

9. 说下Struts的设计模式

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

10. spring事情机制及为什么要用?

①.spring mvc请所有的要求都提交给DispatcherServlet,它会委托运用系统的其他模块卖力卖力对要求进行真正的处理事情。

②.DispatcherServlet查询一个或多个HandlerMapping,找到处理要求的Controller.

③.DispatcherServlet请要求提交到目标Controller

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

⑤.Dispathcher查询一个或多个ViewResolver视图解析器,找到ModelAndView工具指定的视图工具

⑥.视图工具卖力渲染返回给客户端。

为什么用:

{AOP 让开发职员可以创建非行为性的关注点,称为横切关注点,并将它们插入到运用程序代码中。
利用 AOP 后,公共做事 (比 如日志、持久性、事务等)就可以分解成方面并运用到域工具上,同时不会增加域工具的工具模型的繁芜性。

IOC 许可创建一个可以布局工具的运用环境,然后向这些工具通报它们的协为难刁难象。
正如单词 颠倒 所表明的,IOC 就像反 过来的 JNDI。
没有利用一堆抽象工厂、做事定位器、单元素(singleton)和直接布局(straight construction),每一个工具都是用其协为难刁难象布局的。
因此是由容器管理协为难刁难象(collaborator)。

Spring纵然一个AOP框架,也是一IOC容器。
Spring 最好的地方是它有助于您更换工具。
有了 Spring,只要用 JavaBean 属性和配置文件加入依赖性(协为难刁难象)。
然后可以很随意马虎地在须要时更换具有类似接口的协为难刁难象。
}

Spring 框架是一个分层架构,由 7 个定义良好的模块组成。
Spring 模块构建在核心容器之上,核心容器定义了创建、配置和管理 bean 的办法。

组成 Spring 框架的每个模块(或组件)都可以单独存在,或者与其他一个或多个模块联合实现。
每个模块的功能如下:

☆ 核心容器:核心容器供应 Spring 框架的基本功能。
核心容器的紧张组件是 BeanFactory,它是工厂模式的实现。
BeanFactory 利用掌握反转 (IOC)模式将运用程序的配置和依赖性规范与实际的运用程序代码分开。

☆ Spring 高下文:Spring 高下文是一个配置文件,向 Spring 框架供应高下文信息。
Spring 高下文包括企业做事,例如 JNDI、EJB、电子邮件、国际化、校验和调度功能。

☆ Spring AOP:通过配置管理特性,Spring AOP 模块直接将面向方面的编程功能集成到了 Spring 框架中。
以是,可以很随意马虎地使 Spring 框架管理的任何工具支持 AOP。
Spring AOP 模块为基于 Spring 的运用程序中的工具供应了事务管理做事。
通过利用 Spring AOP,不用依赖 EJB 组件,就可以将声明性事务管理集成到运用程序中。

☆ Spring DAO:JDBC DAO 抽象层供应了故意义的非常层次构造,可用该构造来管理非常处理和不同数据库供应商抛出的缺点。
非常层次构造简化了缺点处理,并且极大地降落了须要编写的非常代码数量(例如打开和关闭连接)。
Spring DAO 的面向 JDBC 的非常屈服通用的 DAO 非常层次构造。

☆ Spring ORM:Spring 框架插入了多少个 ORM 框架,从而供应了 ORM 的工具关系工具,个中包括 JDO、Hibernate 和 iBatis SQL Map。
所有这些都屈服 Spring 的通用事务和 DAO 非常层次构造。

☆ Spring Web 模块:Web 高下文模块建立在运用程序高下文模块之上,为基于 Web 的运用程序供应了高下文。
以是,Spring 框架支持与 Jakarta Struts 的集成。
Web 模块还简化了处理多部分要求以及将要求参数绑定到域工具的事情。

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

Spring 框架的功能可以用在任何 J2EE 做事器中,大多数功能也适用于不受管理的环境。
Spring 的核心要点是:支持不绑定到特定 J2EE 做事的可重用业务和数据访问工具。
毫无疑问,这样的工具可以在不同 J2EE 环境 (Web 或 EJB)、独立运用程序、测试环境之间重用。

IOC 和 AOP

掌握反转模式(也称作依赖性参与)的基本观点是:不创建工具,但是描述创建它们的办法。
在代码中不直接与工具和做事连接,但在配置文件中描述哪一个组件须要哪一项做事。
容器(在 Spring 框架中是 IOC 容器) 卖力将这些联系在一起。

在范例的 IOC 场景中,容器创建了所有工具,并设置必要的属性将它们连接在一起,决定什么韶光调用方法。
下表列出了 IOC 的一个实现模式。

Spring 框架的 IOC 容器采取类型 2 和类型3 实现。

面向方面的编程

面向方面的编程,即 AOP,是一种编程技能,它许可程序员对横切关注点或横切范例的职责分边界的行为(例如日志和事务管理)进行模块化。
AOP 的核心布局是方面,它将那些影响多个类的行为封装到可重用的模块中。

AOP 和 IOC 是补充性的技能,它们都利用模块化办法办理企业运用程序开拓中的繁芜问题。
在范例的面向工具开拓办法中,可能要将日志记录语句放在所有方法和 Java 类中才能实现日志功能。
在 AOP 办法中,可以反过来将日志做事模块化,并以声明的办法将它们运用到须要日志的组件上。
当然,上风便是 Java 类不须要知道日志做事的存在,也不须要考虑干系的代码。
以是,用 Spring AOP 编写的运用程序代码是疏松耦合的。

AOP 的功能完备集成到了 Spring 事务管理、日志和其他各种特性的高下文中。

IOC 容器

Spring 设计的核心是 org.springframework.beans 包,它的设计目标是与 JavaBean 组件一起利用。
这个包常日不是由用户直策应用,而是由做事器将其用作其他多数功能的底层中介。
下一个最高级抽象是 BeanFactory 接口,它是工厂设计模式的实现,许可通过名称创建和检索工具。
BeanFactory 也可以管理工具之间的关系。

BeanFactory 支持两个工具模型。

□ 单态 模型供应了具有特定名称的工具的共享实例,可以在查询时对其进行检索。
Singleton 是默认的也是最常用的工具模型。
对付无状态做事工具很空想。

□ 原型 模型确保每次检索都会创建单独的工具。
在每个用户都须要自己的工具时,原型模型最适宜。

bean 工厂的观点是 Spring 作为 IOC 容器的根本。
IOC 将处理事情的任务从运用程序代码转移到框架。
正如我将不才一个示例中演示的那样,Spring 框架利用 JavaBean 属性和配置数据来指出必须设置的依赖关系。

BeanFactory 接口

由于 org.springframework.beans.factory.BeanFactory 是一个大略接口,以是可以针对各种底层存储方法实现。
最常用的 BeanFactory 定义是 XmlBeanFactory,它根据 XML 文件中的定义装入 bean,如清单 1 所示。

清单 1. XmlBeanFactory

?

BeanFactory factory = new XMLBeanFactory(new FileInputSteam(\"大众mybean.xml\公众));

在 XML 文件中定义的 Bean 是被悲观加载的,这意味在须要 bean 之前,bean 本身不会被初始化。
要从 BeanFactory 检索 bean,只需调用 getBean() 方法,传入将要检索的 bean 的名称即可,如清单 2 所示。

清单 2. getBean()

?

MyBean mybean = (MyBean) factory.getBean(\公众mybean\"大众);

每个 bean 的定义都可以是 POJO (用类名和 JavaBean 初始化属性定义) 或 FactoryBean。
FactoryBean 接口为利用 Spring 框架构建的运用程序添加了一个间接的级别。

IOC 示例

理解掌握反转最大略的办法便是看它的实际运用。
在对由三部分组成的 Spring 系列 的第 1 部分进行总结时,我利用了一个示例,演示了如何通过 Spring IOC 容器注入运用程序的依赖关系(而不是将它们构建进来)。

我用开启在线信用帐户的用例作为出发点。
对付该实现,开启信用帐户哀求用户与以下做事进行交互:

☆ 信用级别评定做事,查询用户的信用历史信息。

☆ 远程信息链接手事,插入客户信息,将客户信息与信用卡和银行信息连接起来,以进行自动借记(如果须要的话)。

☆ 电子邮件做事,向用户发送有关信用卡状态的电子邮件。

三个接口

对付这个示例,我假设做事已经存在,空想的情形是用疏松耦合的办法把它们集成在一起。
以下清单显示了三个做事的运用程序接口。

清单 3. CreditRatingInterface

?

public interface CreditRatingInterface {

public boolean getUserCreditHistoryInformation(ICustomer iCustomer);

}

清单 3 所示的信用级别评定接供词给了信用历史信息。
它须要一个包含客户信息的 Customer 工具。
该接口的实现是由 CreditRating 类供应的。

清单 4. CreditLinkingInterface

?

public interface CreditLinkingInterface {

public String getUrl();

public void setUrl(String url);

public void linkCreditBankAccount() throws Exception ;

}

信用链接接口将信用历史信息与银行信息(如果须要的话)连接在一起,并插入用户的信用卡信息。
信用链接接口是一个远程做事,它的查询是通过 getUrl() 方法进行的。
URL 由 Spring 框架的 bean 配置机制设置,我稍后会谈论它。
该接口的实现是由 CreditLinking 类供应的。

清单 5. EmailInterface

?

public interface EmailInterface {

public void sendEmail(ICustomer iCustomer);

public String getFromEmail();

public void setFromEmail(String fromEmail) ;

public String getPassword();

public void setPassword(String password) ;

public String getSmtpHost() ;

public void setSmtpHost(String smtpHost);

public String getUserId() ;

public void setUserId(String userId);

希望本文所述对大家Java程序设计有所帮助。