COTS应用程序开发简介
应用程序设计完成后,相应的数据层结构、业务组件和大致地展现逻辑都已经被确定。
应用程序开始开发前可先拷贝框架提供的一个Web Application的模板到应用服务器的部署目录下。然后进行下面将要介绍的三个步骤,其中数据层的建立是基础,完成后,可并行进行业务逻辑和JSP的开发,因为这两者没有直接的联系。
为方便理解和阐述,在下文中我们假设Apache Tomcat5.5为web服务器,Web Application的Context 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);这个决定一个字段的类型是否是必填项和类型等相关信息。
请求配置
客户请求的名称一般情况下对应着一个form的action(不包含URL匹配的字符串,例如*.do的action由COTS框架来处理,则在配置请求时,请求的名称不包含”.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作为客户请求的名字,并在请求配置文件中查找这个请求的信息,然后进行相应的处理。