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)
上一篇 2021年7月18日 上午10:00
下一篇 2021年7月18日 上午11:00


相关推荐

  • 使用MySQL实现分页查询[通俗易懂]

    使用MySQL实现分页查询[通俗易懂]本文关键字:MySQL、分页查询、真分页、假分页、LIMIT。在项目开发当中,经常要实现分页功能,在面试时也会经常被问到:什么是分页。这是因为在一个页面上能够显示的数据是有限的,而存放在数据库中的数据往往很多,我们必须将这些数据安放到不同的页面中去。

    2022年6月29日
    25
  • iloc函数使用方法

    iloc函数使用方法iloc 前面的冒号就是取行数 后面的冒号是取列数找了一个例子做实践 importnumpya pyplotasplti pd read csv Position Salaries csv dataset head 5 X dataset iloc 1 2 values 第 2 列 1 level 左闭右开 y datase

    2026年3月26日
    2
  • Pytest(6)重复运行用例pytest-repeat「建议收藏」

    Pytest(6)重复运行用例pytest-repeat「建议收藏」前言平常在做功能测试的时候,经常会遇到某个模块不稳定,偶然会出现一些bug,对于这种问题我们会针对此用例反复执行多次,最终复现出问题来。自动化运行用例时候,也会出现偶然的bug,可以针对单个用例,

    2022年7月30日
    6
  • 关于java读取环境变量、虚拟机参数

    关于java读取环境变量、虚拟机参数关于 java 读取环境变量 虚拟机参数本文系统研究在 springboot 启动时传入参数 对于非 springboot 的普通 java 项目也是相同的 传参的参数类型程序参数 Programargum 虚拟机选项 VMoptions 环境变量 Environmentv 后续为了方便 有时会称呼为 程序参数 vm 参数 环境变量如何传参 如图 1 在 IDEA 等工具中是如何传的 如图 注意 环境变量的命名建议不要用 my env var 带点的格式 虽然在 i

    2026年3月19日
    1
  • was ejb学习[通俗易懂]

    was ejb学习[通俗易懂]最近因为项目需要,对ilog进行了学习,包括ilog在was的安装以及客户端连接ilog等内容。个人感觉很多是通过ejb来进行查找及调用的,所以,特意自己做了一个ejb在was上部署以及客户端连接的例子:[b][color=red]1、ejb方面[/color][/b]ejb采用ejb2,分三个类:Hello、HelloHome、HelloWord;[color…

    2026年4月18日
    5
  • VSCode接入Qwen3-coder实现cursor免费平替

    VSCode接入Qwen3-coder实现cursor免费平替

    2026年3月16日
    3

发表回复

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

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