整合的准备工作
第一步、导入jar包
antlr-2.7.7.jar
asm-3.3.jar
asm-commons-3.3.jar
asm-tree-3.3.jar
com.springsource.net.sf.cglib-2.2.0.jar
com.springsource.org.aopalliance-1.0.0.jar
com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar
commons-dbcp-1.2.jar
commons-fileupload-1.3.2.jar
commons-io-2.2.jar
commons-lang3-3.2.jar
commons-logging-1.1.1.jar
commons-pool-1.6.jar
dom4j-1.6.1.jar
freemarker-2.3.28.jar
geronimo-jta_1.1_spec-1.1.1.jar
hibernate-commons-annotations-4.0.2.Final.jar
hibernate-core-4.2.4.Final.jar
hibernate-jpa-2.0-api-1.0.1.Final.jar
jandex-2.0.0.Final.jar
javassist-3.15.0-GA.jar
jboss-logging-3.1.0.GA.jar
jboss-transaction-api_1.1_spec-1.0.1.Final.jar
log4j-1.2.16.jar
log4j-api-2.3.jar
log4j-core-2.3.jar
mchange-commons-java-0.2.3.4.jar
mysql-connector-java-5.1.7-bin.jar
ognl-3.0.21.jar
slf4j-api-1.6.1.jar
slf4j-log4j12-1.7.2.jar
spring-aop-4.0.0.RELEASE.jar
spring-aspects-4.0.0.RELEASE.jar
spring-beans-4.0.0.RELEASE.jar
spring-context-4.0.0.RELEASE.jar
spring-core-4.0.0.RELEASE.jar
spring-expression-4.0.0.RELEASE.jar
spring-jdbc-4.0.0.RELEASE.jar
spring-orm-4.0.0.RELEASE.jar
spring-tx-4.0.0.RELEASE.jar
spring-web-4.0.0.RELEASE.jar
spring-webmvc-4.0.0.RELEASE.jar
struts2-core-2.3.36.jar
struts2-spring-plugin-2.3.15.3.jar
xwork-core-2.3.36.jar
第二步、web.xml里面配置struts2拦截器和配置Spring的ioc容器
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0"
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_3_0.xsd">
<display-name></display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<!-- 把Spring资源文件配置 -->
<!-- 配置监听器 -->
<context-param>
<!-- 上下文配置路径 -->
<param-name>contextConfigLocation</param-name>
<!-- 访问spring配置信息 -->
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!-- 配置spring启动listener入口 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>GoodsServlet</servlet-name>
<servlet-class>cn.com.servlet.GoodsServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>GoodsServlet</servlet-name>
<url-pattern>/GoodsServlet</url-pattern>
</servlet-mapping>
<!--拦截器设置 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
第三步、db.properties
jdbc.username=root
jdbc.password=123456
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\:///lifan
第四步、applicationContext.xml文件(HIbernate.cfg.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"
xmlns:util="http://www.springframework.org/schema/util"
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-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
<context:component-scan base-package="cn.com" ></context:component-scan>
<!-- 指定数据库配置文件的位置 -->
<context:property-placeholder location="classpath:db.properties" />
<bean class="org.apache.commons.dbcp.BasicDataSource" id="dataSource">
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
<property name="driverClassName" value="${jdbc.driverClassName}"></property>
<property name="url" value="${jdbc.url}"></property>
</bean>
<!-- Spring配置sessisonFactory工厂 -->
<!--Spring整合Hibernate -->
<bean id="SessionFactoryBean"
class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
</props>
</property>
<!-- 添加映射文件 -->
<property name="mappingLocations">
<list>
<value>classpath:cn/com/bean/Goods.hbm.xml</value>
</list>
</property>
</bean>
<!-- 配置事务管理器 -->
<bean id="hibernateTransactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="SessionFactoryBean"></property>
</bean>
<!-- 配置事务的属性 -->
<tx:advice transaction-manager="hibernateTransactionManager" id="txadvice">
<tx:attributes>
<tx:method name="*"/>
</tx:attributes>
</tx:advice>
<!--切面和事务的属性关联起来 -->
<aop:config>
<aop:pointcut expression="execution(* cn.com.dao.*.*(..))" id="txpointcut"/>
<aop:advisor pointcut-ref="txpointcut" advice-ref="txadvice"/>
</aop:config>
</beans>
查询数据库里面的数据显示在页面上
实体类
package cn.com.bean;
public class Goods {
//这里是产品的信息
private int goodnum;
private String goodaddress;
private String goodname;
private double price;
private int account;
public int getGoodnum() {
return goodnum;
}
public void setGoodnum(int goodnum) {
this.goodnum = goodnum;
}
public String getGoodaddress() {
return goodaddress;
}
public void setGoodaddress(String goodaddress) {
this.goodaddress = goodaddress;
}
public String getGoodname() {
return goodname;
}
public void setGoodname(String goodname) {
this.goodname = goodname;
}
public double getPrice() {
return price;
}
public void setPrice(double price) {
this.price = price;
}
public int getAccount() {
return account;
}
public void setAccount(int account) {
this.account = account;
}
}
映射文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" >
<hibernate-mapping>
<class name="cn.com.bean.Goods" table="goods" catalog="lifan">
<id column="goodnum" name="goodnum">
<generator class="native"></generator>
</id>
<property name="goodaddress" column="goodaddress" type="string"></property>
<property name="goodname" column="goodname" type="string"></property>
<property name="price" column="price" type="double"></property>
<property name="account" column="account" type="int"></property>
</class>
</hibernate-mapping>
查询信息的接口和实现类(HIbernate操作数据库+Spring注解和事务、AOP)
package cn.com.inter;
import java.util.List;
import cn.com.bean.Goods;
public interface GoodsService {
//1.查询Goods的所有信息
public List<Goods> getGoodsList();
}
package cn.com.dao;
import java.util.List;
import java.util.Map;
import org.apache.struts2.interceptor.RequestAware;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import com.opensymphony.xwork2.ModelDriven;
import com.opensymphony.xwork2.Preparable;
import cn.com.bean.Goods;
import cn.com.inter.GoodsService;
@Repository(value="goodsServiced")
public class GoodsServiceImpl implements GoodsService,RequestAware{
// 1.使用Hibernate操作数据库
// 1.1使用当前线程绑定的session
@Autowired
private SessionFactory sessionfactory;
private Session getSession() {
return sessionfactory.getCurrentSession();
}
// 测试没有问题
@Transactional
public List<Goods> getGoodsList() {
System.out.println("common in....");
// 1.连接数据库
String sql = "from Goods";
Query query = getSession().createQuery(sql);
List<Goods> lists = query.list();
return lists;
}
@Override
public void setRequest(Map<String, Object> arg0) {
}
}
Servlet
package cn.com.servlet;
import java.io.IOException;
import java.util.List;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;
import com.opensymphony.xwork2.ModelDriven;
import com.opensymphony.xwork2.Preparable;
import cn.com.bean.Goods;
import cn.com.inter.GoodsService;
public class GoodsServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// 1.获取上下文
ServletContext sc = getServletContext();
WebApplicationContext ac = WebApplicationContextUtils
.getRequiredWebApplicationContext(sc);
GoodsService gh = (GoodsService) ac.getBean("goodsServiced");
// 调用方法
System.out.println("gh"+gh);
List<Goods> lists=gh.getGoodsList();
request.setAttribute("list", lists);
request.getRequestDispatcher("/goodslist.jsp").forward(request, response);
}
}
显示页面(s标签)
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>铜陵力凡自动化-产品列表</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
</head>
<body>
<!-- 头部 -->
<jsp:include page="headcommon.jsp"></jsp:include>
<table>
<tr><td>产品</td><td>说明</td><td>价格</td><td>销量</td></tr>
<s:iterator value="#request.list">
<tr><td><img src=${goodaddress } /></td>
<td>${goodname}</td>
<td>${price}</td>
<td>${account}</td>
</tr>
</s:iterator>
</table>
</body>
</html>
这里对Struts只是用到了在页面上显示s标签;后面更多的灵活使用