分享
 
 
 

使用JOTM为Servlets增加事务支持(3)

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

表示层:

在表示层,由两个JSP文件组成:

atm.jsp:现金支取应用,用于发送用户信息和需要支取的现金数额到bar.CashDelivery类,并显示用户操作的结果。

admin.jsp:管理控制台用于显示和更新与两个资源有关的信息。(并非程序设计的一部分,但是必须要添加以便使资源更新操作变得简单,比如向用户账户存钱)

图1 应用程序设计

配置数据库:

关于数据库,我们使用MySQL 4.0.12和附带的JDBC驱动。MySql缺省不提供事务支持,为了让其支持事务,在创建表的时候必须声明是InnoDB类型。另外,为了能够提供InnoDB类型支持,你必须将MySQL配置文件(my.cnf)中的#skip-innodb一行注释起来。

在本例中设置MySQL用户为javauser,口令为javaude,需要确认该用户已经被创建并且具有创建数据库的权限。

创建数据库和表的脚本在示例文件的scripts/目录下。运行脚本文件将会创建account表并插入两条用户记录:

john_doe账户上有100元

jane_doe账户上有600元。

示例二:创建account表

mysql> CREATE DATABASE banktest;

mysql> USE banktest;

mysql> CREATE TABLE account(

-> client VARCHAR(25) NOT NULL PRIMARY KEY,

-> money INT) TYPE=InnoDB;

mysql> INSERT INTO account VALUES("john_doe", 100);

mysql> INSERT INTO account VALUES("jane_doe", 600);

mysql> SELECT * FROM account;

+----------+-------+

| client | money |

+----------+-------+

| john_doe | 100 |

| jane_doe | 600 |

+----------+-------+

脚本文件同样会创建ATM表,并提供可以支取500元现金的记录:

示例三:创建atm表

mysql> CREATE DATABASE atmtest;

mysql> USE atmtest;

mysql> CREATE TABLE atm(

-> id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,

-> cash INT) TYPE=InnoDB;

mysql> INSERT INTO atm VALUES(null, 500);

mysql> SELECT * FROM atm;

+----+------+

| id | cash |

+----+------+

| 1 | 500 |

+----+------+

最后,你需要拷贝JDBC驱动到$Tomcat安装目录$/shared/lib目录下。

获取并安装Tomcat

本文基于Tomcat 4.1.18及以上版本编写,请确认你没有使用以前的版本,安装Tomcat并没有任何特殊之处,只需要下载并解压缩就可以了。

获取并安装JOTM

为了要使用JOTM,你必须从最新的二进制发行版下载并解压缩,从lib目录拷贝*.jar文件(除了log4j.jar、common-cli.jar和jotm_iiop_stubs.jar之外)到$Tomcat安装目录$/shared/lib目录下,一切都完成了。

配置Tomcat

你现在需要配置Tomcat以便使其能够从JNDI中获取UserTransaction和DataSource对象(用于foo.BankAccount和bar.ATM中)。

首先,告诉Tomcat在你的Web应用中会用什么JNDI名字寻找数据源。这项工作在web.xml文件中完成,下面列出了web.xml文件的内容。对于银行账户数据源,JNDI名字为java:comp/env/jdbc/bankAccount,但是你只需要给出在java:comp/env/之后的名字。Tomcat会使用JNDI机制解析余下部分的内容。对于ATM数据源也同样处理。

示例四:web.xml

<web-app>

<resource-env-ref>

<description>Bank Account DataSource</description>

<resource-env-ref-name>jdbc/bankAccount</resource-env-ref-name>

<resource-env-ref-type>javax.sql.DataSource</resource-env-ref-type>

</resource-env-ref>

<resource-env-ref>

<description>ATM DataSource</description>

<resource-env-ref-name>jdbc/ATM</resource-env-ref-name>

<resource-env-ref-type>javax.sql.DataSource</resource-env-ref-type>

</resource-env-ref>

</web-app>

现在你需要告诉Tomcat如何检索定义在web.xml中的资源,这些工作在bank.xml文件中完成,下面列出了bank.xml文件的内容。对于银行账户和ATM资源,必须设置正确的参数以便Tomcat将数据源与你的Web应用联系起来。更详细的描述可以在Tomcat JNDI How-to文档中找到。

有一个参数非常特别:factory。使用该参数设置的类会在Web应用查找JNDI时创建一个数据源。另一个在web.xml中描述的重要资源是UserTransaction。这项资源被java:comp/UserTransaction用来区分是否使用事务支持。该项资源的实现是JOTM提供的。

示例五:bank.xml

<Context path="/bank" docBase="bank.war" debug="0" reloadable="true" crossContext="true">

<!-- Description of the DataSource "jdbc/bankAccount" -->

<Resource name="jdbc/bankAccount" auth="Container" type="javax.sql.DataSource" />

<ResourceParams name="jdbc/bankAccount">

<parameter>

<!-- Factory of the DataSource -->

<name>factory</name>

<value>org.objectweb.jndi.DataSourceFactory</value>

</parameter>

<parameter>

<name>url</name>

<value>jdbc:mysql://localhost/banktest</value>

</parameter>

<!-- other parameters include:

o username - name of database user

o password - password of the database user

o driverClassName - JDBC Driver name

-->

...

</ResourceParams>

<!-- Description of the DataSource "jdbc/ATM" -->

<Resource name="jdbc/ATM" auth="Container" type="javax.sql.DataSource" />

<!-- same type of parameters than for resource "jdbc/bankAccount" -->

<ResourceParams name="jdbc/ATM">

...

</ResourceParams>

<!-- Description of the resource "UserTransaction -->

<Resource name="UserTransaction" auth="Container" type="javax.transaction.UserTransaction" />

<ResourceParams name="UserTransaction">

<parameter>

<name>factory</name>

<value>org.objectweb.jotm.UserTransactionFactory</value>

</parameter>

<parameter>

<name>jotm.timeout</name>

<value>60</value>

</parameter>

</ResourceParams>

</Context>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有