练习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)中两部分。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值