目標:使用Struts2.3.8+Spring3.2.1+Hibernate3.9.10搭建Server
1、使用虛擬機搭建數據庫服務器(20130222)
1)練習環境
工具:VMware7+WinXP+MySQL5
原因:安裝簡單,使用便捷。
虛擬機中Vbox也是一個不錯的選擇,本機的操作系統是Win7_x64,原先使用過VirtualBox-4.2.6-82870-Win,鑑於偶爾會發生網絡連接斷開的現象(具體原因不明),因此換成了VMware。
OS和DB當然是選擇linux&Oracle最佳,但鑑於練習的原因,先使用安裝簡單的WinXP&MySQL,待後續再換。
2)安裝注意事項
在VMware上安裝操作系統不能使用Ghost鏡像,可以去xunlei上搜索官方鏡像。
VMware網絡設置,使用最簡單的NAT模式,該模式默認使用vmnet8連接,默認網關是xxx.xxx.xxx.2,以本機爲例:虛擬WinXP的IP設置192.168.137.211、網關192.168.137.2、DNS服務器192.168.137.2。主機Win7的wmnet8的IP設置192.168.137.207、網關192.168.137.2、DNS服務器192.168.137.2。
安裝完MySQL,可能遇到一個問題,主機與虛機間能ping通,但主機在Eclipse中訪問虛機MySQL卻發生錯誤提示:1045 access denied for user 'root'@'localhost(也可以是遠程ip地址)' (using password yes),這是因爲MySQL限制了訪問權限,只要在MySQL Workbench==>Server Administration==>localhost==>Options File==>Secuity==>勾上skip-grant-tables選項,然後重啓MySQL服務即可。
Notice:記下這個流程說明的目的並不是爲了限定開發步驟,而是爲了讓我們在宏觀上對開發思路有一個瞭解。
2、如何在項目中使用SSH框架
1)導入必要文件
TIPS:爲了便於jar包管理,若未使用ant或maven,可以在lib下建立不同文件(比如spring的jar全放在lib/spring下),然後運用Deployment Assembly進行路徑映射,使項目能夠引用到這些jar。
(1)Hibernate3.9.10:
antlr-2.7.6.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
ejb3-persistence.jar
hibernate3.jar
javassist-3.12.0.GA.jar
jta-1.1.jar
slf4j-api-1.6.4.jar
slf4j-nop-1.6.4.jar
(2)JDBC:
mysql-connector-java-5.1.23-bin.jar
(3)Spring3.2.1:
aopalliance-1.0.jar
aspectjtools.jar
spring-aop-3.2.1.RELEASE.jar
spring-aspects-3.2.1.RELEASE.jar
spring-beans-3.2.1.RELEASE.jar
spring-context-3.2.1.RELEASE.jar
spring-context-support-3.2.1.RELEASE.jar
spring-core-3.2.1.RELEASE.jar
spring-expression-3.2.1.RELEASE.jar
spring-jdbc-3.2.1.RELEASE.jar
spring-orm-3.2.1.RELEASE.jar
spring-tx-3.2.1.RELEASE.jar
spring-web-3.2.1.RELEASE.jar
(4)Struts2.3.8:
asm-3.3.jar
commons-fileupload-1.2.2.jar
commons-io-2.0.1.jar
commons-lang3-3.1.jar
commons-logging-1.1.1.jar
freemarker-2.3.19.jar
ognl-3.0.6.jar
struts2-convention-plugin-2.3.8.jar
struts2-core-2.3.8.jar
struts2-spring-plugin-2.3.8.jar
xwork-core-2.3.8.jar
2)第一個簡單的登錄應用
(1)package規劃
爲了簡化測試應用一目瞭然,全部類位於com.karlspace7.crm.test下(不過會在說明中註上實際應用中位於的package):
class User:與User.hbm.xml一同位於model包中
class UserAction:位於action包中,Action代表控制層
interface UserManager:位於manager包中,Manager代表業務邏輯層,用於分離一些中間操作的代碼(比如對用戶輸入的username、password進行去除首位空格處理)
class UserManagerImpl:位於manager包中
interface UserDAO:位於dao包中,DAO層代表數據訪問層,用於分離SQL代碼
class UserDAOImpl:位於dao包中
(2)配置文件部署
Struts是通過Filter攔截Request獲得控制權的,Spring隨項目啓動而啓動是通過Listener實現,因此部署這兩者都需要配置web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
id="WebApp_ID" version="2.5">
<!-- 上下文參數,指明配置文件所在位置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/config/*.xml</param-value>
</context-param>
<!-- Spring的核心監聽器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Struts2的核心攔截器,通過攔截Request的方式將框架融入項目 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern><!-- 指定攔截的Request格式 -->
</filter-mapping>
<!-- 將Hibernate的SessionFactory對象交由Spring管理 -->
<filter>
<filter-name>hibernateFilter</filter-name>
<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
<init-param>
<param-name>sessionFactoryBeanName</param-name>
<param-value>mySessionFactory</param-value>
</init-param>
</filter>
<display-name>MyCRM</display-name>
<welcome-file-list>
<welcome-file>index.html</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>
</web-app>
Spring配置文件applicationContext.xml
<?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: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-3.2.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
">
<!-- 數據源 -->
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://192.168.137.211:3306/mycrm"></property>
<property name="username" value="root"></property>
<property name="password" value="123321"></property>
</bean>
<!-- 對應web.xml中的mySessionFacroty,當項目啓動通過Spring創建該對象Instance,注入Handle -->
<bean id="mySessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
<prop key="show_sql">true</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/karlspace7/crm/test/User.hbm.xml</value>
</list>
</property>
</bean>
<bean id="userDAO" class="com.karlspace7.crm.test.UserDAOImpl">
<property name="sessionFactory" ref="mySessionFactory" />
</bean>
<bean id="userManager" class="com.karlspace7.crm.test.UserManagerImpl">
<property name="userDAO" ref="userDAO" />
</bean>
<bean id="userAction" class="com.karlspace7.crm.test.UserAction">
<property name="userManager" ref="userManager" />
</bean>
</beans>
Struts2配置文件struts.xml
<?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">
<struts>
<include file="struts-default.xml" />
<constant name="struts.i18n.encoding" value="UTF-8"></constant>
<package name="com.karlspace7.crm.test" namespace="/test"
extends="struts-default">
<!-- 這裏class未給定完整package,是因爲userAction已經交由Spring進行管理, -->
<action name="login" class="userAction" method="login">
<result>success.jsp</result>
<result name="login">login.jsp</result>
</action>
</package>
<!-- Add packages here -->
</struts>
由於Hibernate已經交由Spring管理,因此無需再另行配置,但hbm文件仍然需要
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.karlspace7.crm.test.User" table="test">
<id name="uId" type="java.lang.Integer">
<column name="uid"/>
<generator class="native" />
</id>
<property name="userName" type="java.lang.String">
<column name="username"/>
</property>
<property name="userPwd" type="java.lang.String">
<column name="userpwd"/>
</property>
</class>
</hibernate-mapping>
3、將數據庫更換爲Oracle
錯誤代碼:Listener refused the connection with the following error:ORA—12505,可能是因爲安裝Oracle之後IP有變動,需要更改配置文件:$ORACLEHOME/client_1/NETWORK/ADMIN中的tnsnames.ora和listener.ora
通過DataBase Configuration Assistant創建數據庫實例
有了數據庫實例,就可以在SQL Developer中建立表空間
CREATE TABLESPACE ts_mycrm
LOGGING--指明記錄創建過程
DATAFILE 'X:\ts_mycrm\ts_mycrm.ora' SIZE 5M EXTENT--必須事先存在文件夾,表空間大小爲5M
MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO;--當表空間不足,若磁盤空間有剩餘自動自增
創建完表空間,再創建臨時表空間
CREATE TEMPORARY TABLESPACE ts_temp_mycrm
LOGGING--指明記錄創建過程
TEMPFILE 'X:\ts_mycrm\ts_temp_mycrm.ora' SIZE 5M EXTENT--必須事先存在文件夾,表空間大小爲5M
MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO;--當表空間不足,若磁盤空間有剩餘自動自增
還需要創建用戶並授權
CREATE USER mycrm PROFILE DEFAULT IDENTIFIED BY "mycrm" DEFAULT TABLESPACE ts_mycrm TEMPORARY TABLESPACE ts_temp_mycrm;
刪除表空間
DROP TABLESPACE ts_mycrm INCLUDING CONTENTS AND DATAFILES;
授權
GRANT CONNECT TO mycrm;
GRANT RESOURCE TO mycrm;--CRUD操作權限統稱RESOURCE
用mycrm登錄新建表mycrm
更改項目中Spring相關配置文件:applicationContext.xml的dataSource和mySessionFactory(dialect)中兩部分。