練習CRM搭建筆記——2、SSH+MySQL&Oracle

目標:使用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)中兩部分。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章