手动添加SSH支持、使用c3p0

之前做的笔记,现在整理一下;大家有耐心的跟着做就能成功;

SSH(struts2、spring、hibernate)

*  struts2

*  充当mvc的角色

*  hibernate

dao层用hibernate技术来实现

*  spring

*  spring的声明式事务管理

*  应用spring的IOC和di做到完全的面向接口编程

先添加一个数据库做测试用:使用的是mysql5.0

create database testoa default character set utf8;

show create database testoa;

1.新建一个Web Project项目 TestSSH

2.添加Struts2支持:添加jar包

struts-2.1.8.1/apps/struts2-blank-2.1.8.1.war/WEB-INF/lib 下的所以jar包

struts2-core.jar  核心jar包

xwork-2.jar  xwork核心jar包

ognl.jar  ognl表达式

freemarker.jar  FreeMarker模板

commons-logging.jar  日志

commons-fileupload.jar  文件上传

commons-io.jar  文件上传依赖的包

配置文件:

配置Strut2的主过滤器:   将struts-2.1.8.1/apps/struts2-blank-2.1.8.1.war/WEB-INF/web.xml下的下面内容复制到项目的web.xml下:

<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>
	</filter-mapping>

拷贝Strut2的主配置文件:

在struts-2.1.8.1/apps/struts2-blank-2.1.8.1.war/WEB-INF/classes/struts.xml下,

拷贝到工程的src目录下

修改几个基本的配置:

<struts>
	<!-- 配置问开发模式( 显示信息 和 配置文件修改后不需要重启) -->
    <constant name="struts.devMode" value="true" />
	<!-- 配置扩展名为action -->
	<constant name="struts.action.extension" value="action" />
</struts>

Struts2的环境添加完了;

3.添加Hibernate支持

添加jar包:

核心jar包hibernate-distribution-3.6.0.Final/hibernate3.jar ;

hibernate-distribution-3.6.0.Final/lib/ required下的所有包:

还有hibernate-distribution-3.6.0.Final/lib/jpa/ hibernate-jpa-2.0-api-1.0.0.Final.jar;

还有hibernate-distribution-3.6.0.Final/lib/ optional /c3p0/ c3p0-0.9.1.jar;

还有数据库驱动:F:\快盘\JAVA\jdbc\ mysql-connector-java-5.1.5-bin.jar ;

添加配置文件:

主配置文件模版:

hibernate-distribution-3.6.0.Final/ project/ etc/ hibernate.cfg.xml 拷贝到项目的src下;

添加基本的配置:

<hibernate-configuration>
	<session-factory>

		<!-- 数据库信息(连接信息写到spring的配置文件中) -->
		<!-- 方言 -->
		<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
		<property name="connection.url">jdbc:mysql:///testoa</property>
		<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="connection.username">root</property>
		<property name="connection.password">jerome</property>

		<!-- 其他配置 -->
		<property name="show_sql">true</property>
		<property name="hbm2ddl.auto">update</property>

	</session-factory>
</hibernate-configuration>

映射文件的模版:User.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.hqu.oa.domain">

	<class name="User" table="hqu_user">
		<id name="id">
			<generator class="native" />
		</id>
		<property name="name" />
	</class>
</hibernate-mapping>

(在hibernate-distribution-3.6.0.Final/ project 下搜索 *.hbm.xml

随便选一个符合条件的就可以,拷贝到项目src下;)

添加Spring支持:

添加jar包:

Spring核心包:

spring-framework-2.5.6-with-dependencies.zip/spring-framework-2.5.6/dist/spring.jar ;

依赖的:

日志:

lib/jakarta-commons/ commons-logging.jar ;

面向切面编程(AOP)用到的:(

/lib/ aspectj/ aspectjrt.jar和aspectjweaver.jar

和生成代理用的:

ib/cglib/cglib-nodep-2.1_3.jar ; )

还有一个可加的做MD5加密的 这里面有工具类:

/lib/ jakarta-commons/ commons-codec.jar ;

配置文件:

( F:\Java\spring-framework-2.5.6\samples\imagedb\war\WEB-INF下的applicationContext.xml

拷贝到src,)新建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:context="http://www.springframework.org/schema/context"
		xmlns:tx="http://www.springframework.org/schema/tx"
		xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
				http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
				http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
	<!-- 自动扫描与装配bean -->
	<context:component-scan base-package="com.hqu.oa"></context:component-scan>

</beans>

到此都添加ssh完了,接下去开始整合:SSH整合:

先Spring和Hibernate整合:

Spring来管理事务,管理sessionFactory applicationContext.xml 做如下配置:

<!-- 自动扫描与装配bean -->
	<context:component-scan base-package="com.hqu.oa"></context:component-scan>

	<!-- 加载外部的properties配置文件 -->
	<context:property-placeholder location="classpath:jdbc.properties" />

	<!-- 配置数据库连接池(c3p0) -->
	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<!-- 基本信息 -->
		<property name="jdbcUrl" value="${jdbcUrl}"></property>
		<property name="driverClass" value="${driverClass}"></property>
		<property name="user" value="${username}"></property>
		<property name="password" value="${password}"></property>
		<!-- 其他配置 -->
		<!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
		<property name="initialPoolSize" value="3"></property>
		<!--连接池中保留的最小连接数。Default: 3 -->
		<property name="minPoolSize" value="3"></property>
		<!--连接池中保留的最大连接数。Default: 15 -->
		<property name="maxPoolSize" value="5"></property>
		<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->
		<property name="acquireIncrement" value="3"></property>
		<!-- 控制数据源内加载的PreparedStatements数量。如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0 -->
		<property name="maxStatements" value="8"></property>
		<!-- maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->
		<property name="maxStatementsPerConnection" value="5"></property>
		<!--最大空闲时间,1800秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
		<property name="maxIdleTime" value="1800"></property>
	</bean>

	<!-- 配置SessionFactory -->
	<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		<property name="dataSource" ref="dataSource"></property>
		<property name="configLocation" value="classpath:hibernate.cfg.xml"></property>
	</bean>

	<!-- 配置声明式的事务管理(采用基于注解的方式) -->
	<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
		<property name="sessionFactory" ref="sessionFactory"></property>
	</bean>
	<tx:annotation-driven transaction-manager="transactionManager" />

在src创建jdbc.properties文件 内容为:

jdbcUrl = jdbc:mysql:///testoa

driverClass = com.mysql.jdbc.Driver

username = root

password = jerome

这时,hibernate.cfg.xml下的数据连接信息就可以注释了:

测试:

创建SpringTest类 com.hqu.oa.test 下;

代码如下:

	private ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");

	//测试SessionFactory管理是否正确
	@Test
	public void testSessionFactory() throws Exception {
		SessionFactory sessionFactory = (SessionFactory) ac.getBean("sessionFactory");
		System.out.println(sessionFactory);
	}

	//测试事务
	@Test
	public void testTransaction() throws Exception {

	}

单元测试运行如下:

[email protected]

说明成功;

测试事务:

添加Service: TestService在com.hqu.oa.test 下;

添加一个User实体:User在com.hqu.oa.domain下 :

	private Long id;
	private String name;

	public Long getId() {
		return id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

写映射文件:

将之前的*.hbm.xml拷贝到com.hqu.oa.domain下:

改名为 User.hbm.xml :

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.hqu.oa.domain">

	<class name="User" table="hqu_user">
		<id name="id">
			<generator class="native" />
		</id>
		<property name="name" />
	</class>
</hibernate-mapping>

在hibernate.cfg.xml 导入映射文件:

<!-- 导入映射文件 -->

<mapping resource="com/hqu/oa/domain/User.hbm.xml" />

在TestService 中保存两个用户:

@Service("testService")
public class TestService {
	@Resource
	private SessionFactory sessionFactory;

	@Transactional
	public void saveTwoUsers() {
		Session session = sessionFactory.getCurrentSession();
		session.save(new User());
		//int a = 1 / 0;//这里会抛异常
		session.save(new User());
	}
}

在SpringTest单元测试:

//测试事务
	@Test
	public void testTransaction() throws Exception {
		TestService testService = (TestService) ac.getBean("testService");
		testService.saveTwoUsers();
	}

testService 就是上面的 @Service("testService") ;

测试成功;控制台输出两条插入的语句

再测试 : 将TestService 的异常代码打开

单元测试运行,查看数据库没新数据,说明事务成功;

Spring和Hibernate整合完成;

Spring和Struts2整合:

整合之前写一个action 和整合之后做对比:

创建action TestAction在com.hqu.oa.test下:

public class TestAction extends ActionSupport {
	@Override
	public String execute() throws Exception {
		System.out.println("---->>>TestAction.execute()");
		return "success";
	}
}

在struts.xml配置文件配置:

<package name="default" extends="struts-default" namespace="/">
		<!-- 测试用的action -->
		<action name="test" class="com.hqu.oa.test.TestAction">
			<result name="success">/index.jsp</result>
		</action>
</package>

部署,启动tomcat 浏览器输入:http://localhost:8080/TestSSH/test.action

控制台输出:---->>>TestAction.execute()

说明action成功;

接下来做Spring和Struts2整合:

添加F:\Java\struts\struts-2.2.1\lib下的struts2-spring-plugin-2.2.1.jar;

这样就自动整合了 做如下配置:

在web.xml配置spring监听器:用于在应用程序启时初始化

ApplicationContext对象。

	<!-- 配置Spring的监听器,用于初始化ApplicationContext对象 -->
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>
	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>classpath:applicationContext*.xml</param-value>
	</context-param>

在TestService上加上注解:

@Controller
@Scope("prototype") //多例
public class TestAction extends ActionSupport {
	@Override
	public String execute() throws Exception {
		System.out.println("---->>>TestAction.execute()");
		return "success";
	}
}

修改struts.xml文件:

	<package name="default" namespace="/" extends="struts-default">
		<!-- 测试用的action,当与Spring整合后,class属性写的就是Spring中bean的名称 -->
		<action name="test" class="testAction">
			<result name="success">/test.jsp</result>
		</action>
	</package>

重动 tomcat 测试,成功;

Spring和Struts2整合成功;

三个框架一起用:

在action调用Service:

在 TestAction下:

@Controller
@Scope("prototype")//多例
public class TestAction extends ActionSupport {
	@Resource
	private TestService testService;

	@Override
	public String execute() throws Exception {
		System.out.println("---->>>TestAction.execute()");
		testService.saveTwoUsers();
		return "success";
	}
}

重启tomcat,事务也管用,成功;完成;

工作量好大~

手动添加SSH支持、使用c3p0

时间: 2024-10-15 01:34:22

手动添加SSH支持、使用c3p0的相关文章

手动加入SSH支持、使用c3p0

之前做的笔记,如今整理一下.大家有耐心的跟着做就能成功: SSH(struts2.spring.hibernate) *  struts2 *  充当mvc的角色 *  hibernate dao层用hibernate技术来实现 *  spring *  spring的声明式事务管理 *  应用spring的IOC和di做到全然的面向接口编程 先加入一个数据库做測试用:使用的是mysql5.0 create database testoa default character set utf8;

本地添加maven支持

第一步:添加maven支持,去Apache maven官网下载maven, 解压 在conf文件夹里有个settings.xml,这个是需要自己配置的,不然的话也会有默认,只是那样的话会在C盘了,不喜欢放在C盘,那么问题来了,需要设置的有: localRepository:表示本地库的保存位置,也就是maven2主要的jar保存位置,默认在${user.dir}/.m2/repository,如果需要另外设置,就换成其他的路径. <localRepository>D:\Develop\mave

添加SSH密钥到GitHub

$ clip < ~/.ssh/id_rsa.pubbash: /c/Users/huangxi/.ssh/id_rsa.pub: No such file or directory [转]Generating SSH keys 生成 SSH 密钥 Step 1.检查本机现有的SSH密钥 检查~/.ssh看看是否有名为d_rsa.pub  和id_dsa.pub的2个文件.如果你什么都没得到这些文件,转到  步骤2 ;否则,请跳到  第3步. 打开你的Git Bash,输入: $ ls -al

s3c2440 移植linux内核 添加网卡支持 yaffs2文件系统支持

三.内核的移植 说明:针对的是百问网的jz2440 gcc:4.9.1 1.移植内核 首先,下载源码包:https://www.kernel.org/ 现在时间为2014年12月20日其主界面截图为: 在此,就在下较新的稳定的版本作为尝试.在这里有个命名问题需要说明一下,最前面的2.6或者3.18是主版本号码,后面的次版本号是比如2.6.32.65中的32,再后面的比如2.6.32.65中的65是升级版本号,主版本号为奇数的是开发本比如3.17,主版本号为偶数的为稳定版比如3.18,一般情况下名

Provisioning Services 7.8 入门系列教程之六 手动添加设备

续Provisioning Services 7.8 入门系列教程之五 使用Provisioning Services控制台 目前,Provisioning Services 7.8 支持三种添加设备的方式,即手动添加.批量导入和自动添加. 设备,我们可以简单理解就是一台计算机,可能是一台无硬盘.安装有网卡(支持或者不支持PXE启动)的计算机. 设备集合:可以理解为具有某些共同特性(如使用相同虚拟磁盘,相同操作系统)的一些设备,在实际生产环境中,为了便于管理,用户可以根据客户的使用情况(如操作系

iOS 自己手动添加编译警告

文/青花瓷的平方(简书作者)原文链接:http://www.jianshu.com/p/b2e30cad2a0d著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 缘由 上一次生产环境我们出现重大bug,因ApplePay上线,其中有一个宏文件我同事忘记加版本控制,测试也没测试(因为是小版本,applepay还未开放),导致线上一天崩溃近万次,多亏了jspatch,用热修复解决了此问题.那么问题来了,怎么让开发人员提前看到编译警告呢,以至于不犯这种低级错误. 解决 1.xcodebu

仅仅需手动添加一行代码就可以让Laravel4执行在SAE (v. 1.0.0)

Github:https://github.com/chariothy/laravel4-sae (已更新至v1.1.0) laravel4-sae (v. 1.0.0) 仅仅需手动添加一行代码就可以让Laravel4(~4.2)执行在SAE,并且在本地和在SAE开发无需命令切换,自己主动推断环境并切换配置. 安装 在SAE安装Laravel 在SAE安装Laravel与本地环境安装稍有差别: 在SAE的"应用管理"中新建一个没有代码的应用.比方叫project-name(这里面仅仅是

IOS 手动添加第三方库报错问题

当不想使用CocoaPods来管理和使用第三方库的时候,就需要手动添加和配置这些第三方库,难免会出现一些问题,主要问题汇总如下: 1.AFNetworking.NKNetWork.ZxingObjC等第三方库为了支持低版本的系统(IOS 5,6)会出现不能编译如下代码 @property (nonatomic, strong)dispatch_queue_t 这是因为,当IOS SDK版本>=6.0时,ARC会管理GCD对象,当IOS SDK版本<6.0时,GCD是需要手动管理的,兼容则需要写

为项目添加CUDA支持

最近研究体绘制方面的东西,需要用到CUDA加速.从官网下载了CUDA 7.0(支持VS2013)装好后,VS2013中能直接创建CUDA项目,也可以在原有项目中添加cu文件. 进入正题,为已有项目添加CUDA支持,网上能搜到的多数都是针对VS2010的办法,然而我用的是VS2013,跟VS10版本略有不同. 先给出VS2010的方法,这个也是官方介绍的方法: 在项目上右键--生成自定义... 弹窗中选择相应版本的CUDA 之后打开项目的属性,即可看到CUDA C++了 里面的参数一般不用改,如果