eclipse下struts+spring+hibernate快速入门

eclipse下struts+spring+hibernate快速入门

                                      

本文是开发基于springweb应用的入门文章,前端采用Struts MVC框架,中间层采用spring,后台采用Hibernate。在写作过程中参考了appfusespringlive项目

本文包含以下内容:

·配置Hibernate和事务

·装载SpringapplicationContext.xml文件

·建立业务层和DAO之间的依赖关系

·将Spring应用到Struts

概览

这个例子是建立一个简单的web应用,叫MyUsers,完成用户管理操作,包含简单的数据库增,删,查,该即CRUD(新建,访问,更新,删除)操作。这是一个三层的web应用,通过ActionStruts)访问业务层,业务层访问DAO。图一简要说明了该应用的总体结构。图上的数字说明了流程顺序-从webUserAction)到中间层(UserManager),再到数据访问层(UserDAO),然后将结果返回。

Spring层的真正强大在于它的声明型事务处理,帮定和对持久层支持(例如HiberateiBATIS

以下下是完成这个例子的步骤:

1. 安装Eclipse插件

2. 数据库建表

3. 配置HibernateSpring

4. 建立Hibernate DAO接口的实现类

5. 运行测试类,测试DAOCRUD操作

6. 创建一个处理类,声明事务

7. 创建Struts Action的测试类

8. 创建web层的Actionmodel

9. 运行Action的测试类测试CRUD操作

10. 创建jsp文件通过浏览器进行CRUD操作

11. 通过浏览器校验jsp

安装eclipse插件

1. Hibernate插件http://www.binamics.com/hibernatesync

2. Spring插件http://springframework.sourceforge.net/spring-ide/eclipse/updatesite/

3. MyEclipse插件(破解版)

4. Tomcat插件. tanghan

5. 其他插件包括xmljsp

数据库建表

Create table app_user ( id number(5) not null,primate key lastname vchar2(20),firstname vchar2(20));

新建项目

新建一个web project

新建后的目录结构如上图所示,同时包含了新建文件夹page用于放jsp文件,和源文件夹test用于放junit测试文件。同时将用到的包,包括strutshibernatespring都导入到lib目录下。

创建持久层O/R mapping

1. src/com.jandar.model下用hibernate插件从数据库导出app_user.hbm.xml文件改名为User.hbm.xml

<?xml version="1.0"?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD//EN"

"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd" >

<hibernate-mapping package="com.jandar.model">

<class name="User" table="APP_USER">

<id

column="ID"

name="id"

type="integer"

>

<generator class="assigned" />

</id>

<property

column="LASTNAME"

length="10"

name="lastname"

not-null="false"

type="string"

/>

<property

column="FIRSTNAME"

length="10"

name="firstname"

not-null="true"

type="string"

/>

</class>

</hibernate-mapping>

2. 通过hibernate synchronizer->synchronizer file生成User.java文件,User对象对应于数据库中的app_user

注:在eclipse下自动生成的对象文件不完全相同,相同的是每个对象文件必须实现Serializable接口,必需又toStringhashCode方法;

import java.io.Serializable;

import org.apache.commons.lang.builder.EqualsBuilder;

import org.apache.commons.lang.builder.HashCodeBuilder;

import org.apache.commons.lang.builder.ToStringBuilder;

import org.apache.commons.lang.builder.ToStringStyle;

public class BaseObject implements Serializable {

public String toString() {

return ToStringBuilder.reflectionToString(this,

ToStringStyle.MULTI_LINE_STYLE);

}

public boolean equals(Object o) {

return EqualsBuilder.reflectionEquals(this, o);

}

public int hashCode() {

return HashCodeBuilder.reflectionHashCode(this);

}

}

public class User extends BaseObject {

private Long id;

private String firstName;

private String lastName;

/**

* @return Returns the id.

*/

public Long getId() {

return id;

}

/**

* @param id The id to set.

*/

public void setId(Long id) {

this.id = id;

}

/**

* @return Returns the firstName.

*/

public String getFirstName() {

return firstName;

}

/**

* @param firstName The firstName to set.

*/

public void setFirstName(String firstName) {

this.firstName = firstName;

}

/**

* @return Returns the lastName.

*/

public String getLastName() {

return lastName;

}

/**

* @param lastName The lastName to set.

*/

public void setLastName(String lastName) {

this.lastName = lastName;

}

}

创建DAO,访问对象

1. src/com.jandar.service.dao新建IDAO.java接口,所有的DAO都继承该接口

package com.jandar.services.dao;

public interface IDAO {

}

2. src/com.jandar.service.dao下新建IUserDAO.java接口

public interface IUserDAO extends DAO {

List getUsers();

User getUser(Integer userid);

void saveUser(User user);

void removeUser(Integer id);

}

该接口提供了访问对象的方法,

3. src/com.jandar.service.dao.hibernate下新建UserDAOHiberante.java

import java.util.List;

import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

import org.springframework.orm.hibernate.support.HibernateDaoSupport;

import com.jandar.model.User;

import com.jandar.service.dao.IUserDAO;

public class UserDaoHibernate extends HibernateDaoSupport implements IUserDAO {

private Log log=LogFactory.getLog(UserDaoHibernate.class);

/* (非 Javadoc

* @see com.jandar.dao.IUserDAO#getUsers()

*/

public List getUsers() {

return getHibernateTemplate().find("from User");

}

/* (非 Javadoc

* @see com.jandar.dao.IUserDAO#getUser(java.lang.Long)

*/

public User getUser(Integer id) {

// TODO 自动生成方法存根

return (User) getHibernateTemplate().get(User.class,id);

}

/* (非 Javadoc

* @see com.jandar.dao.IUserDAO#saveUser(com.jandar.model.User)

*/

public void saveUser(User user) {

log.debug("xxxxxxx");

System.out.println("yyyy");

getHibernateTemplate().saveOrUpdate(user);

if(log.isDebugEnabled())

{

log.debug("userId set to "+user.getId());

}

}

/* (非 Javadoc

* @see com.jandar.dao.IUserDAO#removeUser(java.lang.Long)

*/

public void removeUser(Integer id) {

Object user=getHibernateTemplate().load(User.class,id);

getHibernateTemplate().delete(user);

if(log.isDebugEnabled()){

log.debug("del user "+id);

}

}

}

在这个类中实现了IUserDAO接口的方法,并且继承了HibernateDAOSupport类。这个类的作用是通过hibernate访问、操作对象,进而实现对数据库的操作。

创建业务层,声明事务

业务层主要处理业务逻辑,提供给web层友好的访问接口和实现访问DAO层。用业务层的另一个好处是,可以适应数据访问层从Hibernate技术转移到其他数据访问技术。

1. src/com.jandar.service下新建一个IUserManager接口,该接口有几乎于IUserDAO同样的方法,不同的是处理参数,应为IUserManager是供web层访问的。

public interface IUserManager {

User getUser(String userid);

List getUsers();

User saveUser(User user);

void removeUser(String userid);

}

2. src/com.jandar.service.spring下新建IuserManager实现类,UserManager.java

/*

* 创建日期 2005-3-4

*

* TODO 要更改此生成的文件的模板,请转至

* 窗口 首选项 Java 代码样式 代码模板

*/

package com.jandar.service.spring;

import java.util.List;

import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

import com.jandar.model.User;

import com.jandar.service.IUserManager;

import com.jandar.service.dao.IUserDAO;

/**

* @author Administrator

*

* TODO 要更改此生成的类型注释的模板,请转至

* 窗口 首选项 Java 代码样式 代码模板

*/

public class UserManagerImpl implements IUserManager {

/* (非 Javadoc

* @see com.jandar.service.IUserManager#getUser(java.lang.String)

*/

private static Log log=LogFactory.getLog(UserManagerImpl.class);

public IUserDAO userDao;

/**

* @return 返回 userDao

*/

public IUserDAO getUserDao() {

return userDao;

}

/**

* @param userDao 要设置的 userDao

*/

public void setUserDao(IUserDAO userDao) {

this.userDao = userDao;

}

public User getUser(String userid) {

User user=userDao.getUser(Integer.valueOf(userid));

if(user==null){

log.warn(" user id "+userid+" not found in database");

}

if(log.isDebugEnabled()){

log.debug("get a user with id "+userid);

}

return user;

}

/* (非 Javadoc

* @see com.jandar.service.IUserManager#getUsers()

*/

public List getUsers() {

// TODO 自动生成方法存根

return userDao.getUsers();

}

/* (非 Javadoc

* @see com.jandar.service.IUserManager#saveUser(com.jandar.model.User)

*/

public User saveUser(User user) {

// TODO 自动生成方法存根

userDao.saveUser(user);

return user;

}

/* (非 Javadoc

* @see com.jandar.service.IUserManager#removeUser(java.lang.String)

*/

public void removeUser(String userid) {

// TODO 自动生成方法存根

userDao.removeUser(Integer.valueOf(userid));

}

}

UserManager.java通过访问dao接口实现业务逻辑和数据库操作。同时该类中提供了set方法,运用了Spring的依赖注入机制。但尚未使用springAOP和声明事务。

配置applicationContext.xml

WEB-INF 下新建applicationContext.xml

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

<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"

"http://www.springframework.org/dtd/spring-beans.dtd">

<beans>

<bean id="dataSource"

class="org.springframework.jdbc.datasource.DriverManagerDataSource">

<property name="driverClassName"><value>org.hsqldb.jdbcDriver</value></property>

<property name="url"><value>jdbc:hsqldb:db/appfuse</value></property>

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

<!-- Make sure <value> tags are on same line - if they''re not,

authentication will fail -->

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

</bean>

<!-- Hibernate SessionFactory -->

<bean id="sessionFactory"

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

<property name="dataSource"><ref local="dataSource"/></property>

<property name="mappingResources">

<list>

<value>com/jandar/model/User.hbm.xml</value>

</list>

</property>

<property name="hibernateProperties">

<props>

<prop key="hibernate.dialect">net.sf.hibernate.dialect.HSQLDialect</prop>

<prop key="hibernate.hbm2ddl.auto">create</prop>

</props>

</property>

</bean>

<!-- Transaction manager for a single Hibernate SessionFactory (alternative to JTA) -->

<bean id="transactionManager" class="org.springframework.orm.hibernate.HibernateTransactionManager">

<property name="sessionFactory"><ref local="sessionFactory"/></property>

</bean>

<bean id="userDAO" class="com.jandar.dao.hibernate.UserDAOHibernate">

<property name="sessionFactory"><ref local="sessionFactory"/></property>

</bean>

<bean id="userManagerTarget" class="com.jandar.service.spring.UserManager">

<property name="userDAO"><ref local="userDAO"/></property>

</bean>

<bean id="userManager"

class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">

<property name="transactionManager"><ref local="transactionManager"/></property>

<property name="target"><ref local="userManagerTarget"/></property>

<property name="transactionAttributes">

<props>

<prop key="save*">PROPAGATION_REQUIRED</prop>

<prop key="remove*">PROPAGATION_REQUIRED</prop>

<prop key="*">PROPAGATION_REQUIRED,readOnly</prop>

</props>

</property>

</bean>

</beans>

创建Web

1. 创建Struts Action,为了在一个action中实现CRUD操作,Action继承了DispatchAction根据参数决定调用方法。在src/com.jandar.web.struts.action下创建UserAction.java

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

import org.apache.struts.action.ActionForm;

import org.apache.struts.action.ActionForward;

import org.apache.struts.action.ActionMapping;

import org.apache.struts.action.ActionMessage;

import org.apache.struts.action.ActionMessages;

import org.apache.struts.action.DynaActionForm;

import org.apache.struts.actions.DispatchAction;

import org.appfuse.model.User;

import org.appfuse.service.UserManager;

public class UserAction extends DispatchAction {

private static Log log = LogFactory.getLog(UserAction.class);

private UserManager mgr = null;

public void setUserManager(UserManager userManager) {

this.mgr = userManager;

}

public ActionForward delete(ActionMapping mapping, ActionForm form,

HttpServletRequest request,

HttpServletResponse response)

throws Exception {

if (log.isDebugEnabled()) {

log.debug("entering ''delete'' method...");

}

mgr.removeUser(request.getParameter("user.id"));

ActionMessages messages = new ActionMessages();

messages.add(ActionMessages.GLOBAL_MESSAGE,

new ActionMessage("user.deleted"));

saveMessages(request, messages);

return list(mapping, form, request, response);

}

public ActionForward edit(ActionMapping mapping, ActionForm form,

HttpServletRequest request,

HttpServletResponse response)

throws Exception {

if (log.isDebugEnabled()) {

log.debug("entering ''edit'' method...");

}

DynaActionForm userForm = (DynaActionForm) form;

String userId = request.getParameter("id");

// null userId indicates an add

if (userId != null) {

User user = mgr.getUser(userId);

if (user == null) {

ActionMessages errors = new ActionMessages();

errors.add(ActionMessages.GLOBAL_MESSAGE,

new ActionMessage("user.missing"));

saveErrors(request, errors);

return mapping.findForward("list");

}

userForm.set("user", user);

}

return mapping.findForward("edit");

}

public ActionForward list(ActionMapping mapping, ActionForm form,

HttpServletRequest request,

HttpServletResponse response)

throws Exception {

if (log.isDebugEnabled()) {

log.debug("entering ''list'' method...");

}

request.setAttribute("users", mgr.getUsers());

return mapping.findForward("list");

}

public ActionForward save(ActionMapping mapping, ActionForm form,

HttpServletRequest request,

HttpServletResponse response)

throws Exception {

if (log.isDebugEnabled()) {

log.debug("entering ''save'' method...");

}

// run validation rules on this form

ActionMessages errors = form.validate(mapping, request);

if (!errors.isEmpty()) {

saveErrors(request, errors);

return mapping.findForward("edit");

}

DynaActionForm userForm = (DynaActionForm) form;

mgr.saveUser((User)userForm.get("user"));

ActionMessages messages = new ActionMessages();

messages.add(ActionMessages.GLOBAL_MESSAGE,

new ActionMessage("user.saved"));

saveMessages(request, messages);

return list(mapping, form, request, response);

}

public ActionForward unspecified(ActionMapping mapping, ActionForm form,

HttpServletRequest request,

HttpServletResponse response)

throws Exception {

return list(mapping, form, request, response);

}

}

UserAction.java通过IuserManger访问业务层,IuserManager通过依赖注入

2. 创建struts ActionFrom

可以在src/com.jandar.web.struts.form下创建一个UserForm.javastruts ActionForm,我们也可以采用已建好的模型来配置form bean即采用动态form

org.apache.struts.validator.DynaValidatorForm 同时指定property

com.jandar.fuse.model.User详见struts-config.xml配置文件.

3. 配置struts-config.xml

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

<!DOCTYPE struts-config PUBLIC

"-//Apache Software Foundation//DTD Struts Configuration 1.2//EN"

"http://jakarta.apache.org/struts/dtds/struts-config_1_2.dtd">

<struts-config>

<!-- ======================================== Form Bean Definitions -->

<form-beans>

<form-bean

name="userForm" type="org.apache.struts.validator.DynaValidatorForm">

<form-property name="user" type="com.jandar.model.User"/>

</form-bean>

</form-beans>

<!-- =================================== Global Forward Definitions -->

<global-forwards>

</global-forwards>

<!-- =================================== Action Mapping Definitions -->

<action-mappings>

<action path="/user" type="com.jandar.web.struts.action.UserAction "

name="userForm" scope="request" parameter="method" validate="false">

<forward name="list" path="/userList.jsp"/>

<forward name="edit" path="/userForm.jsp"/>

</action>

</action-mappings>

<!-- ================================ Message Resources Definitions -->

<message-resources parameter="messages"/>

</struts-config>

4. 通过struts-config.xmlstrutsspring结合起来

UserAction.java中的UserManager需要通过依赖注入,通过plug-in技术将spring加到

 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于eclipse、s2sh和extjs源码的下载,我们可以采取以下步骤: 1. 首先,我们需要使用搜索引擎,如Google或百度,在相关的官方网站或开源社区中搜索Eclipse、S2SH和ExtJS的源码下载链接。 2. 对于Eclipse的源码,我们可以访问Eclipse官方网站(https://www.eclipse.org/downloads/)下载Eclipse IDE的安装包,然后在安装包中找到源码文件。 3. 关于S2SH(Struts2+Spring+Hibernate)的源码,我们可以在Struts2、SpringHibernate的官方网站上找到相应的源码下载链接。我们可以访问它们的官方网站,如Struts2(https://struts.apache.org/download.cgi)、Spring(https://spring.io/projects/spring-framework)和Hibernate(https://hibernate.org/orm/downloads/)。 4. 对于ExtJS的源码,我们可以访问Sencha公司(原ExtJS开发公司)的官方网站(https://www.sencha.com/products/extjs/#overview)下载相应的版本。在官方网站上,我们可以找到下载源码的链接或通过付费订阅来获取它们。 需要注意的是,这些框架的源码通常是以压缩包的形式提供的,我们需要下载后解压缩才能查看源码。此外,对于如此流行的框架,也可以在许多开源社区中找到相应的源码下载链接,如GitHub、CodePlex、Bitbucket等。在这些社区搜索相应的框架名称,通常可以找到相应的源码仓库。 总的来说,下载Eclipse、S2SH和ExtJS的源码需要访问官方网站或开源社区,并根据相关的下载链接或搜索结果来获取源码文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值