Struts2+Spring+Hibernate+Jbpm技術實現Oa(Office Automation)辦公系統第一天框架搭建

=============編碼規範,全部文健,全部頁面,全部數據庫的數據表都採用UTF-8編碼格式,避免亂碼;===========開發環境:jdk1.7+tomcat8.0+mysql5.7+eclipse Mars.2 Release (4.5.2)
html

1:建立一個動態web項目,名稱如Oa;前端

2:建立一個Oa的數據庫,而且建立一個新用戶只能夠操做Oa這個數據庫;java

1 ----建立數據庫
2 create database Oa default character set utf8;
3 
4 -----建立用戶
5 create user biexiansheng identified by '123456';
6 
7 -----爲用戶受權
8 grant all on Oa.* to biexiansheng;

舒適提示:建立好以後使用的是Navicat鏈接的數據庫,注意鏈接名和用戶名是本身起的好比個人別先生,密碼也是本身的好比個人123456。mysql

3:導入各個框架的jar包:web

  3.1:第一步,先導入struts2的jar包,以下所示:spring

asm-3.3.jar
asm-commons-3.3.jar
asm-tree-3.3.jar
commons-fileupload-1.3.1.jar
commons-io-2.2.jar
commons-lang-2.4.jar
freemarker-2.3.19.jar
javassist-3.11.0.GA.jar
ognl-3.0.6.jar
struts2-core-2.3.16.3.jar
struts2-spring-plugin-2.3.16.3.jar
xwork-core-2.3.16.3.jar
sql

而後配置一下web.xml的前端控制器:數據庫

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <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">
 3   <display-name>Oa</display-name>
 4   <welcome-file-list>
 5     <welcome-file>index.html</welcome-file>
 6     <welcome-file>index.htm</welcome-file>
 7     <welcome-file>index.jsp</welcome-file>
 8     <welcome-file>default.html</welcome-file>
 9     <welcome-file>default.htm</welcome-file>
10     <welcome-file>default.jsp</welcome-file>
11   </welcome-file-list>
12   
13   
14   <!-- 配置struts2的前端控制器 -->
15   <filter>
16       <filter-name>struts2</filter-name>
17       <!-- struts2-core-2.3.16.3.jar這個jar包裏面查找 -->
18       <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
19   </filter>
20   <filter-mapping>
21       <filter-name>struts2</filter-name>
22       <url-pattern>/*</url-pattern>
23   </filter-mapping>
24   
25   
26   
27   
28 </web-app>

而後再複製一下struts.xml的配置文件放到src/config下面,模板以下所示:express

<?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">


<!-- struts2的配置信息 -->
<struts>
    
    <!-- 將對象工廠指定爲spring -->    
    <constant name="struts.objectFactory" value="spring"></constant>
    
    <!-- struts的Action的訪問後綴,必須以.do結尾 -->
    <constant name="struts.action.extension" value="do"></constant>
    
    
       <package name="default" namespace="/" extends="struts-default">
           <action name="">
               <result></result>
           </action>
       </package>

</struts>

  3.2:導入spring的jar包:以下所示:apache

com.springsource.com.mchange.v2.c3p0-0.9.1.2.jar
com.springsource.org.aopalliance-1.0.0.jar
com.springsource.org.apache.commons.logging-1.1.1.jar
com.springsource.org.apache.log4j-1.2.15.jar
com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar
spring-aop-3.2.5.RELEASE.jar
spring-aspects-3.2.5.RELEASE.jar
spring-beans-3.2.5.RELEASE.jar
spring-context-3.2.5.RELEASE.jar
spring-core-3.2.5.RELEASE.jar
spring-expression-3.2.5.RELEASE.jar
spring-jdbc-3.2.5.RELEASE.jar
spring-orm-3.2.5.RELEASE.jar
spring-tx-3.2.5.RELEASE.jar
spring-web-3.2.5.RELEASE.jar

而後在web.xml裏面配置一下spring的上下文載入器和監聽器,配置以下所示:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <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">
 3   <display-name>Oa</display-name>
 4   <welcome-file-list>
 5     <welcome-file>index.html</welcome-file>
 6     <welcome-file>index.htm</welcome-file>
 7     <welcome-file>index.jsp</welcome-file>
 8     <welcome-file>default.html</welcome-file>
 9     <welcome-file>default.htm</welcome-file>
10     <welcome-file>default.jsp</welcome-file>
11   </welcome-file-list>
12   
13   <!-- 經過上下文參數指定spring配置文件的位置 -->
14   <context-param>
15       <param-name>contextConfigLocation</param-name>
16       <param-value>classpath:beans.xml</param-value>
17   </context-param>
18   
19   <!-- 配置spring的上下文載入器監聽器,項目啓動時加載spring -->
20   <listener>
21       <!-- 
22           方法:ctrl+shift+t 搜索ContextLoaderListener 
23           spring-web-3.2.5.RELEASE.jar
24       -->
25       <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
26   </listener>      
27   
28  
29   <!-- 配置struts2的前端控制器 -->
30   <filter>
31       <filter-name>struts2</filter-name>
32       <!-- struts2-core-2.3.16.3.jar這個jar包裏面查找 -->
33       <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
34   </filter>
35   <filter-mapping>
36       <filter-name>struts2</filter-name>
37       <url-pattern>/*</url-pattern>
38   </filter-mapping>
39   
40   
41   
42   
43 </web-app>

而後在src/config下面配置一下spring的配置文件:(因爲使用的是註解掃描的,因此會使用開啓註解和組件掃描)

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <beans xmlns="http://www.springframework.org/schema/beans"
 3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
 4     xmlns:p="http://www.springframework.org/schema/p"
 5     xmlns:context="http://www.springframework.org/schema/context"
 6     xmlns:aop="http://www.springframework.org/schema/aop"
 7     xmlns:tx="http://www.springframework.org/schema/tx"
 8     xsi:schemaLocation="http://www.springframework.org/schema/beans
 9          http://www.springframework.org/schema/beans/spring-beans.xsd
10           http://www.springframework.org/schema/context
11          http://www.springframework.org/schema/context/spring-context.xsd
12          http://www.springframework.org/schema/aop
13          http://www.springframework.org/schema/aop/spring-aop.xsd
14          http://www.springframework.org/schema/tx
15           http://www.springframework.org/schema/tx/spring-tx.xsd">
16      
17      
18      <!-- IoC容器的配置,也叫控制反轉,要建立的全部的對象都配置在這裏 -->
19      
20      <!-- 讀取屬性文件 -->
21      <context:property-placeholder location="classpath:jdbc.properties"/>
22      
23      <!-- 數據源 -->
24      <!-- 
25          ctrl+shift+t搜索ComboPooledDataSource
26       -->
27      <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
28          <property name="driverClass" value="${driverClass}"></property>
29          <property name="jdbcUrl" value="${jdbcUrl}"></property>
30          <property name="user" value="${user}"></property>
31          <property name="password" value="${password}"></property>
32          <property name="initialPoolSize" value="${initialPoolSize}"></property>
33          <property name="minPoolSize" value="${minPoolSize}"></property>
34          <property name="maxPoolSize" value="${maxPoolSize}"></property>
35      </bean>
36      
37      <!-- 本地回話工廠bean -->
38      <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
39          <!-- 注入數據源 -->
40          <property name="dataSource" ref="dataSource"></property>
41          
42          <!-- 注入hibernate屬性 -->
43          <property name="hibernateProperties">
44              <props>
45                  <!-- mysql的方言,因爲使用工做流框架因此使用這個方言 -->
46                  <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
47                  
48                  <prop key="hibernate.hbm2ddl.auto">true</prop>
49                  
50                  <prop key="hibernate.show_sql">true</prop>
51                  
52                  <prop key="hibernate.format_sql">true</prop>
53              </props>
54              
55          </property>
56          
57          
58          <!-- hibernate的映射文件 -->
59          <property name="mappingDirectoryLocations">
60              <list>
61                  <value>classpath:com/oa/po</value>
62              </list>
63          </property>
64          
65      </bean>
66      
67      <!-- hibernate的事務管理器 -->
68      <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
69          <property name="sessionFactory" ref="sessionFactory"></property>
70      </bean>
71      
72      <!-- 對註解的支持 -->
73      <context:annotation-config></context:annotation-config>
74      <!-- 組件掃描 -->
75      <context:component-scan base-package="com.oa"></context:component-scan>
76      
77      <!-- 註解驅動 -->
78      <tx:annotation-driven transaction-manager="txManager"/>
79      
80     
81 </beans>     

建立一個jdbc.properties配置文件,配置以下所示:

1 driverClass=com.mysql.jdbc.Driver
2 jdbcUrl=jdbc:mysql://localhost:3306/oa
3 user=biexiansheng
4 password=123456
5 initialPoolSize=20
6 minPoolSize=20
7 maxPoolSize=40

建立一個log4j.properties配置文件,用於記錄日誌的相關信息:(記得修改本身的日誌保存的文件路徑,在第9行)

 1 ### direct log messages to stdout ###
 2 log4j.appender.stdout=org.apache.log4j.ConsoleAppender
 3 log4j.appender.stdout.Target=System.err
 4 log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
 5 log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
 6 
 7 ### direct messages to file mylog.log ###
 8 log4j.appender.file=org.apache.log4j.FileAppender
 9 log4j.appender.file.File=E:\Android_java_resouce\JAVA_EE\eclipse\workspace\mylog.log
10 log4j.appender.file.layout=org.apache.log4j.PatternLayout
11 log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
12 
13 ### set log levels - for more verbose logging change 'info' to 'debug' ###
14 
15 log4j.rootLogger=info, stdout

  3.3:導入hibernate的相關jar包,以下所示:

 1 antlr-2.7.6.jar
 2 commons-collections-3.1.jar
 3 dom4j-1.6.1.jar
 4 hibernate-jpa-2.0-api-1.0.0.Final.jar
 5 hibernate3.jar
 6 javassist-3.12.0.GA.jar
 7 jta-1.1.jar
 8 mysql-connector-java-5.1.40-bin.jar
 9 slf4j-api-1.6.1.jar
10 slf4j-log4j12-1.7.2.jar

4:建立項目包結構,搭建的項目結構以下所示:

5:項目搭建好以後將項目放到本地tomat下面跑一下,看看搭建的項目是否出現錯誤:

 

舒適提示:假如最後跑項目出現錯誤,請不要着急,仔細分析,應該能夠很快解決問題;

所謂萬事開頭難,開好頭,加油!生命不息,運動不止;

6:框架搭建完以後就能夠進行業務開發了;先提取公共的方法,好比增刪改查的公共的方法,Action公共的方法。

首先建立一個接口,實現這些需求的方法,增刪改查:

 1 package com.oa.base;
 2 
 3 import java.util.List;
 4 
 5 /**
 6  * @author biexiansheng
 7  *
 8  *建立日期  2017年7月16日
 9  *
10  *公共的增刪改查的方法
11  */
12 public interface BaseDao<T> {
13 
14     //添加信息
15     public void save(T entity);
16     
17     //根據什麼id進行刪除
18     public void delete(Long id);
19     
20     //根據id進行修改
21     public void update(T entity);
22     
23     //根據id進行查詢什麼信息,修改的時候可使用
24     public T getById(Long id);
25     
26     //查詢全部的信息
27     public List<T> findAll();
28     
29     //一次查詢多個對象
30     public List<T> getByIds(Long[] ids);
31 }

 而後實現這個接口的這些方法:

  1 package com.oa.base.impl;
  2 
  3 import java.lang.reflect.ParameterizedType;
  4 import java.lang.reflect.Type;
  5 import java.util.List;
  6 
  7 import javax.annotation.Resource;
  8 
  9 import org.hibernate.Query;
 10 import org.hibernate.Session;
 11 import org.hibernate.SessionFactory;
 12 
 13 import com.oa.base.BaseDao;
 14 
 15 /**
 16  * @author biexiansheng
 17  *
 18  *建立日期:2017年7月16日
 19  *
 20  *對公共的增刪改查方法進行具體實現
 21  */
 22 public class BaseDaoImpl<T> implements BaseDao<T>{
 23 
 24     //將sessionFactory注入到ioc容器中
 25     @Resource
 26     private SessionFactory sessionFactory;
 27     
 28     private Class<T> clazz;
 29     
 30     public BaseDaoImpl() {
 31         //得到實體類型
 32         //this.getClass();這個得到的是子類的名稱
 33         
 34         //得到真正的父類的名稱,是什麼類型
 35         //生成類型和名稱的快捷鍵ctrl+1
 36         ParameterizedType genericSuperclass = (ParameterizedType) this.getClass().getGenericSuperclass();
 37         
 38         //獲取父類的類型以後開始獲取泛型裏面的內容
 39         Type[] actualTypeArguments = genericSuperclass.getActualTypeArguments();
 40     
 41         //將獲取到的第一個參數即實體類的名稱傳給clazz
 42         clazz = (Class<T>) actualTypeArguments[0];
 43     }
 44     
 45     
 46     @Override
 47     public void save(T entity) {
 48         //保存直接調用hibernate的保存的方法便可
 49         //將傳遞進來的entity參數保存到數據表中
 50         sessionFactory.getCurrentSession().save(entity);
 51     }
 52 
 53     @Override
 54     public void delete(Long id) {
 55         //根據編號刪除,須要先根據編號查詢出來,而後根據編號進行刪除
 56         sessionFactory.getCurrentSession().delete(sessionFactory.getCurrentSession().get(clazz, id));
 57     
 58     }
 59 
 60     @Override
 61     public void update(T entity) {
 62         //修改操做
 63         //即將要修改的內容放到update裏面便可
 64         sessionFactory.getCurrentSession().update(entity);
 65     }
 66 
 67     @Override
 68     public T getById(Long id) {
 69         //根據編號進行查詢信息
 70         
 71         return (T) sessionFactory.getCurrentSession().get(clazz, id);
 72     }
 73 
 74     
 75     @Override
 76     public List<T> findAll() {
 77         //查詢全部
 78         //根據傳遞進來的實體類,將獲取到簡單的類名
 79         String hql = "from" + clazz.getSimpleName();
 80         
 81         //使用createQuery方法建立hql語句進行查詢出全部的信息
 82         return sessionFactory.getCurrentSession().createQuery(hql).list();
 83     }
 84 
 85     @Override
 86     public List<T> getByIds(Long[] ids) {
 87         //一次查詢多個信息
 88         String hql = " from " + clazz.getSimpleName() + " where id in (:ids) ";
 89         
 90         //將查詢語句做爲參數進行傳遞
 91         Query query = sessionFactory.getCurrentSession().createQuery(hql);
 92         
 93         //一次賦值多個
 94         query.setParameterList("ids", ids);
 95         
 96         //將查詢的結果返回回去
 97         return query.list();
 98     }
 99 
100     
101     
102     //提取公共的語句
103     public Session getSession(){
104     
105         //能夠對上面的進行抽取替換,這樣優化開發
106         return sessionFactory.getCurrentSession();
107     }
108     
109 }

接下來再實現Action的這個公共的類的公共的方法:

 1 package com.oa.base.impl;
 2 
 3 import java.lang.reflect.ParameterizedType;
 4 import java.lang.reflect.Type;
 5 
 6 import com.opensymphony.xwork2.ActionSupport;
 7 import com.opensymphony.xwork2.ModelDriven;
 8 
 9 /***
10  * 通用父類action
11  * @author biexiansheng
12  *
13  *建立日期:2017年7月16日
14  */
15 public class BaseAction<T> extends ActionSupport implements ModelDriven<T>{
16 
17     
18     private static final long serialVersionUID = 1L;
19 
20     //構造方法
21     public BaseAction(){
22         //獲取到BaseAction的這個名稱
23         ParameterizedType genericSuperclass = (ParameterizedType) this.getClass().getGenericSuperclass();
24         
25         //獲取父類的類型以後開始獲取泛型裏面的內容
26         Type[] types = genericSuperclass.getActualTypeArguments();
27         
28         將獲取到的第一個參數即實體類的名稱傳給clazz
29         Class<T> clazz = (Class<T>) types[0];
30         
31         try {
32             //將獲取的參數名稱傳給model
33             model = clazz.newInstance();
34         } catch (InstantiationException | IllegalAccessException e) {
35             e.printStackTrace();
36         }
37     }
38     
39     //聲明model類型
40     protected T model;
41     
42     @Override
43     public T getModel() {
44         
45         //返回model類型
46         return model;
47     }
48 
49     
50 }

等到次日就開始實現具體的業務需求;

相關文章
相關標籤/搜索