根据用户的业务需要,制定了如下主要目标:
用户根据自己权限的不同,对权限内的文书信息进行网络登陆,查询,删除,修改等管理,查看文书的阅览情况,系统管理员根据需要对用户进行权限设置,后台数据库根据计划对数据库记录定期进行批处理,定期自动删除日志(保存期限可以自行设置),最大程度减少管理员的工作量。
1.1工作内容
本人承担的主要工作内容
Ø参与系统总体架构设计;
Ø负责实现未读新增一览,模板显示,阅览状况的设计与实现;
Ø使用Ajax异步通讯技术,实现文书新增自动提示;
Ø参与数据库设计与实现;
Ø负责后台数据库批处理的设计和实现;
Ø负责数据库日志和系统日志自动批处理的设计和实现。
1.2研究的方法和技术路线
对于该项目我们主要采取提取公共类,按功能来设计Bean并划分模块来实现。
l为多个Bean都使用的数据库连接创建一个公共类FNCD_DBConnectionFactory.class
l为系统常数定义一个公共类FNCZ_SystemConstants
l系统日志输出,SQL语句执行分别创建
FNCU_SQLExecuteUtil.java
FNCU_LogUtil.java
l为逻辑层创建多个Bean
FNOL_UserLogicBean.java
FNOL_GroupLogicBean.java
FNOL_UnreadLogicBean.java
FNOL_BBSLogicBean.java
FNOL_BBSGroupLogicBean.java
FNOL_DocumentLogicBean.java
FNOL_AttachmentLogicBean.java
l创建相应的控制器即Action
模板阅览
FNOA_ShowBBSAction.java
FNOA_ShowBBSListAction.java
文书详细
FNOA_DocumentDetailAction.java
阅览状况确认
FNOA_OpenStatusAction.java
FNOA_OpenStatusDetailAction.java
这里就不一一列举了。
l创建系统定义文件(保存系统参数,便于将来系统管理者修改)
log4j.xml
MessageResources.properties.sjis
SystemConfig.properties.sjis
SystemSQL.properties.sjis
l对于上文提到的MVC结构中,用户界面不能自动刷新的问题,该系统主要采用Ajax异步通讯技术解决,大概流程;客户端定期向服务器端发出XMLHttpRequest请求,刷新频率系统管理员可以自行设定,服务器端返回ResponseXML,使用JavaScript解析该XML,得到你想要得信息。至于使用Ajax异步通讯技术要注意的问题在以后的论文中在详细说明。
2关键技术及难点
2.1关键技术
该系统所涉及的关键技术有:
1、MVC逻辑层的设计及公共类的编写
2、Ajax异步通讯技术的运用
3、Oracle数据库中各个表的关联设计和最小程度的冗余
4、SQL语句读取数据库的效率问题
5数据库触发器和自动批处理