SSH框架整合实例

项目结构:

这里写图片描述

添加依赖:pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>gdou.laiminghai</groupId>
    <artifactId>pre-worker-ssh</artifactId>
    <packaging>war</packaging>
    <version>0.0.1-SNAPSHOT</version>
    <name>pre-worker-ssh Maven Webapp</name>
    <url>http://maven.apache.org</url>
    <properties>
        <struts.version>2.3.33</struts.version>
        <spring.version>4.3.12.RELEASE</spring.version>
        <hibernate.version>4.2.21.Final</hibernate.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
        <!-- Struts2 -->
        <dependency>
            <groupId>org.apache.struts</groupId>
            <artifactId>struts2-core</artifactId>
            <version>${struts.version}</version>
            <!-- 去除与hibernate重复的依赖 -->
            <exclusions>
                <exclusion>
                    <groupId>javassist</groupId>
                    <artifactId>javassist</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!-- spring核心 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <!-- Spring AOP -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-aspects</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <!-- Spring ORM -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-orm</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <!-- Spring Web -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <!-- Spring 单元测试 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <!-- Hibernate -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>${hibernate.version}</version>
        </dependency>
        <!-- Struts2 -->
        <dependency>
            <groupId>org.apache.struts</groupId>
            <artifactId>struts2-spring-plugin</artifactId>
            <version>${struts.version}</version>
        </dependency>
        <!-- JDBC 驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.43</version>
        </dependency>
        <!-- C3P0 连接池 -->
        <dependency>
            <groupId>c3p0</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.1.2</version>
        </dependency>
        <!-- slf4j日志 -->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.25</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-simple</artifactId>
            <version>1.6.4</version>
        </dependency>
        <!-- jstl -->
        <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
        <dependency>
            <groupId>taglibs</groupId>
            <artifactId>standard</artifactId>
            <version>1.1.2</version>
        </dependency>
        <!-- servlet -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>jsp-api</artifactId>
            <version>2.2</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>
    <build>
        <finalName>pre-worker-ssh</finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

Web全局配置:web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://xmlns.jcp.org/xml/ns/javaee"
    xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
    id="WebApp_ID" version="3.1">
    <display-name>SSH-START</display-name>
    <!-- 配置spring监听器,在服务器启动时初始化IoC容器 -->
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <!-- 指定Spring配置文件位置applicationContext.xml -->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext.xml</param-value>
    </context-param>
    <!-- 配置struts2过滤器 -->
    <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>

数据库参数设置:jdbc.properties

jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://localhost\:3306/pre_worker?useUnicode\=true&characterEncoding\=utf8
jdbc.username=root
jdbc.password=mysql
jdbc.maxPoolSize=40
jdbc.minPoolSize=1
jdbc.initialPoolSize=1
jdbc.maxIdleTime=60

Spring配置: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:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop" 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/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
    <!-- 引入jdbc.properties -->
    <context:property-placeholder location="classpath:jdbc.properties" />
    <!-- c3p0数据源配置 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
        destroy-method="close">
        <property name="driverClass" value="${jdbc.driverClass}"></property>
        <property name="jdbcUrl" value="${jdbc.url}" />
        <property name="user" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        <property name="maxPoolSize" value="${jdbc.maxPoolSize}" />
        <property name="minPoolSize" value="${jdbc.minPoolSize}" />
        <property name="initialPoolSize" value="${jdbc.initialPoolSize}" />
        <!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。默认为0 -->
        <property name="maxIdleTime" value="${jdbc.maxIdleTime}" />
    </bean>
    <!-- Hibernate的SessionFactory相关配置 -->
    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
                hibernate.show_sql=true<!-- 控制台打印sql语句 -->
                hibernate.format_sql=true
                hibernate.hbm2ddl.auto=update<!-- 自动生成数据库表格 -->
            </value>
        </property>
        <property name="mappingLocations" value="classpath:gdou/laiminghai/po/*.hbm.xml" />
    </bean>
    <!-- Dao组件扫描 -->
    <context:component-scan base-package="gdou.laiminghai.dao"/>
    <!-- Service组件扫描 -->
    <context:component-scan base-package="gdou.laiminghai.service"/>
    <!-- 事务管理器配置 -->
    <bean id="txManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>
    <!-- 切面定义 -->
    <tx:advice id="txAdivce" transaction-manager="txManager">
        <tx:attributes>
            <tx:method name="get*" read-only="true" />
            <tx:method name="*" propagation="REQUIRED" />
        </tx:attributes>
    </tx:advice>
    <!-- AOP切面配置 -->
    <aop:config>
        <aop:pointcut expression="execution(* gdou.laiminghai.service.*.*(..))"
            id="pointcut" />
        <aop:advisor advice-ref="txAdivce" pointcut-ref="pointcut" />
    </aop:config>
</beans>

Struts配置:struts.xml

<?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>
    <constant name="struts.enable.DynamicMethodInvocation" value="false" />
    <constant name="struts.devMode" value="true" />
    <include file="struts-default.xml" />
    <package name="default" extends="struts-default">
        <global-results>
            <result name="failure">op-failure.jsp</result>
        </global-results>
        <action name="addClazz" class="gdou.laiminghai.action.ClazzAction">
            <result name="success">clazz-list.jsp</result>
        </action>
        <action name="addStudent" class="gdou.laiminghai.action.StudentAction">
            <result name="success">student-list.jsp</result>
        </action>
    </package>
</struts>     

PO类及映射文件编写:

Clazz.hbm.xml

<?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="gdou.laiminghai.po.Clazz" table="clazz">
        <id name="claId" type="int">
            <column name="iClaId" />
            <generator class="native" />
        </id>
        <property name="claName" type="java.lang.String">
            <column name="vClaName" length="20" />
        </property>
        <set name="students" table="student" lazy="false" cascade="all"
            inverse="false"><!-- inverse默认值为false -->
            <key>
                <column name="iClaId" />
            </key>
            <one-to-many class="gdou.laiminghai.po.Student" />
        </set>
    </class>
</hibernate-mapping>

Student.hbm.xml

<?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="gdou.laiminghai.po.Student" table="student">
        <id name="stuId" type="int">
            <column name="iStuId" />
            <generator class="native" />
        </id>
        <property name="stuName" type="java.lang.String">
            <column name="vStuName" length="20" />
        </property>
        <many-to-one name="stuCla" class="gdou.laiminghai.po.Clazz"
            fetch="join" cascade="all" lazy="false">
            <column name="iClaId" />
        </many-to-one>
    </class>
</hibernate-mapping>

Dao编写:

参考自:http://blog.csdn.net/wuxintdrh/article/details/77841664
BaseDao.java

public interface BaseDao<T> {
    long save(T t);
    void delete(int id);
    T get(int id);
    void update(T t);
    List<T> getByHql(String hql);
}

BaseDaoImpl.java

public class BaseDaoImpl<T> extends HibernateDaoSupport implements BaseDao<T>{
    @Resource(name="sessionFactory")
    public void setSuperSessionFactory(SessionFactory sessionFactory) {
        super.setSessionFactory(sessionFactory);
    }

    @Override
    public long save(T t) {
        return (int) getHibernateTemplate().save(t);
    }

    @Override
    public void delete(int id) {
        getHibernateTemplate().delete(get(id));
    }

    @Override
    public T get(int id) {
        return getHibernateTemplate().get(getClz(), id);
    }

    @Override
    public void update(T t) {
        getHibernateTemplate().update(t);
    }

    @Override
    public List<T> getByHql(String hql) {
        return (List)getHibernateTemplate().find(hql);
    }

    //获取泛型的类
    private Class<T> clz;
    @SuppressWarnings("unchecked")
    public Class<T> getClz() {
        if (clz == null) {
            clz = (Class<T>)(((ParameterizedType)(this.getClass().getGenericSuperclass())).getActualTypeArguments()[0]);
        }
        return clz;
    }
}

Service编写:

Action编写:

StudentAction.java

//模型驱动 
public class StudentAction extends ActionSupport implements ModelDriven<Student> {

    private Student student = new Student();

    @Autowired
    private StudentService studentService;

    @Override
    public Student getModel() {
        return student;
    }

    @Override
    public String execute() throws Exception {
        studentService.save(student);
        ActionContext.getContext().put("students", studentService.getAllStudents());
        return SUCCESS;
    }
}

ClazzAction.java

//属性驱动 
public class ClazzAction extends ActionSupport {

    private Clazz clazz;
    private Set<Student> students;

    @Autowired
    private ClazzService clazzService;

    public Clazz getClazz() {
        return clazz;
    }

    public void setClazz(Clazz clazz) {
        this.clazz = clazz;
    }

    public Set<Student> getStudents() {
        return students;
    }

    public void setStudents(Set<Student> students) {
        this.students = students;
    }

    @Override
    public String execute() throws Exception {
        clazz.setStudents(students);
        clazzService.save(clazz);
        ActionContext.getContext().put("clazzs", clazzService.getAllClazzs());
        return SUCCESS;
    }
}

ClazzAction 需要封装Set集合,注意在action当前目录下添如下配置文件:
ClazzAction-conversion.properties

KeyProperty_students=stuId

页面:

添加Clazz:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>添加班级</title>
</head>
<body>
添加班级:
    <s:form action="addClazz">
        <s:textfield name="clazz.claName" label="班级名称"></s:textfield>
        <s:textfield name="students.makeNew[0].stuName" label="学生1"></s:textfield>
        <s:textfield name="students.makeNew[1].stuName" label="学生2"></s:textfield>
        <s:submit value="添加"></s:submit>
    </s:form>
</body>
</html>

添加成功:

扫描二维码关注公众号,回复: 2368074 查看本文章
<ul>
        <s:iterator value="clazzs" var="clazz">
            <li><s:property value="#clazz.claId"/>:<s:property value="#clazz.claName"/></li>
            <ul>
                <s:iterator value="#clazz.students" var="student">
                    <li><s:property value="#student.stuId"/>:<s:property value="#student.stuName"/></li>
                </s:iterator>
            </ul>
        </s:iterator>
    </ul>

完整代码:http://download.csdn.net/download/crazylai1996/10256298

猜你喜欢

转载自blog.csdn.net/crazylai1996/article/details/79357948