- 17
- 0
- 约9.68千字
- 约 8页
- 2016-10-17 发布于贵州
- 举报
实验 六 Stuts2和Hibernate整合基础
实验六 Struts2和Hibernate3整合应用
(注意本实验的字符集全部为UTF-8)
目的和要求
本实验是为了让学生对持久化技术有一个初步了解,并掌握在MyEclipse10集成环境下,建立一个持久化技术的简单的应用的方法。通过本实验
掌握在企业Java应用中Struts的作用;
熟悉在MyEclipse10环境中综合使用Hibernate和Struts的方法和步骤;
掌握Hibernate的核心思想;
掌握Struts和Hibernate整合的思想。
实验内容
创建数据库test,在数据库中创建一张表users,包括id,username和password,通过hibernate建立与表users对应的类Users。
在Struts框架创建的index.jsp表单中输入users信息,将此信息转换成一个对象,通过struts的action和hibernate的映射机制将对象持久化到数据库中。
实验原理简介
持久(Persistence)化,即把内存中的临时对象转换成可永久保存的数据(如存入数据库或文件中)。持久化的主要应用是将内存中的临时对象存储到关系数据库中。使用Hibernate实现数据持久化,就是要建立对象与数据库表中元组之间的映射关系,并通过save(o)将指定的对象存储到数据库中(内部转化成SQL 的insert into语句来完成)。具体实现是利用两个xml配置文件,在其中的一个hibernate.cfg.xml文件中给出了数据库连接的相关参数和映射文件,另一个文件*.hbm.xml(在此例中为users.hbm.xml)定义了对象(Users.class)中的属性与数据库表(Users)中元组字段之间的对应关系。这样当使用对象中的方法(在此例中对象的方法定义在Users.java中)对对象中的某些属性进行操作时,属性在数据库中对应的字段值也会发生相应的变化。
实验步骤
创建工程并使其具有Struts2能力
创建Web工程,名为TestS2H。
按实验三的实验步骤增添Struts2能力并创建相关的资源文件,包括:
增添Struts2能力;
创建属性文件perties—定义全局或局部属性;
创建消息资源文件messageResource_zh_CN.properties。
准备数据库和数据库连接驱动
在SQL Server 20XY中创建数据库test和表users。SQL脚本如下:
Use test
CREATE TABLE users (
id tinyint IDENTITY (1, 1) primary key ,
username varchar (20) NOT NULL ,
password varchar (20) NOT NULL
)
在MyEclipse的Database Explore透视图中创建数据库连接驱动。
添加Hibernate能力
切换到 MyEclipse Java Enterprise透视图,开始添加Hibernate能力。
在添加Hibernate能力的过程中,
选择最新Hibernate版本(在MyEclipse10中为Hibernate3.3)
选择“通过新建”来创建Hibernate配置文件;
使用JDBC驱动创建数据源(注意方言为SQL)来进行数据库连接;
指定创建会话工厂。
切换到Database Explore透视图进行反向工程
先要准备存放映射文件和持久化类的包:com. persist。
对ID Generater项选increment。
添加日志配置
在src/目录下添加文件:perties。
其具体配置如下:
log4j.rootLogger=INFO, CONSOLE
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d [%t] %-5p %c - %m%n
# Print only messages of level WARN or above in the package com.foo.
# .foo=WARN
#.sa.health.oacis=DEBUG
#.apache.struts2=DEBUG
#.apache=INFO
#.hibernate=INFO
#log4j.logger.ca.uhn=INFO
### log HQL query parser ac
原创力文档

文档评论(0)