struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

struts+hibernate这两个框架在一起使用,其实二者之间并没有什么联系。struts负责前端与后台代码的交互通讯,也就是view视图与control(控制器)之间的通讯。hibernate则负责dao层与数据库或javaBean之间的交互。所以说二者之间并没有直接的联系,就是负责的部分之间没有重叠的地方。

原理或整个流程就是:

1,前端jsp发送请求,首先web.xml拦截器拦截所有请求,遇到.action结尾的请求,会发送到struts.xml中,找到对应的name,进图到进入到相应的dao层处理(此之前都是struts负责的部分),

2,在dao层做业务逻辑处理,当在与数据库交互时,比如说增删改查,首先通过Configuration config = new Configutration().configure();

3,读取并解析hibernate.cfg.xml配置文件,由此文件中的<mapping resource=”包名.类名.hbm.xml”/>读取并解析映射文件。

4,再SessionFactory sf = config.buildSessionFactory();创建sessionFactory;然后Session session=sf.openSession();打开session,session即会话。

5,接着Transaction ts=session.beginTransaction();创建并启动事务transaction。persistence operate 操作数据,持久化操作,如session.save();

6,最后ts.commit()提价事务,关闭session和sessionFactory;(至此hibernate部分完成)。

7,操作完数据库后dao层返回数据,回到struts.xml,根据name 找到相应的result,返回给前端页面。

简单工程创建步骤(工程下载地址见文末):

说明:这里以一个简单的登陆页面为例,用struts+hibernate框架实现

1,ecllipse中右键–》new —>Dynamic Web Project创建动态工程,填写工程名,再统统下一步即可。(hibernate创建步骤跟创建servlet工程步骤一样,可参见小编的另一篇博文:http://blog.csdn.net/csdnliuxin123524/article/details/77915367)

struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

2,在WebContent/WEB-INF/lib目录下导入struts+hibernate所需要的jar包,具体jar包小编会再文章末尾上传此工程,工程中包含jar包。

struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

3,修改web.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 
	xmlns="http://java.sun.com/xml/ns/javaee" 
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <welcome-file-list>
    <welcome-file>login.jsp</welcome-file>
  </welcome-file-list>
  	<filter>								<!--定义核心Filter FilterDispatcher -->
		<filter-name>struts2</filter-name>	<!-- 定义核心Filter的名称 -->
		<filter-class>						<!--定义核心Filter的实现类 -->
			org.apache.struts2.dispatcher.FilterDispatcher
		</filter-class>
	</filter>
	<filter-mapping>
		<filter-name>struts2</filter-name><!--核心Filter的名称 -->
		<url-pattern>/*</url-pattern><!--使用该核心Filter过滤所有的Web请求 -->
	</filter-mapping>
</web-app>

4,hibernate连接数据配置:

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="dialect">
        	org.hibernate.dialect.MySQLDialect</property>		<!-- 数据库方言 -->
        <property name="connection.url">
        	jdbc:mysql://localhost:3306/db_examsystem</property><!-- 数据库连接URL -->
        <property name="connection.username">root</property>	<!-- 数据库用户名 -->
        <property name="connection.password">12345</property>	<!-- 数据库用户密码 -->
        <property name="connection.driver_class">				<!-- 数据库驱动类 -->
        	com.mysql.jdbc.Driver</property>
        <mapping resource="hibernate/po/Student.hbm.xml"/>
    </session-factory>
</hibernate-configuration>

5,struts配置

<?xml version="1.0" encoding="UTF-8" ?><!-- XML声明 -->
<!DOCTYPE struts PUBLIC
 "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
 "http://struts.apache.org/dtds/struts-2.1.dtd"><!-- 指定Struts 2配置文件的DTD信息 -->
<struts><!-- 根节点 -->
	<constant name="struts.i18n.encoding" value="gb2312"></constant>
	<package name="struts2r" extends="struts-default">
 		<action name="login" class="hibernate.action.LoginAction">
 			<result name="studentSuccess">/success.jsp</result><!--登录失败页面-->
 		</action>
 	</package>	
</struts>

6,实体类,dao层,dao实现层,控制器层,hibernate工厂等结构:


struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

7,两个页面,一个是登陆页面,一个是登陆成功后的页面

struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

8,工程部署好后,再本地启动,可出现以下界面,登陆角色学学生,账号是0509302*21  ,密码是manager

struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

登陆成功后,有:

struts+hibernate工作原理和简单工程创建步骤(附工程下载地址)

工程可在百度网盘下载:https://pan.baidu.com/s/1miSOFw8

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106307.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm修改环境_pycharm更改环境

    pycharm修改环境_pycharm更改环境因为有时需要在Terminal中调试代码,而且调试前需要配置环境变量,虽然操作不麻烦,但用起来总不习惯.特别是项目比较多时,需要频繁进到设置里面去改.以前设置环境变量的操作如下图:Settings-Tools-Terminal-ProjectSettings-Enviromentvariables添加环境变量比如我们有一个文件env.list里面的内容如下:IN_HOST=’192.168.0.6’#数据库主机IPIN_PORT=8888#数据库端口IN_US

    2022年8月27日
    4
  • 移动端开发之Web App开发

    移动端开发之Web App开发写在前面:本人刚刚接触移动端开发,希望自己的见解能够帮助到他人,不足之处还望提醒。1移动端开发分类1.1NativeApp原生App开发优点:(1)用户体验好(2)性能稳定(3)操作速度快(4)能够访问本地资源(通讯录,相册)(5)能够设计出色的动效,转场(6)拥有系统级别的贴心通知或提醒(7)用户留存率高缺点:(1)开发成本高(2)维护成本高(3)更新缓慢,根据不同平台,提交–审核–上线…

    2022年6月17日
    30
  • aria2最新tracker服务器,Aria2自动更新BT Tracker服务器列表的方法「建议收藏」

    aria2最新tracker服务器,Aria2自动更新BT Tracker服务器列表的方法「建议收藏」说明公开的BTtracker服务器,因为种种原因总会经常失效,要想获取更多的peer需要经常维护这份列表。感谢github上的小伙伴提供了这么一份tracker自动更新列表:https://github.com/ngosang/trackerslist。我们要想Aria2也支持自动更新这份列表,那么你可以按照下面方法来实现。关于Aria2安装使用教程可参考:https://www.moerats…

    2022年6月16日
    591
  • console.writeline的功能(writeline用法)

    输入cw,然后按两次tab效果图

    2022年4月16日
    58
  • 白话经典算法系列之七 堆与堆排序

    白话经典算法系列之七 堆与堆排序

    2021年11月23日
    46
  • 数据仓库常见建模方法与大数据领域建模实例综述

    数据仓库常见建模方法与大数据领域建模实例综述为什么需要数据建模?为什么要进行数据仓库建模?随着DT时代互联网、智能设备等信息技术的发展,数据开始井喷式的增长,如何讲这些数据进行有序、有结构地分类组织存储是我们面临的一个挑战。如果把数据看作图书馆里的书,我们希望看到它们在书架上分门别类地放置,而不是乱糟糟的大数据的数仓建模是通过建模的方法更好的组织、存储数据,以便在性能、成本、效率和数据质量之间找到最佳平衡点。一般主要从下面四点考虑…

    2022年5月4日
    58

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号