=============編碼規範,全部文健,全部頁面,全部數據庫的數據表都採用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.jarsql
而後配置一下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 }
等到次日就開始實現具體的業務需求;