今天记录的项目是基于Web的文档管理系统的设计与实现,这个项目是这么回事:本文对文档管理系统进行了研究,阐述了文档管理系统的基本概念,文档管理对象,总结了文档管理系统的发展现状。详细介绍了文档管理系统的主要功能及其相关理论:查询功能、分类管理、版本管理、安全控制和文档存储等。。
做这个项目的时候,我们需要用到SSM(MYECLIPSE)框架,开发工具选用最拿手的MYECLIPSE。
基于Web的文档管理系统的设计与实现项目是一个 后台项目。
开发系统时,需求分析是必不可少的一个环节。基于Web的文档管理系统的设计与实现拥有的登录角色包括了管理员、用户。
每个账号设置身份、账号、密码是必不可少的,管理员、用户中都包含这些登录角色该有的字段。
总结得出该系统所有数据为:管理员(admin)、用户(yonghu)、查询功能(chaxungongneng)、文档存储(wendangcunchu)
管理员表
字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 管理员id
username | VARCHAR(255) | | 账号
password | VARCHAR(255) | | 密码
用户表
字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 用户id
xingming | VARCHAR(255) | | 姓名
xingbie | VARCHAR(255) | | 性别
nianling | VARCHAR(255) | | 年龄
quanxian | VARCHAR(255) | | 权限
zhiwu | VARCHAR(255) | | 职务
username | VARCHAR(255) | | 账号
password | VARCHAR(255) | | 密码
查询功能表
字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 查询功能id
zhonglei | VARCHAR(255) | | 种类
leixing | VARCHAR(255) | | 类型
文档存储表
字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 文档存储id
cunru | VARCHAR(255) | | 存入
mingzi | VARCHAR(255) | | 名字
neirong | VARCHAR(255) | | 内容
shijian | VARCHAR(255) | | 时间
zhonglei | VARCHAR(255) | | 种类
leixing | VARCHAR(255) | | 类型
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- ----------------------------
-- Table structure for ggjywebdwdglxtdsjysx
-- ----------------------------
DROP TABLE IF EXISTS `t_admin`;
CREATE TABLE `t_admin` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '管理员id',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` VARCHAR(255) DEFAULT NULL COMMENT '密码',PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='管理员';
-- ----------------------------
DROP TABLE IF EXISTS `t_yonghu`;
CREATE TABLE `t_yonghu` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '用户id',`xingming` VARCHAR(255) DEFAULT NULL COMMENT '姓名',`xingbie` VARCHAR(255) DEFAULT NULL COMMENT '性别',`nianling` VARCHAR(255) DEFAULT NULL COMMENT '年龄',`quanxian` VARCHAR(255) DEFAULT NULL COMMENT '权限',`zhiwu` VARCHAR(255) DEFAULT NULL COMMENT '职务',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` VARCHAR(255) DEFAULT NULL COMMENT '密码',PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='用户';
-- ----------------------------
DROP TABLE IF EXISTS `t_chaxungongneng`;
CREATE TABLE `t_chaxungongneng` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '查询功能id',`zhonglei` VARCHAR(255) DEFAULT NULL COMMENT '种类',`leixing` VARCHAR(255) DEFAULT NULL COMMENT '类型',PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='查询功能';
-- ----------------------------
DROP TABLE IF EXISTS `t_wendangcunchu`;
CREATE TABLE `t_wendangcunchu` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '文档存储id',`cunru` VARCHAR(255) DEFAULT NULL COMMENT '存入',`mingzi` VARCHAR(255) DEFAULT NULL COMMENT '名字',`neirong` VARCHAR(255) DEFAULT NULL COMMENT '内容',`shijian` VARCHAR(255) DEFAULT NULL COMMENT '时间',`zhonglei` VARCHAR(255) DEFAULT NULL COMMENT '种类',`leixing` VARCHAR(255) DEFAULT NULL COMMENT '类型',PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='文档存储';
添加文档存储模块:
在wendangcunchuController中定义tianjiawendangcunchuact接收页面传入的文档存储参数,定义为wendangcunchu。其中wendangcunchu包含字段:存入,名字,内容,时间,种类,类型,使用tianjiawendangcunchuact将该文档存储对象存入数据库中,在wendangcunchuMapper中定义了insert方法,匹配数据库中的insert into wendangcunchu语句实现将文档存储数据存入数据库的操作。该部分核心代码如下:
通过wendangcunchudao的insert方法将页面传输的文档存储添加到数据库中 wendangcunchudao.insert(wendangcunchu);
将添加文档存储成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "添加文档存储成功");
返回文档存储管理界面
return "forward:/tianjiawendangcunchu.action";
查询文档存储模块:
文档存储的查询模块实现方式为,在页面中发起wendangcunchuguanli.action请求。通过该请求,响应服务器wendangcunchuController类中的wendangcunchuguanli,在该方法中通过selectByexample进行数据的查询操作。将所有的文档存储信息查询后,保存到request中的wendangcunchuall中,在页面中进行展示,返回wendangcunchuguanli.jsp,该部分核心代码如下所示:
生成文档存储样例类,通过example定义查询条件 WendangcunchuExample example = new WendangcunchuExample();
通过wendangcunchudao的selectByExample方法查询出所有的文档存储信息 List wendangcunchuall = wendangcunchudao.selectByExample(example);
将文档存储信息,保存到request中,在页面通过foreach方法进行展示 request.setAttribute("wendangcunchuall", wendangcunchuall);
返回文档存储管理界面
return "forward:/wendangcunchuguanli.action";
修改文档存储模块:
在页面完成文档存储的修改信息填写后,将该部分数据传入xiugaiwendangcunchu.action地址,并通过post进行提交。提交后在wendangcunchuController中通过xiugaiwendangcunchu进行接收,将所有字段封装为一个文档存储实体。并将该实体传入wendangcunchudao中的updateByPrimaryKeySelective方法中,在该方法中定义了通过文档存储id更新其余文档存储的字段,该部分字段包括存入,名字,内容,时间,种类,类型,该部分核心代码如下所示:
通过wendangcunchudao的修改方法根据id修改对应的文档存储 wendangcunchudao.updateByPrimaryKeySelective(wendangcunchu);
将修改文档存储成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "修改文档存储信息成功");
返回文档存储管理界面
return "forward:/wendangcunchuguanli.action";
删除文档存储模块:
在页面中通过a标签,shanchuwendangcunchu?id=将id传入到后台中,通过shanchuwendangcunchu接收文档存储id。使用deleteByid的方法
删除该文档存储,完成删除操作。定义删除成功提示信息,删除文档存储成功,并保存到request中,该部分代码如下:
通过wendangcunchudao的删除方法根据id删除对应的文档存储 wendangcunchudao.deleteByPrimaryKey(id);
将删除文档存储成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "删除文档存储成功");
返回文档存储管理界面
return "forward:/wendangcunchuguanli.action";