您的位置:首页 > 编程语言 > Java开发

Struts2整合Spring Hibernate的CRUD的实例

2009-07-07 20:33 525 查看
原帖及讨论:http://bbs.bccn.net/thread-239431-1-1.html

Struts 2 + Spring 2.0 + Hibernate 3.0整合的操作可以参照我的这篇文章 http://bbs.bccn.net/thread-239025-1-1.html
本文提供Struts2整合Spring Hibernate的CRUD的实例的源代码

1. 数据库脚本,数据库采用MySQL 5.0

CREATE TABLE `user` (
`id` int(11) NOT NULL auto_increment,
`username` varchar(32) NOT NULL,
`password` varchar(32) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2. 几个重要的文件

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">

<!-- spring的应用上下文 -->

<context-param>

<param-name>contextConfigLocation</param-name>

<param-value>/WEB-INF/applicationContext*.xml</param-value>

</context-param>

<!-- struts2 过滤器 -->

<filter>

<filter-name>struts2</filter-name>

<filter-class>

org.apache.struts2.dispatcher.FilterDispatcher

</filter-class>

</filter>

<filter-mapping>

<filter-name>struts2</filter-name>

<url-pattern>/*</url-pattern>

</filter-mapping>

<!-- spring的监听器,以便在启动时就自动加载spring的配置 -->

<listener>

<listener-class>

org.springframework.web.context.ContextLoaderListener

</listener-class>

</listener>

<!-- OpenSessionInViewFilter过滤器 -->

<filter>

<filter-name>lazyLoadingFilter</filter-name>

<filter-class>

org.springframework.orm.hibernate3.support.OpenSessionInViewFilter

</filter-class>

</filter>

<filter-mapping>

<filter-name>lazyLoadingFilter</filter-name>

<url-pattern>*.action</url-pattern>

</filter-mapping>

<welcome-file-list>

<welcome-file>/user/userAdd.jsp</welcome-file>

</welcome-file-list>

</web-app>

<?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">
<!-- spring的应用上下文 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext*.xml</param-value>
</context-param>
<!-- struts2 过滤器 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- spring的监听器,以便在启动时就自动加载spring的配置 -->
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
<!-- OpenSessionInViewFilter过滤器 -->
<filter>
<filter-name>lazyLoadingFilter</filter-name>
<filter-class>
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
</filter-class>
</filter>
<filter-mapping>
<filter-name>lazyLoadingFilter</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>/user/userAdd.jsp</welcome-file>
</welcome-file-list>
</web-app>


applicationContext.xml

Java代码



<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">

<bean id="dataSource"

class="org.apache.commons.dbcp.BasicDataSource">

<property name="driverClassName"

value="com.mysql.jdbc.Driver">

</property>

<property name="url"

value="jdbc:mysql://localhost:3306/catalog">

</property>

<property name="username" value="root"></property>

<property name="password" value="ethip"></property>

</bean>

<bean id="sessionFactory"

class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">

<property name="dataSource">

<ref bean="dataSource" />

</property>

<property name="hibernateProperties">

<props>

<prop key="hibernate.dialect">

org.hibernate.dialect.MySQLDialect

</prop>

</props>

</property>

<property name="mappingResources">

<list>

<value>org/ethip/catalog/model/User.hbm.xml</value>

</list>

</property>

</bean>

<bean id="UserDAO" class="org.ethip.catalog.dao.UserDAO">

<property name="sessionFactory">

<ref bean="sessionFactory" />

</property>

</bean>

<bean id="UserService"

class="org.ethip.catalog.service.UserService">

<property name="dao">

<ref bean="UserDAO" />

</property>

</bean>

<bean name="addUserBean" class="org.ethip.catalog.web.UserAction"

scope="prototype">

<property name="service">

<ref bean="UserService" />

</property>

</bean>

<bean name="listUserBean" class="org.ethip.catalog.web.UserAction"

scope="prototype">

<property name="service">

<ref bean="UserService" />

</property>

</bean>

<bean name="deleteUserBean" class="org.ethip.catalog.web.UserAction"

scope="prototype">

<property name="service">

<ref bean="UserService" />

</property>

</bean>

<bean name="editUserBean" class="org.ethip.catalog.web.UserAction"

scope="prototype">

<property name="service">

<ref bean="UserService" />

</property>

</bean>

<bean name="updateUserBean" class="org.ethip.catalog.web.UserAction"

scope="prototype">

<property name="service">

<ref bean="UserService" />

</property>

</bean>

</beans>

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">

<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName"
value="com.mysql.jdbc.Driver">
</property>
<property name="url"
value="jdbc:mysql://localhost:3306/catalog">
</property>
<property name="username" value="root"></property>
<property name="password" value="ethip"></property>
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>org/ethip/catalog/model/User.hbm.xml</value>
</list>
</property>
</bean>
<bean id="UserDAO" class="org.ethip.catalog.dao.UserDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<bean id="UserService"
class="org.ethip.catalog.service.UserService">
<property name="dao">
<ref bean="UserDAO" />
</property>
</bean>
<bean name="addUserBean" class="org.ethip.catalog.web.UserAction"
scope="prototype">
<property name="service">
<ref bean="UserService" />
</property>
</bean>
<bean name="listUserBean" class="org.ethip.catalog.web.UserAction"
scope="prototype">
<property name="service">
<ref bean="UserService" />
</property>
</bean>
<bean name="deleteUserBean" class="org.ethip.catalog.web.UserAction"
scope="prototype">
<property name="service">
<ref bean="UserService" />
</property>
</bean>
<bean name="editUserBean" class="org.ethip.catalog.web.UserAction"
scope="prototype">
<property name="service">
<ref bean="UserService" />
</property>
</bean>
<bean name="updateUserBean" class="org.ethip.catalog.web.UserAction"
scope="prototype">
<property name="service">
<ref bean="UserService" />
</property>
</bean>
</beans>


struts.xml

Java代码



<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

<include file="struts-default.xml" />

<!-- 此constant设置临时文件存放目录,因为默认的default.properties中没有指定 -->

<constant name="struts.multipart.saveDir" value="c:/"></constant>

<!-- 将action托管给spring -->

<constant name="struts.objectFactory" value="spring"></constant>

<package name="SSH2" extends="struts-default">

<action name="userAdd" class="addUserBean" method="userAdd">

<result name="success" type="redirect">userList.action</result>

</action>

<action name="userList" class="listUserBean" method="userList">

<result name="success">/user/userList.jsp</result>

</action>

<action name="userDelete" class="deleteUserBean"

method="userDelete">

<result name="success" type="redirect">userList.action</result>

</action>

<action name="userEdit" class="editUserBean"

method="userEdit">

<result name="success">/user/userEdit.jsp</result>

</action>

<action name="userUpdate" class="updateUserBean"

method="userUpdate">

<result name="success" type="redirect">userList.action</result>

</action>

</package>

</struts>

3. 本实例仅实现CRUD功能,没有实现其他的处理,如数据校验、国际化、分页等.

4. 由于附件过大,lib下所有的jar都删掉了,请各位学习者按照上一文的操作导入。

附件是ssh2目录结构

http://www.bccn.net/Article/UploadFDL05/200810/2008102122353132.rar

http://hxg1026.javaeye.com/blog/281340
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: