• Struts2+Spring+Hibernate+Jbpm技术实现Oa(Office Automation)办公系统第一天框架搭建


    =============编码规范,所有文健,所有页面,所有数据库的数据表都采用UTF-8编码格式,避免乱码;===========开发环境:jdk1.7+tomcat8.0+mysql5.7+eclipse Mars.2 Release (4.5.2)

    1:创建一个动态web项目,名称如Oa;

    2:创建一个Oa的数据库,并且创建一个新用户只可以操作Oa这个数据库;

    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。

    3:导入各个框架的jar包:

      3.1:第一步,先导入struts2的jar包,如下所示:

    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

    然后配置一下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下面,模板如下所示:

    <?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包:如下所示:

    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">update</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_resouceJAVA_EEeclipseworkspacemylog.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 }

    等到第二天就开始实现具体的业务需求;

  • 相关阅读:
    安卓开发_求好评功能
    安卓开发_深入理解Content Provider
    安卓开发_数据存储技术_sqlite
    安卓开发_慕课网_Fragment实现Tab(App主界面)
    安卓开发_数据存储技术_外部存储
    Go语言基础之数组
    Go语言基础之结构体
    Go操作MySQL
    Go语言基础之文件操作
    Go第三方日志库logrus
  • 原文地址:https://www.cnblogs.com/biehongli/p/7190686.html
Copyright © 2020-2023  润新知