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