经过23天的艰苦斗争,终于搞定了数据采集系统~徐培成老师很厉害啊,明明只是用了10天就搞定的项目我却做了23天,还是模仿的。。。呵呵,算了,总之最后总算是完成了,现在该好好整理该项目了。

第一天的内容:SSH框架搭建

一、系统说明

  1.该系统是数据采集系统,说白了就是问卷调查系统,它和考试系统使用的技术几乎完全相同。

  2.开发环境:

    Eclipse版本:Eclipse Java EE IDE for Web Developers,Mars Release (4.5.0)

    Hibernate版本:hibernate-distribution-3.5.6-Final

    Spring版本:spring 3.1.0

    Struts2版本:struts2 2.3.1.2

    使用的数据库:mysql 5.5

    使用的数据库连接池:c3p0-0.9.1.2

    其余第三方插件用到的时候再说。

二、环境搭建 

  1.引入类库

    [struts2]
      asm-3.3.jar
      asm-commons-3.3.jar
      asm-tree-3.3.jar
      commons-fileupload-1.2.2.jar
      commons-io-2.0.1.jar
      commons-lang-2.5.jar
      freemarker-2.3.18.jar
      javassist-3.11.0.GA.jar
      ognl-3.0.4.jar
      struts2-core-2.3.1.2.jar
      xwork-core-2.3.1.2.jar
    [hibernate]
      antlr-2.7.6.jar
      commons-collections-3.1.jar
      hibernate3.jar
      javassist-3.11.0.GA.jar
      jta-1.1.jar
      log4j.jar
      slf4j-api-1.5.8.jar
      slf4j-log4j12.jar
    [spring]
      org.springframework.aop-3.1.0.RELEASE.jar
      org.springframework.asm-3.1.0.RELEASE.jar
      org.springframework.aspects-3.1.0.RELEASE.jar
      org.springframework.beans-3.1.0.RELEASE.jar
      org.springframework.context-3.1.0.RELEASE.jar
      org.springframework.context.support-3.1.0.RELEASE.jar
      org.springframework.core-3.1.0.RELEASE.jar
      org.springframework.expression-3.1.0.RELEASE.jar
      org.springframework.jdbc-3.1.0.RELEASE.jar
      org.springframework.orm-3.1.0.RELEASE.jar
      org.springframework.transaction-3.1.0.RELEASE.jar
      org.springframework.web-3.1.0.RELEASE.jar

      com.springsource.net.sf.cglib-2.2.0.jar
      com.springsource.org.aopalliance-1.0.0.jar
      com.springsource.org.aspectj.tools-1.6.6.RELEASE.jar
      com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar
      com.springsource.org.apache.commons.logging-1.1.1.jar
      [struts-spring-plugin]
      struts2-spring-plugin-2.3.1.2.jar
    [driver]
      mysql-connector-java-5.0.8-bin.jar
    [datasource]
      com.springsource.com.mchange.v2.c3p0-0.9.1.2.jar

  2.创建基本包结构

    [src]

      com.kdyzm.dao.base
      com.kdyzm.dao.base.impl
      com.kdyzm.dao.impl
      com.kdyzm.domain
      com.kdyzm.service
      com.kdyzm.service.base
      com.kdyzm.service.base.impl
      com.kdyzm.service.impl
      com.kdyzm.struts.action
      com.kdyzm.struts.action.base
      com.kdyzm.utils

    [config]

      struts.xml
      hibernate
      spring
      struts2

    [readSrc]

    [init]

  3.配置文件

    (1)struts2配置

      [web.xml配置]

 <!-- 配置OSIV模式过滤器,该过滤器必须在struts2过滤器之前配置
缺点是耗费资源因为在前端页面渲染的时候Session不能关闭表示数据库连接一直打开
-->
<filter>
<filter-name>osivFilter</filter-name>
<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>osivFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- 配置struts2过滤器 -->
<filter>
<filter-name>struts2filter</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2filter</filter-name>
<url-pattern>/*</url-pattern><!-- 对所有流量进行过滤 -->
</filter-mapping>

      [config/strtus.xml] 为了加快tomcat启动速度,并且摆脱必须连接到Internet的限制,全部使用本地文件传输协议(file:///)

<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.1.7//EN"
"file:\\\D:\程序\java\struts2\dtd\struts-2.3.dtd">
<struts>
</struts>

      [config/struts.properties]

 struts.i18n.encoding=UTF-8
struts.action.extension=action,,
struts.serve.static.browserCache=false
struts.i18n.reload=true
struts.configuration.xml.reload=true
struts.devMode=true
struts.ui.theme=simple
struts.enable.DynamicMethodInvocation=true
struts.multipart.maxSize=2097152
struts.ognl.allowStaticMethodAccess=true

    (2)hibernate配置

      [config/hibernate/hibernate.cfg.xml配置]

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"file:///D:/程序/java/Hibernate/dtd文件/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 这里的数据源不需要配置了,使用spring进行c3p0数据源的配置 -->
<!-- <property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<property name="connection.username">root</property>
<property name="connection.password">5a6f38</property>
<property name="connection.url">
jdbc:mysql://localhost:3306/lsn_surveypark
</property> -->
<property name="show_sql">true</property>
<property name="hbm2ddl.auto">update</property>
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name="javax.persistence.validation.mode">none</property>
</session-factory>
</hibernate-configuration>

      [config/jdbc.properties]配置,该文件将被spring引用。

 #jdbc configurations
jdbc.username=root
jdbc.password=5a6f38
jdbc.url=jdbc:mysql://localhost:3306/lsn_surveypark
jdbc.driverclass=com.mysql.jdbc.Driver #c3p0 configurations
c3p0.pool.maxsize=20
c3p0.pool.minsize=4
c3p0.pool.initsieze=4
c3p0.pool.increment=2

    (3)config/spring/applicationContext.xml文件配置

      [命名空间声明],同样使用本地文件传输协议(file:///)来声明xsd文件的位置。除了之后的spring缓存策略,其余使用spring 2.5即可解决。

<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:cache="http://www.springframework.org/schema/cache"
xsi:schemaLocation="http://www.springframework.org/schema/aop file:///D:\程序\java\Spring\spring-framework-4.2.1\spring-framework-4.2.1.RELEASE\schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/beans file:///D:\程序\java\Spring\spring-framework-4.2.1\spring-framework-4.2.1.RELEASE\schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/cache file:///D:\程序\java\Spring\spring-framework-4.2.1\spring-framework-4.2.1.RELEASE\schema\cache/spring-cache-3.1.xsd
http://www.springframework.org/schema/tx file:///D:\程序\java\Spring\spring-framework-4.2.1\spring-framework-4.2.1.RELEASE\schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/context file:///D:\程序\java\Spring\spring-framework-4.2.1\spring-framework-4.2.1.RELEASE\schema/context/spring-context-2.5.xsd">
</beans>

      [组件扫描] 为了加快扫描速度,具体到每个包

<context:component-scan
base-package="com.kdyzm.dao.impl,com.kdyzm.service.impl,com.kdyzm.struts.action,com.kdyzm.dao.base.impl,com.kdyzm.listener"></context:component-scan>

      [加载jdbc配置文件]

<context:property-placeholder location="classpath:jdbc.properties" />

      [整合hibernate]

          [配置数据源]

 <bean id="dateSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driverclass}"></property>
<property name="jdbcUrl" value="${jdbc.url}"></property>
<property name="user" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property> <!-- 配置本身的数据源 -->
<property name="maxPoolSize" value="${c3p0.pool.maxsize}"></property>
<property name="minPoolSize" value="${c3p0.pool.minsize}"></property>
<property name="initialPoolSize" value="${c3p0.pool.initsieze}"></property>
<property name="acquireIncrement" value="${c3p0.pool.increment}"></property>
</bean>

          [配置本地会话工厂bean]

 <bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 注入数据源 -->
<property name="dataSource" ref="dataSource"></property>
<!-- 指定hibernate配置文件 -->
<property name="configLocation" value="classpath:hibernate/hibernate.cfg.xml"></property>
<!-- 指定映射文件目录 -->
<property name="mappingDirectoryLocations">
<list>
<value>classpath:com/kdyzm/domain</value>
</list>
</property>
</bean>

      [事务管理配置]

          [配置事务管理器]

 <!-- 事务管理器 -->
<bean name="txManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>

          [配置事务通知]

 <!-- 配置事务通知 -->
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
<!-- 需要加上事务处理的 -->
<tx:method name="save*" isolation="DEFAULT" propagation="REQUIRED"
read-only="false" />
<tx:method name="update*" isolation="DEFAULT" propagation="REQUIRED"
read-only="false" />
<tx:method name="delete*" isolation="DEFAULT" propagation="REQUIRED"
read-only="false" />
<tx:method name="batch*" isolation="DEFAULT" propagation="REQUIRED"
read-only="false" />
<tx:method name="new*" isolation="DEFAULT" propagation="REQUIRED"
read-only="false" />
<tx:method name="create*" isolation="DEFAULT" propagation="REQUIRED"
read-only="false" />
<!-- 不需要加上事务处理的 -->
<tx:method name="get*" isolation="DEFAULT" propagation="REQUIRED"
read-only="true" />
<tx:method name="load*" isolation="DEFAULT" propagation="REQUIRED"
read-only="true" />
<tx:method name="find*" isolation="DEFAULT" propagation="REQUIRED"
read-only="true" />
<!-- 其余的方法全部加上事务,防止某些方法应该加上事务但是方法名不匹配 -->
<tx:method name="*" isolation="DEFAULT" propagation="REQUIRED" />
</tx:attributes>
</tx:advice>

          [aop事务配置]

 <aop:config>
<aop:pointcut expression="execution(* *..*Service.*(..))"
id="txPointcut" />
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"
order="2" />
</aop:config>

      [web.xml配置文件配置] 使得spring容器在tomcat启动的时候初始化

 <!-- 通过上下文参数指定spring文件的位置,为什么tomcat会知道该位置? -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/applicationContext.xml,classpath:spring/schedual.xml</param-value>
</context-param>
<!-- spring上下文载入监听器,使得spring容器随着tomcat的启动而初始化 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

    

    OK,SSH框架整合结束。

      

【Java EE 学习 69 中】【数据采集系统第一天】【SSH框架搭建】的更多相关文章

  1. 【Java EE 学习 69 下】【数据采集系统第一天】【实体类分析和Base类书写】

    之前SSH框架已经搭建完毕,现在进行实体类的分析和Base类的书写.Base类是抽象类,专门用于继承. 一.实体类关系分析 既然是数据采集系统,首先调查实体(Survey)是一定要有的,一个调查有多个 ...

  2. 【Java EE 学习 78 中】【数据采集系统第十天】【Spring远程调用】

    一.远程调用概述 1.远程调用的定义 在一个程序中就像调用本地中的方法一样调用另外一个远程程序中的方法,但是整个过程对本地完全透明,这就是远程调用.spring已经能够非常成熟的完成该项功能了. 2. ...

  3. 【Java EE 学习 69 上】【struts2】【paramsPrepareParamsStack拦截器栈解决model对象和属性赋值冲突问题】

    昨天有同学问我问题,他告诉我他的Action中的一个属性明明提供了get/set方法,但是在方法中却获取不到表单中传递过来的值.代码如下(简化后的代码) public class UserAction ...

  4. Java EE 学习(8):IDEA + maven + spring 搭建 web(4)- 用户管理

    转载:Gaussic(一个致力于AI研究却不得不兼顾项目的研究生) 注:在阅读本文前,请先阅读: Java EE 学习(5):IDEA + maven + spring 搭建 web(1) ava E ...

  5. Java EE学习——Quartz的Cron表达式

    经历过低谷后,还是要好好学习,越失落会越来越落后. 今天写一下Cron表达式的用法,虽然是之前自己写的,也过了挺长一段时间,这次就拿出来作为回顾吧. Cron表达式是Quartz的精髓(个人觉得),比 ...

  6. Java EE 学习(9):IDEA + maven + spring 搭建 web(5)- 博客文章管理

    转载:Gaussic(一个致力于AI研究却不得不兼顾项目的研究生) . 注:在阅读本文前,请先阅读: Java EE 学习(5):IDEA + maven + spring 搭建 web(1) Jav ...

  7. Java EE 学习(7):IDEA + maven + spring 搭建 web(3)- 配置数据库

    参考: https://my.oschina.net/gaussik/blog/513444 注:在阅读本文前,请先阅读: Java EE 学习(5):IDEA + maven + spring 搭建 ...

  8. Java EE 学习(6):IDEA + maven + spring 搭建 web(2)- 配置 Spring

    参考:https://my.oschina.net/gaussik/blog/513353 注:此文承接上一文:Java EE 学习(5):IDEA + maven + spring 搭建 web(1 ...

  9. Java EE 学习(5):IDEA + maven + spring 搭建 web(1)

    参考:http://www.cnblogs.com/lonelyxmas/p/5397422.html http://www.ctolib.com/docs-IntelliJ-IDEA-c--1590 ...

随机推荐

  1. [原创] C# dynamic拼接Json串

    using Newtonsoft.Json; 之前拼接两个json串,是用的这样的代码 , json1.Length - ); json2 = json2.Insert(json2 - , tmp); ...

  2. 网络抓包wireshark(转)

    转自 网络抓包wireshark   抓包应该是每个技术人员掌握的基础知识,无论是技术支持运维人员或者是研发,多少都会遇到要抓包的情况,用过的抓包工具有fiddle.wireshark,作为一个不是经 ...

  3. vim vi Ubuntu

    在vi编辑模式下按退格键不能删除内容,按方向键不能上下左右移动?如果是则:1. 在vi里非编辑模式下按冒号进入到末行命令模式,然后输入set nocompatible,回车,然后在进入vi编辑模式,看 ...

  4. 阿里云推送SDK在某些机型(某米为主)下崩溃问题的解决方法

    引言 最近APP上线,遇到一个比较诡异的问题.最后竟然和dex文件有关,也是醉了,看来还得深入底层学习啊. 问题描述 在集成阿里推送SDK时,需要在Application中进行初始化,大多数Andro ...

  5. php、前端开发(网站建设)环境搭建

    php集成开发环境wampserver,是一款免费开源的软件,下载地址http://www.wampserver.com,由于是国外的网站,打开速度慢,根据自己的电脑选择32位/64位的系统下载.

  6. netlink优势

    netlink相对其他应用进程和内核之间通信的方式(ioctrl或者系统文件等方式),全双工,可由内核发起,应用进程可用epoll监听,而其他方式只能由应用进程发起. 顺便记下隧道,隧道可以通过在ip ...

  7. 【Win10】SplitView控件

    SplitView是Win10中的新控件. 用于呈现两部分视图. 一个视图是主要内容,另一个视图是用于导航.(也就是通常说的汉堡菜单.) 主要结构: <SplitView> <Spl ...

  8. sql表分区

    1.单表达多少条数据后需要分区呢?   a.个人认为要似情况而定,有些常操作的表,分区反而带来麻烦,可以采用物理分表以及其它方法处理:   b.对于一些日志.历史订单类的查询数据,500w左右即可享受 ...

  9. nodeJS爬虫---慕课网

    源代码一(爬取html源码) //引入http模块var http = require('http');//引入url地址var url = 'http://www.imooc.com/learn/2 ...

  10. Maven把自己的包部署到远程仓库

    1,配置项目的POM文件 <dependencyManagement> </dependencies> </dependency> ...... </depe ...