struts2+spring+hibernate三大框架环境搭建小小总结(1300字)

来源:m.fanwen118.com时间:2021.8.3

struts2+spring+hibernate三大框架环境搭建小小总结:

一、环境搭建

导入各种jar包什么的就不多说了。

二、整个包结构及模式:

1、src文件下,由com.companyname组成一个大的包结构和各项配置文件组成

2、companyname下,分成两部分:

A、model层

B、功能层

3、model层下,包含整个项目所要的数据库表名,按照功能来命名包的名称,

A、功能包下包含对应的数据库表的java类,里面包含对应数据库表中所有的字段以及get,set方法

B、功能包下包含对应的数据库表的hbm.xml类,里面包含对应数据库表中所有字段的定义

4、功能层下,可以只有一个功能模块的一个结构,也可以有多个功能模块的包结构,再在包结构下细分到功能模块的结构

A、一个完整的功能模块包下包含:action,dao,service层,

1>、对应的action层包含对应功能实现的Action类;

2>、对应的dao层包含对应功能实现的数据库操作类;

3>、对应的service层包含对应功能实现的各service接口;

5、各项配置文件:

A、首先包含三个大的配置文件:applicationContext.xml,struts.xml,jdbc.properties

B、applicationContext.xml实现依赖注入,struts.xml实现各响应功能的配置,jdbc.properties配置数据库相关属性

三、页面

1、所有的页面,js包都放到WebRoot目录下,

2、要配置web.xml文件

3、所有的jar包放到WebRoot-WEB-INF-lib包下

四、功能操作

1、定义好model层,配置好对应的model.hbm.xml映射文件

2、将对应的model.hbm.xml映射文件映射到applicationContext.xml文件中

3、页面中对应的跳转,实现action,到struts-function.xml去增加对应的Action类和方法

4、将struts-function.xml映射文件映射到struts.xml映射文件中

5、在功能层下建立对应的功能包,包下包含action,dao,service三个层

6、根据struts-function.xml映射文件,建立对应的Action类,在类中创建对应的方法

7、在service层和dao层下分别建立对应的接口层和实现接口类

8、在对应的applicationContext-function.xml映射文件中将dao层方法映射到对应的service层中

9、service层中,包含iservice层和实现iservice层的service

10、在service类中实现对应的iservice定义的方法,并return这个dao对象的方法,

11、根据这个方法,在idao接口中创建对应的方法,在dao层的实现类中来具体实现方法的业务

12、dao层实现之后,将在Action中调用对应的dao层实现的方法,然后保存结果返回到对应的界面去

13、至此,简单的一个业务就实现了。里面还有很多的方法需要自己去制定成公共能够调用

的方法,方便以后自己调用。


第二篇:Struts,Spring,Hibernate面试题总结 3400字

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

原理:

1. 读取并解析配置文件

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

3. 打开Sesssion

4. 创建事务Transation

5. 持久化操作

6. 提交事务

7. 关闭Session

8. 关闭SesstionFactory

为什么要用:

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

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

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

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

2. Hibernate是如何延迟加载?

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

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

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

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

类与类之间的关系主要体现在表与表之间的关系进行操作,它们都是对对象进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one、one-to-many、many-to-many、

4. 说下Hibernate的缓存机制

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

2. 二级缓存:

a) 应用及缓存

b) 分布式缓存

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

c) 第三方缓存的实现

5. Hibernate的查询方式

Sql、Criteria,object comptosition

Hql:

1、 属性查询

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

3、 关联查询

4、 分页查询

5、 统计函数

6. 如何优化Hibernate?

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

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

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

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

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

6. 继承类使用显式多态

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

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

单例模式

Factory(工厂模式):

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

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

Proxy(代理模式)

10. 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 属性和配置文件加入依赖性(协作对象)。然后可以很容易地在需要时替换具有类似接口的协作对象。}

更多类似范文
┣ ERP总结 1400字
┣ ERP总结 3800字
┣ ERP总结 2800字
┣ erp总结 1700字
┣ 更多erp总结ppt
┗ 搜索类似范文