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

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

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

 ----创建数据库
create database Oa default character set utf8; -----创建用户
create user biexiansheng identified by '123456'; -----为用户授权
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的前端控制器:

 <?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>Oa</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list> <!-- 配置struts2的前端控制器 -->
<filter>
<filter-name>struts2</filter-name>
<!-- struts2-core-2.3.16.3.jar这个jar包里面查找 -->
<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>

然后再复制一下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的上下文载入器和监听器,配置如下所示:

 <?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>Oa</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list> <!-- 通过上下文参数指定spring配置文件的位置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:beans.xml</param-value>
</context-param> <!-- 配置spring的上下文载入器监听器,项目启动时加载spring -->
<listener>
<!--
方法:ctrl+shift+t 搜索ContextLoaderListener
spring-web-3.2.5.RELEASE.jar
-->
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener> <!-- 配置struts2的前端控制器 -->
<filter>
<filter-name>struts2</filter-name>
<!-- struts2-core-2.3.16.3.jar这个jar包里面查找 -->
<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>

然后在src/config下面配置一下spring的配置文件:(由于使用的是注解扫描的,所以会使用开启注解和组件扫描)

 <?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:p="http://www.springframework.org/schema/p"
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"> <!-- IoC容器的配置,也叫控制反转,要创建的所有的对象都配置在这里 --> <!-- 读取属性文件 -->
<context:property-placeholder location="classpath:jdbc.properties"/> <!-- 数据源 -->
<!--
ctrl+shift+t搜索ComboPooledDataSource
-->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${driverClass}"></property>
<property name="jdbcUrl" value="${jdbcUrl}"></property>
<property name="user" value="${user}"></property>
<property name="password" value="${password}"></property>
<property name="initialPoolSize" value="${initialPoolSize}"></property>
<property name="minPoolSize" value="${minPoolSize}"></property>
<property name="maxPoolSize" value="${maxPoolSize}"></property>
</bean> <!-- 本地回话工厂bean -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 注入数据源 -->
<property name="dataSource" ref="dataSource"></property> <!-- 注入hibernate属性 -->
<property name="hibernateProperties">
<props>
<!-- mysql的方言,由于使用工作流框架所以使用这个方言 -->
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop> <prop key="hibernate.hbm2ddl.auto">update</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop>
</props> </property> <!-- hibernate的映射文件 -->
<property name="mappingDirectoryLocations">
<list>
<value>classpath:com/oa/po</value>
</list>
</property> </bean> <!-- hibernate的事务管理器 -->
<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean> <!-- 对注解的支持 -->
<context:annotation-config></context:annotation-config>
<!-- 组件扫描 -->
<context:component-scan base-package="com.oa"></context:component-scan> <!-- 注解驱动 -->
<tx:annotation-driven transaction-manager="txManager"/> </beans>

创建一个jdbc.properties配置文件,配置如下所示:

 driverClass=com.mysql.jdbc.Driver
jdbcUrl=jdbc:mysql://localhost:3306/oa
user=biexiansheng
password=123456
initialPoolSize=20
minPoolSize=20
maxPoolSize=40

创建一个log4j.properties配置文件,用于记录日志的相关信息:(记得修改自己的日志保存的文件路径,在第9行)

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

  3.3:导入hibernate的相关jar包,如下所示:

 antlr-2.7.6.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
hibernate-jpa-2.0-api-1.0.0.Final.jar
hibernate3.jar
javassist-3.12.0.GA.jar
jta-1.1.jar
mysql-connector-java-5.1.40-bin.jar
slf4j-api-1.6.1.jar
slf4j-log4j12-1.7.2.jar

4:创建项目包结构,搭建的项目结构如下所示:

5:项目搭建好之后将项目放到本地tomat下面跑一下,看看搭建的项目是否出现错误:

温馨提示:假如最后跑项目出现错误,请不要着急,仔细分析,应该可以很快解决问题;

所谓万事开头难,开好头,加油!生命不息,运动不止;

6:框架搭建完之后就可以进行业务开发了;先提取公共的方法,比如增删改查的公共的方法,Action公共的方法。

首先创建一个接口,实现这些需求的方法,增删改查:

 package com.oa.base;

 import java.util.List;

 /**
* @author biexiansheng
*
*创建日期 2017年7月16日
*
*公共的增删改查的方法
*/
public interface BaseDao<T> { //添加信息
public void save(T entity); //根据什么id进行删除
public void delete(Long id); //根据id进行修改
public void update(T entity); //根据id进行查询什么信息,修改的时候可以使用
public T getById(Long id); //查询所有的信息
public List<T> findAll(); //一次查询多个对象
public List<T> getByIds(Long[] ids);
}

然后实现这个接口的这些方法:

 package com.oa.base.impl;

 import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.List; import javax.annotation.Resource; import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory; import com.oa.base.BaseDao; /**
* @author biexiansheng
*
*创建日期:2017年7月16日
*
*对公共的增删改查方法进行具体实现
*/
public class BaseDaoImpl<T> implements BaseDao<T>{ //将sessionFactory注入到ioc容器中
@Resource
private SessionFactory sessionFactory; private Class<T> clazz; public BaseDaoImpl() {
//获得实体类型
//this.getClass();这个获得的是子类的名称 //获得真正的父类的名称,是什么类型
//生成类型和名称的快捷键ctrl+1
ParameterizedType genericSuperclass = (ParameterizedType) this.getClass().getGenericSuperclass(); //获取父类的类型之后开始获取泛型里面的内容
Type[] actualTypeArguments = genericSuperclass.getActualTypeArguments(); //将获取到的第一个参数即实体类的名称传给clazz
clazz = (Class<T>) actualTypeArguments[0];
} @Override
public void save(T entity) {
//保存直接调用hibernate的保存的方法即可
//将传递进来的entity参数保存到数据表中
sessionFactory.getCurrentSession().save(entity);
} @Override
public void delete(Long id) {
//根据编号删除,需要先根据编号查询出来,然后根据编号进行删除
sessionFactory.getCurrentSession().delete(sessionFactory.getCurrentSession().get(clazz, id)); } @Override
public void update(T entity) {
//修改操作
//即将要修改的内容放到update里面即可
sessionFactory.getCurrentSession().update(entity);
} @Override
public T getById(Long id) {
//根据编号进行查询信息 return (T) sessionFactory.getCurrentSession().get(clazz, id);
} @Override
public List<T> findAll() {
//查询所有
//根据传递进来的实体类,将获取到简单的类名
String hql = "from" + clazz.getSimpleName(); //使用createQuery方法创建hql语句进行查询出所有的信息
return sessionFactory.getCurrentSession().createQuery(hql).list();
} @Override
public List<T> getByIds(Long[] ids) {
//一次查询多个信息
String hql = " from " + clazz.getSimpleName() + " where id in (:ids) "; //将查询语句作为参数进行传递
Query query = sessionFactory.getCurrentSession().createQuery(hql); //一次赋值多个
query.setParameterList("ids", ids); //将查询的结果返回回去
return query.list();
} //提取公共的语句
public Session getSession(){ //可以对上面的进行抽取替换,这样优化开发
return sessionFactory.getCurrentSession();
} }

接下来再实现Action的这个公共的类的公共的方法:

 package com.oa.base.impl;

 import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type; import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven; /***
* 通用父类action
* @author biexiansheng
*
*创建日期:2017年7月16日
*/
public class BaseAction<T> extends ActionSupport implements ModelDriven<T>{ private static final long serialVersionUID = 1L; //构造方法
public BaseAction(){
//获取到BaseAction的这个名称
ParameterizedType genericSuperclass = (ParameterizedType) this.getClass().getGenericSuperclass(); //获取父类的类型之后开始获取泛型里面的内容
Type[] types = genericSuperclass.getActualTypeArguments(); ////将获取到的第一个参数即实体类的名称传给clazz
Class<T> clazz = (Class<T>) types[0]; try {
//将获取的参数名称传给model
model = clazz.newInstance();
} catch (InstantiationException | IllegalAccessException e) {
e.printStackTrace();
}
} //声明model类型
protected T model; @Override
public T getModel() { //返回model类型
return model;
} }

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

Struts2+Spring+Hibernate+Jbpm技术实现Oa(Office Automation)办公系统第一天框架搭建的更多相关文章

  1. SSH面试题(struts2+Spring+hibernate)

    struts2 + Spring +hibernate Hibernate工作原理及为什么要用?   原理:   1.读取并解析配置文件   2.读取并解析映射信息,创建SessionFactory ...

  2. 整合struts2+spring+hibernate

     一.准备struts2+spring+hibernate所须要的jar包:        新建web项目并将jar包引入到project项目中. 二.搭建struts2环境        a.在 ...

  3. SSH(Struts2+Spring+Hibernate)框架搭建流程<注解的方式创建Bean>

    此篇讲的是MyEclipse9工具提供的支持搭建自加包有代码也是相同:用户登录与注册的例子,表字段只有name,password. SSH,xml方式搭建文章链接地址:http://www.cnblo ...

  4. struts2+spring+hibernate(SSH)框架的搭建和总结

    SSH框架:struts2+spring+hibernate,是目前较流行的一种Web应用程序开源集成框架,用于构建灵活.易于扩展的多层Web应用程序. struts2+spring+hibernat ...

  5. SSH框架简化(struts2+spring+hibernate)

    目的: 通过对ssh框架有了基础性的学习,本文主要是使用注解的方式来简化ssh框架的代码编写. 注意事项: 1.运行环境:Windows 8-64位,Eclipse(开发工具),jdk1.8.0_91 ...

  6. Struts2 + Spring + Hibernate

    Struts2 + Spring + Hibernate整合. 使用的是无配置方法进行SSH的整合,struts-convertion plugin + spring annotation + hib ...

  7. Struts2 + Spring + Hibernate 通用 Service 和 DAO

    我在 Struts2 + Spring + Hibernate  项目开发中总结出了一个Service 和 DAO ,可以用于处理任何的pojo(bean).使用这两个Service 和 DAO 可以 ...

  8. Struts2+Spring+Hibernate 三大框架的合并集成

    这次来看看Struts2+Spring+Hibernate三大框架的整合应用,主要是Spring和Hibernate框架的整合,因为前边已经将Strtus2+Spring整合过了基本一样.  首先看一 ...

  9. Spring、Struts2+Spring+Hibernate整合步骤

    所使用的Jar包: Hibernate: Spring(使用MyEclipse自动导入框架功能) Struts2: 注解包和MySql驱动包: 1.配置Hibernate和Spring: <be ...

随机推荐

  1. 使用sqlserver搭建高可用双机热备的Quartz集群部署【附源码】

    一般拿Timer和Quartz相比较的,简直就是对Quartz的侮辱,两者的功能根本就不在一个层级上,如本篇介绍的Quartz强大的序列化机制,可以序列到 sqlserver,mysql,当然还可以在 ...

  2. Java常用类之要点总结

    Java常用类之要点总结

  3. Thrift总结(一)介绍

    这段时间,一直在整理公司的内部 rpc 服务接口,面临的一个问题就是:由于公司内部的系统由几个不同的语言编写的.C# ,java,node.js 等,如何实现这些内部系统之间的接口统一调用,确实是比较 ...

  4. C#之out修饰符、ref修饰符、params修饰符的简单介绍

    一.out修饰符 1.调用一个带有输出参数的方法也需要使用out 修饰符,但是作为输出变量传递的本地变量在将他们作为输出变量传递前不需要赋值(因为调用后会改变或丢失),编译器允           许 ...

  5. 打开IIS的快捷键

    [windows键+R]→在运行界面输入“inetmgr”→点击回车键,即可以出现IIS界面

  6. mybatis批量增、删、改(更新)操作oracle和mysql批量写法小记

    前言:用mybatis也好几年了,mybatis在批量的增删操作也写起来也是比较简单的,只有批量更新这一块是特别坑,特此记录. 注:本文主要用来记录oracle和mysql数据库在使用mybatis的 ...

  7. spring-boot开发:使用内嵌容器进行快速开发及测试

    一.简述一下spring-boot微框架 1.spring-boot微框架是什么? 大家都知道,在使用spring框架进行应用开发时需要很多*.xml的初始化配置文件,而springBoot就是用来简 ...

  8. github pages部署静态网页

    如果你的项目只是一个静态网站,就没有必要再去整什么服务器,github pages 提供了搭建静态网站的功能: 为什么使用Github Pages 1. 搭建简单而且免费: 2. 支持静态脚本: 3. ...

  9. C# 模拟浏览器请求

    public string getHtml(string Url, string type = "UTF-8")        {            try           ...

  10. 通过 itms:services://? 在线安装ipa ,跨过app-store

    1.需要一个html文件,引导下载用户在线安装ipa <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN&quo ...