每天记录学习,每天会有好心情。*^_^*
最近了解了基于Web的企业在线审批流程系统项目,在这个平台记录一下这个基于Web的企业在线审批流程系统项目,方便以后再次使用或学习的时候能够及时的翻阅。在完成基于Web的企业在线审批流程系统项目的时候,考虑了很多框架。最终决定选用SSM(MYECLIPSE),该框架具有极强的移植性,多平台性,便于操作性等优点。此框架能在MYECLIPSE开发工具中完美的编写和运行,基于Web的企业在线审批流程系统为一个 后台项目。采用当前非常流行的B/S体系结构,以JSP作为开发技术,主要依赖SSM技术框架,mysql数据库建立本系统。
在对基于Web的企业在线审批流程系统项目进行需求分析的时候,得出系统的登录角色包括了管理员、用户注册。对应用户可以通过登录自己的账号,进行入系统。系统对不同角色拥有不同权限。
总结得出基于Web的企业在线审批流程系统项目所有数据为:管理员(admin)、用户注册(yonghuzhuce)、总体设计(zongtisheji)、审批流程(shenpiliucheng)
基于Web的企业在线审批流程系统之管理员表
字段名 | 类型 | 属性 | 描述 id | INT(11) | PRIMARY KEY | 管理员id username | VARCHAR(255) | | 账号 password | VARCHAR(255) | | 密码 quanxian | VARCHAR(255) | | 权限
基于Web的企业在线审批流程系统之用户注册表
字段名 | 类型 | 属性 | 描述 id | INT(11) | PRIMARY KEY | 用户注册id xingming | VARCHAR(255) | | 姓名 nianling | VARCHAR(255) | | 年龄 xingbie | VARCHAR(255) | | 性别 zhiwu | VARCHAR(255) | | 职务 username | VARCHAR(255) | | 账号 password | VARCHAR(255) | | 密码
基于Web的企业在线审批流程系统之总体设计表
字段名 | 类型 | 属性 | 描述 id | INT(11) | PRIMARY KEY | 总体设计id xitongxuqiufenxi | VARCHAR(255) | | 系统需求分析 xitonggongnengjieshgao | VARCHAR(255) | | 系统功能介绍 xitongmokuaigongneng | VARCHAR(255) | | 系统模块功能 shejisixiang | VARCHAR(255) | | 设计思想
基于Web的企业在线审批流程系统之审批流程表
字段名 | 类型 | 属性 | 描述 id | INT(11) | PRIMARY KEY | 审批流程id faqishenpibiao | VARCHAR(255) | | 发起审批表 bumenpiyue | VARCHAR(255) | | 部门批阅 shenpijieguo | VARCHAR(255) | | 审批结果
SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- ---------------------------- -- Table structure for ggjyWebdqyzxsplcxt -- ---------------------------- 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 '密码',`quanxian` VARCHAR(255) DEFAULT NULL COMMENT '权限',PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='管理员'; -- ---------------------------- DROP TABLE IF EXISTS `t_yonghuzhuce`; CREATE TABLE `t_yonghuzhuce` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '用户注册id',`xingming` VARCHAR(255) DEFAULT NULL COMMENT '姓名',`nianling` VARCHAR(255) DEFAULT NULL COMMENT '年龄',`xingbie` 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_zongtisheji`; CREATE TABLE `t_zongtisheji` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '总体设计id',`xitongxuqiufenxi` VARCHAR(255) DEFAULT NULL COMMENT '系统需求分析',`xitonggongnengjieshgao` VARCHAR(255) DEFAULT NULL COMMENT '系统功能介绍',`xitongmokuaigongneng` VARCHAR(255) DEFAULT NULL COMMENT '系统模块功能',`shejisixiang` VARCHAR(255) DEFAULT NULL COMMENT '设计思想',PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='总体设计'; -- ---------------------------- DROP TABLE IF EXISTS `t_shenpiliucheng`; CREATE TABLE `t_shenpiliucheng` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '审批流程id',`faqishenpibiao` VARCHAR(255) DEFAULT NULL COMMENT '发起审批表',`bumenpiyue` VARCHAR(255) DEFAULT NULL COMMENT '部门批阅',`shenpijieguo` VARCHAR(255) DEFAULT NULL COMMENT '审批结果',PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='审批流程';
添加审批流程模块:
从页面中通过post方法,将审批流程信息传入到后台服务器中,在tianjiashenpiliuchengact
中接收,字段包括发起审批表,部门批阅,审批结果使用insert方法添加数据,将数据同步到
数据库中,完成添加操作。定义添加成功提示信息,添加审批流程成功,并保存到request中具体代码如下:
通过shenpiliuchengdao的insert方法将页面传输的审批流程添加到数据库中 shenpiliuchengdao.insert(shenpiliucheng);
将添加审批流程成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "添加审批流程成功");
返回审批流程管理界面
return "forward:/tianjiashenpiliucheng.action";
查询审批流程模块:
审批流程的查询模块实现方式为,在页面中发起shenpiliuchengguanli.action请求。通过该请求,响应服务器shenpiliuchengController类中的shenpiliuchengguanli,在该方法中通过selectByexample进行数据的查询操作。将所有的审批流程信息查询后,保存到request中的shenpiliuchengall中,在页面中进行展示,返回shenpiliuchengguanli.jsp,该部分核心代码如下所示:
生成审批流程样例类,通过example定义查询条件 ShenpiliuchengExample example = new ShenpiliuchengExample();
通过shenpiliuchengdao的selectByExample方法查询出所有的审批流程信息 List shenpiliuchengall = shenpiliuchengdao.selectByExample(example);
将审批流程信息,保存到request中,在页面通过foreach方法进行展示 request.setAttribute("shenpiliuchengall", shenpiliuchengall);
返回审批流程管理界面
return "forward:/shenpiliuchengguanli.action";
修改审批流程模块:
点击修改按钮,可以跳转到审批流程修改页面。在审批流程修改页面中,将初始化该审批流程的所有信息,并将信息一一对应填充到对应编辑栏中。编辑完审批流程信息后,页面通过post方法将数据封装为一个审批流程实体,传入到shenpiliuchengController中。在xiugaishenpiliucheng中进行接收,接收完毕后,调用shenpiliuchengMapper中的updateByPrimaryKeySelective方法进行修改。该部分代码如下:
通过shenpiliuchengdao的修改方法根据id修改对应的审批流程 shenpiliuchengdao.updateByPrimaryKeySelective(shenpiliucheng);
将修改审批流程成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "修改审批流程信息成功");
返回审批流程管理界面
return "forward:/shenpiliuchengguanli.action";
删除审批流程模块:
在管理页面中,点击删除。页面将通过a标签的href属性,使用get方法将该审批流程
的id上传到服务器中,在服务器中通过shenpiliuchengController类中的shanchushenpiliucheng进行接收,之后调用shenpiliuchengMapper中的deleteByPrimaryKey方法根据ID进行删除。将删除信息保存到request的message中,在页面给出用户删除成功的提示信息,该部分核心代码如下:
通过shenpiliuchengdao的删除方法根据id删除对应的审批流程 shenpiliuchengdao.deleteByPrimaryKey(id);
将删除审批流程成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "删除审批流程成功");
返回审批流程管理界面
return "forward:/shenpiliuchengguanli.action";