cotsframework的专栏

新生应用程序开发框架(JAVA)

COTS应用程序开发框架简介(二)

COTS应用程序开发简介

 

应用程序设计完成后,相应的数据层结构、业务组件和大致地展现逻辑都已经被确定。

应用程序开始开发前可先拷贝框架提供的一个Web Application的模板到应用服务器的部署目录下。然后进行下面将要介绍的三个步骤,其中数据层的建立是基础,完成后,可并行进行业务逻辑和JSP的开发,因为这两者没有直接的联系。

为方便理解和阐述,在下文中我们假设Apache Tomcat5.5web服务器,Web ApplicationContext Path/WebApp,并且所有的操作都是在本地(应用服务器所在的机器)进行。

 

数据层开发

首先根据设计阶段完成的ER图编写SQL脚本,并执行这些SQL脚本,建立所有的数据库。

然后配置blcontext-local.xml文件,对每个数据库(新建立的数据库,或者已经存在但本应用程序需要访问的数据库)配置一个DAO组件(该配置可以时JDBC配置,也可以是DataSource配置),并给每个DAO起一个有明确意义的名字。一个配置的例子如下:

    <daos>

          <dao>

               <!--name of the DAO object-->

               <name>core</name>

 

 

               <!--JDBC configuration below-->

               <!--database type, one of the oracle, sql, mysql-->

               <dbType>oracle</dbType>

 

 

               <!--<dbUser>cotsadmin</dbUser>

               <dbPassword>ZagHnJ82</dbPassword>

               <dbURL>jdbc:oracle:thin:@127.0.0.1:1521:gldnsky</dbURL>

               <driver>oracle.jdbc.driver.OracleDriver</driver>

               <dbConnections>10</dbConnections>-->

 

 

               <!--data source configuration below-->

                        <datasource xa="fasle" overrideUser="false">java:comp/env/jdbc/gldnskyJNDI</datasource>

          </dao>

     </daos>

然后启动应用服务器。打入如下URL:http://locahhost:8080/WebApp/jsp/sys/listDAOs.  我们可以看到配置的三个DAO的名字:

假设选择test后:


 

选择“创建表的系统信息”,系统将根据每个表结构的在数据字典中创建系统信息部分。创建完毕之后,选择设置表的自定义信息,出现下面的界面:


更新Test1表的自定义信息:字段的中文名,显示方式,显示顺序,是否是主键,字段的来源,引用表的名称,引用表中的字段名,系统会根据这些信息自动生成JSP代码。

最后向业务数据字典中插入两条记录,分别是,(“Test1”,”gender”,”f”,””),和(“Test1”,”gender”,”m”,””)

除可以通过COTS的开发工具来生成表信息数据词典外,还可通过应用程序com.dream.bizsdk.common.util.DataDictToolW来完成。通过命令行运行java com.dream.bizsdk.common.util.DataDictToolW,出现如下界面:

 

在输入框中输入正确的数据库用户名,密码和DBURL,点击Connect在左侧文本域中将会列出数据库下所有的数据表名,如下界面


如果没有创建过数据字典,点击Build开始自动创建过程。如果以前创建过数据字典可以点击Update按钮完成更新。点击Clear将会清空数据字典。

业务层开发

业务组件都必须直接或间接从AbstractBLC继承。COTS还提供了另外一个基类DBBLC,业务组件如果从此类继承,则将自动继承了访问数据库的功能。业务组件可以自由的调用包括DAO在内的基础组件的方法。一个简单的例子如下:

package org.redtroy.test;

 

import java.sql.SQLException;

 

import com.dream.bizsdk.common.blc.AbstractBLC;

import com.dream.bizsdk.common.databus.BizData;

public class Test extends AbstractBLC {

       public int doTest(BizData rd,BizData sd){

              String hello=rd.getString("hello");

              sd.add("hello",hello);

              try{

              int rows=coreDAO.executeQuery("select * from test","tests",rd);

              //System.out.println(rows);

              }catch(SQLException sqle){

                     sqle.printStackTrace();

              }

              return 1;

       }

}

展现层开发

       展现层除了可以调用数据对象的getter方法外,还可以调用数据字典的两个方法:DataDict.getFieldLength(String tableName,String colName),这样JSP页面中可以跟数据字典同步,当数据字典中某个字段的长度发生变化时,无需修改页面;另外一个方法是:DataDict.getCSSClass(String tableName,String colName);这个决定一个字段的类型是否是必填项和类型等相关信息。

请求配置

客户请求的名称一般情况下对应着一个formaction(不包含URL匹配的字符串,例如*.doactionCOTS框架来处理,则在配置请求时,请求的名称不包含”.do”),当客户端请求这个action时,COTS框架会根据这个客户请求的配置,决定调用什么样的业务逻辑和视图。

/WEB-INF/requests/*-reqs.xml中进行客户请求的配置,该请求将业务逻辑-视图连接在一起。请求配置好后,重新启动应用服务器,开发就完成了。

下面以一个最基本的实例来说明这个问题,客户请求的名称getCurrentRate的配置如下:

       <request>

              <name>getCurrentRate</name>

              <model name=”com.mm.Exchange.getCurrentRate”>

              <dispatch url=”” type=”forward”/>

       </request>

在一个form中以如下形式发出这个请求:

              <form action=”getCurrentRate.do” method=”post”>

                     <input type=”text” name=”moneyTypeID”>

                     ……

              </form>

那么这个form在提交的时候,由于其action以“.do”结尾,因此被匹配到COTS框架的控制器,控制器将以”.do”前面的部分,也就是getCurrentRate作为客户请求的名字,并在请求配置文件中查找这个请求的信息,然后进行相应的处理。

阅读更多
上一篇COTS应用程序开发框架简介(一)
下一篇COTS应用程序开发框架简介(三)
想对作者说点什么? 我来说一句

COTS技术展望 分类 作用

2010年01月19日 322KB 下载

没有更多推荐了,返回首页

关闭
关闭