CSDN博客

img ah_cai

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

发表于2004/4/20 23:19:00  905人阅读

表示层

在表示层,由两个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.jarcommon-cli.jarjotm_iiop_stubs.jar之外)到$Tomcat安装目录$/shared/lib目录下,一切都完成了。

 

配置Tomcat

你现在需要配置Tomcat以便使其能够从JNDI中获取UserTransactionDataSource对象(用于foo.BankAccountbar.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>
0 0

相关博文

我的热门文章

img
取 消
img