Strust2+Spring+Hibernate(S2SH)框架搭建

2024-06-16 09:32

本文主要是介绍Strust2+Spring+Hibernate(S2SH)框架搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SSH2框架的版本为:struts-2.2.3 + spring-2.5.6 + hibernate-3.6.8

1、jar包

struts2:
struts2-core-2.2.3.jar
struts2-spring-plugin-2.2.3.jar
xwork-core-2.2.3.jar
commons-io-2.0.1.jar
commons-lang-2.5.jar
commons-fileupload-1.2.2.jar
freemarker-2.3.16.jar
ognl-3.0.1.jar
javassist-3.12.0.GA.jar(hibernate同样需要)
spring:
spring.jar
commons-logging-1.1.1.jar
common-annotations.jar
aspectjrt.jar
aspectjweaver.jar
cglib-nodep-2.1_3.jar
(如果用BasicDataSource来配置数据库连接,还要加入以下2个包)
commons-dbcp.jar
commons-pool.jar
hibernate:
hibernate3.jar
hibernate-jpa-2.0-api-1.0.1.Final.jar
antlr-2.7.6.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
javassist-3.12.0.GA.jar
jta-1.1.jar
slf4j-api-1.6.1.jar
slf4j-nop-1.6.4.jar(这个jar包要去slf4j官网下载slf4j-1.6.4集成包)
jdbc:
ojdbc14.jar(oracle)

2、web.xml配置
<?xml version="1.0" encoding="UTF-8"?>  
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">  <display-name>testSSH</display-name>  <welcome-file-list>  <welcome-file>index.jsp</welcome-file>  </welcome-file-list>  <!-- 配置资源 -->  <context-param>  <param-name>contextConfigLocation</param-name>  <param-value>classpath:config/applicationContext.xml</param-value>  </context-param>  <!-- 配置自定义filter,并由spring管理 -->  <!--   <filter>  <filter-name>myFilter</filter-name>  <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>  <init-param>  <param-name>targetFilterLifecycle</param-name>  <param-value>true</param-value>  </init-param>  <init-param>  <param-name>encoding</param-name>  <param-value>UTF-8</param-value>  </init-param>  </filter>  <filter-mapping>  <filter-name>myFilter</filter-name>  <url-pattern>/*</url-pattern>  </filter-mapping>  -->  <!-- 配置CharacterEncoding,设置字符集 -->  <filter>  <filter-name>characterEncodingFilter</filter-name>  <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  <init-param>  <param-name>encoding</param-name>  <param-value>UTF-8</param-value>  </init-param>  <init-param>  <param-name>forceEncoding</param-name>  <param-value>true</param-value>  </init-param>  </filter>  <filter-mapping>  <filter-name>characterEncodingFilter</filter-name>  <url-pattern>/*</url-pattern>  </filter-mapping>  <!-- 将HibernateSession开关控制配置在Filter,保证一个请求一个session,并对lazy提供支持 -->  <filter>  <filter-name>hibernateFilter</filter-name>  <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>  <init-param>  <param-name>singleSession</param-name>  <param-value>true</param-value>  </init-param>  </filter>  <filter-mapping>  <filter-name>hibernateFilter</filter-name>  <url-pattern>*.do</url-pattern>  </filter-mapping>  <!-- 配置struts2 -->  <filter>  <filter-name>struts2</filter-name>  <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>  <init-param>  <param-name>config</param-name>  <param-value>struts-default.xml,struts-plugin.xml,/config/struts.xml</param-value>  </init-param>  </filter>  <filter-mapping>  <filter-name>struts2</filter-name>  <url-pattern>/*</url-pattern>  </filter-mapping>  <!-- 配置spring -->  <listener>  <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  </listener>  <!-- 页面session配置 -->  <session-config>  <session-timeout>20</session-timeout>  </session-config>  <!-- 错误页面 -->  <error-page>  <error-code>404</error-code>  <location>/error404.html</location>  </error-page>  
</web-app>  

注意

  • 配置自定义filter即DelegatingFilterProxy时,参数targetFilterLifecycle设为true是将filter放入web容器中成为真正意义上的filter。否则只是个代理filter,不具有filter的生命周期,因此无法执行filter的init、destroy方法。因为统一交由spring管理,所以在spring资源配置文件(如applicationContext.xml)中必须相应的并且名称为myFilter的bean。
  • OpenSessionInViewFilter要将参数singleSession设置为true,否则意义不大。
  • 配置struts2建议采用StrutsPrepareAndExecuteFilter。struts.xml默认放在src根目录下,若想放置到其他地方还要将struts-default.xml和struts-plugin.xml一同配置下,否则在于其他框架结合时(如spring)就会报错。配置struts2的filter标签要放到所有filter标签的最下面,否则会有问题。
3、struts.xml配置
<!DOCTYPE struts PUBLIC  "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  "http://struts.apache.org/dtds/struts-2.0.dtd">  
<struts>  <!-- 将Action的创建交给spring来管理 -->  <constant name="struts.objectFactory" value="spring" />  <!-- 更改struts2请求Action的后缀名,默认为action。若想去掉后缀,设为","即可 -->  <constant name="struts.action.extension" value="do"></constant>  <package name="struts" namespace="/" extends="struts-default">  <!-- 配置拦截器 -->  <interceptors>  <interceptor name="myInterceptor" class="myInterceptor"></interceptor>  <interceptor-stack name="myDefult">  <interceptor-ref name="myInterceptor"></interceptor-ref>  <interceptor-ref name="defaultStack"></interceptor-ref>  </interceptor-stack>  </interceptors>  <action name="myLogin" class="loginAction">  <result name="success">/success.jsp</result>  <result name="error" type="redirect">/index.jsp</result>  </action>  <action name="testSession" class="sessionAction">  <interceptor-ref name="myDefult"></interceptor-ref>  <result name="success">/success.jsp</result>  <result name="error" type="redirect">/login.jsp</result>  </action>  </package>  
</struts>  

注意

  • 执行完自定义拦截器后,还要执行struts2默认的拦截器defaultStack,否则可能会出错。
  • action标签的class属性,与spring结合后要写成spring中bean的名称name。
4、applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>  
<beans xmlns="http://www.springframework.org/schema/beans"  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xmlns:aop="http://www.springframework.org/schema/aop"  xmlns:context="http://www.springframework.org/schema/context"  xmlns:tx="http://www.springframework.org/schema/tx"  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd  http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd  http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">  <!-- 启用spring注解支持 -->  <context:annotation-config/>  <!-- 第一种方法配置sessionFactory -->  <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  <property name="configLocation" value="classpath:config/hibernate.cfg.xml"></property>  </bean>  <!-- 第二种方法配置sessionFactory  <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>  <property name="url" value="jdbc:oracle:thin:@localhost:1521:wang"/>  <property name="username" value="wang"/>  <property name="password" value="wang"/>  </bean>  <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  <property name="dataSource" ref="dataSource"/>  <property name="hibernateProperties">  <props>  <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>  <prop key="hibernate.show_sql">true</prop>  </props>  </property>  <property name="mappingLocations">  <list>  <value>classpath:test/entity/User.hbm.xml</value>  </list>  </property>  </bean>  -->  <!-- 第一种方法配置事务 -->  <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">  <property name="sessionFactory" ref="sessionFactory"/>  </bean>  <tx:advice id="txadvice" transaction-manager="transactionManager">  <tx:attributes>  <tx:method name="add*" propagation="REQUIRED" rollback-for="Exception"/>  <tx:method name="del*" propagation="REQUIRED" no-rollback-for="MyException"/>  <tx:method name="update*" propagation="REQUIRED"/>  <tx:method name="*" propagation="REQUIRED" read-only="true"/>  </tx:attributes>  </tx:advice>   <aop:config>  <aop:pointcut id="daoMethods" expression="execution(* test.dao.*.*(..))"/>  <aop:advisor advice-ref="txadvice" pointcut-ref="daoMethods"/>  </aop:config>  <!-- 第二种方法配置事务  <bean id="transactionProxy" class= "org.springframework.transaction.interceptor.TransactionProxyFactoryBean" abstract="true">  必须为true时CGLIB才不用强制编写DAO接口  <property name="proxyTargetClass" value="true" />  <property name="transactionManager" ref="transactionManager" />  <property name="transactionAttributes">  <props>  <prop key="add*">PROPAGATION_REQUIRED, -Exception</prop>  <prop key="del*">PROPAGATION_REQUIRED, +MyException</prop>  <prop key="update">PROPAGATION_REQUIRED</prop>  <prop key="*">PROPAGATION_REQUIRED, readOnly</prop>  </props>  </property>  </bean>  <bean id="userService" parent="transactionProxy">  <property name="target" ref="iUserService"></property>  </bean>  <bean id="iUserService" class="test.service.UserServiceImpl"></bean>  -->  <bean id="userService" class="test.service.UserServiceImpl"></bean>  <bean id="userDao" class="test.dao.UserDaoImpl">  <property name="sessionFactory" ref="sessionFactory" />  </bean>  <!-- spring管理的自定义filter -->  <bean id="myFilter" class="test.service.MyFilter"></bean>  <!-- spring管理struts2的Action -->  <bean id="loginAction" class="test.action.LoginAction" scope="prototype"></bean>  <bean id="sessionAction" class="test.action.SessionAction" scope="prototype"></bean>  <bean id="myInterceptor" class="test.service.MyInterceptor" scope="prototype"></bean>  
</beans>  

注意

  • 配置事务时,如果事务是与含有sessionFactory的DAO层关联的话,要将标签的proxy-target-class属性设为true(第二种方法是proxyTargetClass属性),否则就会报错
  • 采用Resource或Autowired注解时,bean中无需配置property属性标签。
  • 采用第二种方法配置sessionFactory时,还需要另外引入两个包(详见上述“所需jar”部分)。
5、filter与拦截器

过滤器(MyFilter)

package test.service;  import java.io.IOException;  import javax.servlet.Filter;  
import javax.servlet.FilterChain;  
import javax.servlet.FilterConfig;  
import javax.servlet.ServletException;  
import javax.servlet.ServletRequest;  
import javax.servlet.ServletResponse;  public class MyFilter implements Filter {  private String encoding;  @Override  public void destroy() {  }  @Override  public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {  request.setCharacterEncoding(encoding);  response.setCharacterEncoding(encoding);  chain.doFilter(request, response);  }  @Override  public void init(FilterConfig config) throws ServletException {  System.out.println("========" + config.getInitParameter("encoding") + "========");  encoding = config.getInitParameter("encoding");  }  
}  

拦截器(MyInterceptor)

package test.service;  import java.util.Map;  import com.opensymphony.xwork2.ActionInvocation;  
import com.opensymphony.xwork2.interceptor.Interceptor;  @SuppressWarnings("serial")  
public class MyInterceptor implements Interceptor{  @Override  public void destroy() {  }  @Override  public void init() {  }  @Override  public String intercept(ActionInvocation invocation) throws Exception {  Map sessionMap = invocation.getInvocationContext().getSession();  String username = (String)sessionMap.get("username");  if (username != null) {  return invocation.invoke();  }  return "error";  }  }  

filter与拦截器(interceptor)的区别:
二者不论从结构还是功能都非常相似,但是二者是有区别的,:
① filter是基于servlet容器的,而interceptor仅限于struts2,因此filter的作用域要远大于interceptor。
② filter中doFilter方法是基于回调函数,而interceptor中intercept方法则是基于java反射。
③ filter的功能要远大于interceptor,filter除了过滤请求外通过通配符可以保护页面,图片,文件,还可以进行加密、安全过滤、权限管理等等,而Interceptor基本只能过滤请求。
④ filter拦截请求的粒度较粗,interceptor拦截请求的粒度较细。

6、action层
package test.action;  import javax.annotation.Resource;  
import javax.servlet.http.HttpServletRequest;  import org.apache.struts2.ServletActionContext;  import test.entity.User;  
import test.service.IUserService;  import com.opensymphony.xwork2.ActionSupport;  @SuppressWarnings("serial")  
public class LoginAction extends ActionSupport {  @Resource  private IUserService userService;  private String username;  private String password;  public String getUsername() {  return username;  }  public void setUsername(String username) {  this.username = username;  }  public String getPassword() {  return password;  }  public void setPassword(String password) {  this.password = password;  }  @Override  public String execute() throws Exception {  User user = new User();  user.setUsername(username);  user.setPassword(password);  try {  userService.addUser(user);  HttpServletRequest request = ServletActionContext.getRequest();  request.getSession().setAttribute("username", username);  return "success";  } catch (Exception e) {  e.printStackTrace();  }  return "error";  }  
}  
7、service层
package test.service;  import java.util.List;  import javax.annotation.Resource;  import test.dao.IUserDao;  
import test.entity.User;  public class UserServiceImpl implements IUserService{  @Resource  private IUserDao userDao;  @Override  public void addUser(User user) throws Exception {  userDao.addUser(user);  if (!"admin".equals(user.getUsername()) || !"admin".equals(user.getPassword())) {  throw new Exception();  }  }  @Override  public boolean updateUser(User user) {  return false;  }  @Override  public boolean delUser(String username) {  return false;  }  @Override  public List<User> findAllUser() {  return null;  }  
} 
8、dao层
package test.dao;  import java.util.Date;  import org.springframework.orm.hibernate3.support.HibernateDaoSupport;  import test.entity.User;  public class UserDaoImpl extends HibernateDaoSupport implements IUserDao{  @Override  public void addUser(User user){  user.setName("wang");  user.setCreateTime(new Date());  user.setModifyTime(new Date());  this.getHibernateTemplate().save(user);  }  
}  

这篇关于Strust2+Spring+Hibernate(S2SH)框架搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1066085

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3