学生请假管理系统需求分析设计文档(附待部分核心代码-ssh框架实现)._第1页
学生请假管理系统需求分析设计文档(附待部分核心代码-ssh框架实现)._第2页
学生请假管理系统需求分析设计文档(附待部分核心代码-ssh框架实现)._第3页
学生请假管理系统需求分析设计文档(附待部分核心代码-ssh框架实现)._第4页
学生请假管理系统需求分析设计文档(附待部分核心代码-ssh框架实现)._第5页
已阅读5页,还剩19页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、2014 - 2015学年 第 2 学期 1总体目标41.1背景41.1.1引言41.2要求41.3目标42.需求分析52.1功能需求描述52.1.1基本功能:52.1.2业务功能:52.2用户需求描述52.2.1学生用户需求描述52.2.2任课教师用户需求描述53.数据库设计54. 功能模块设计74.1系统流程85. 主要功能的具体实现115.1请假功能的实现115.2审核功能的实现145.3权限修改功能185.4导入功能206系统的运行环境需求216.1硬件环境:216.2.软件环境:217测试结果与分析217.1主要测试内容217.2软件测试的目的227.3软件测试的任务 227.4.1

2、功能测试227.4.2负载测试227.4.3文档测试227.5 测试环境237.6 系统具体测试238课程设计总结241总体目标1.1背景1.1.1引言目前高校大部分都还是采用学生写好请假条,然后到辅导员那里申请请假的方式进行请假,这种方式不仅麻烦而且比较费时。在信息化的今天,能有效地借助网络才能提高办事效率。因此,请假管理系统能够解决这种请假方式所带来的很多麻烦。1.2要求请假管理系统要达到以下功能:增删查改:学生信息管理(导入/查/改/删)、老师(含辅导员和系领导)信息管理业务功能:学生填写请假事由、提交给辅导员审批、按请假制度超过3天的提交给系领导审批、打印请假条、学生查看历史请假记录、

3、辅导员可按不同筛选条件查看请假记录。1.3目标请假管理系统的基本目标是方便学生请假和校方的批假工作,系统实现后,应做该到:方便学生:学生可以通过登录本系统填写请假原因向校方申请请假,不用通过手写请假条后找到导员请假。方便校方:学生在系统中申请请假后可以进入本系统进行审核,方便了校方很多请假方面的工作。2.需求分析2.1功能需求描述2.1.1基本功能:学生信息管理(导入/查/改/删)、老师(含辅导员和系领导)信息管理2.1.2业务功能:学生填写请假事由、提交给辅导员审批、按请假制度超过3天的提交给系领导审批、打印请假条、学生查看历史请假记录、辅导员可按不同筛选条件查看请假记录。2.2用户需求描述

4、2.2.1学生用户需求描述学生对本系统的主要需求是:学生填写请假理由进行请假、打印请假条、查看请假记录、修改密码。2.2.2任课教师用户需求描述校方对本系统的主要需求是:学生信息管理(导入/查/改/删)、老师(含辅导员和系领导)信息管理、对学生的请假申请进行审核、打印、和查看请假记录。3.数据库设计请假管理系统涉及到学生用户、教师用户和管理员。根据实际应用的需要,最大限度的提高系统的性能,本系统涉及到8张表,分别是管理员表、学生表、教师表、请假表、审核表、岗位表、管理员表、权限表。学生表(student):字段类型长度主键是否为空注释idint5010idstu_numvachar5000学号

5、stu_namevachar5000学生姓名stu_sexvachar5000性别stu_classvachar5000班级leava_timesint5000请假次数stu_phonevachar5000联系电话stu_yuanxivachar5000所属院系root_typevachar5000权限类型(岗位名称)教师表(teacher):字段类型长度主键是否为空注释idint 5010idtch_numvachar5000教师编号tch_namevachar5000教师姓名tch_sexvachar5000教师性别lavelvachar5000级别(辅导员,领导)yuanxivachar

6、5000所属院系tch_phonevachar5000联系电话root_typevacahr5000权限类型(岗位名称)请假表(leave):字段类型长度主键是否为空注释idint 5010idleave_numvachar5000请假流水号leave_startvachar5000请假开始时间leave_endvachar5000请假结束时间leave_daysvachar5000请假天数leave_reasonvachar5000请假原因stu_numvachar5000请假学号stu_namevachar5000学生姓名审核表(audit):字段类型长度主键是否为空注释idint5010

7、idleave_numvachar5000请假流水号audit_namevachar5000审核人audit_statusint5000审核状态audit_timevachar5000审核时间audit_posivachar5000审核岗位audit_notevachar15000批注岗位表(position):字段类型长度主键是否为空注释idint5010idposi_numvachar5000岗位编号posi_namevachar5000岗位名称管理员表(admin):字段类型长度主键是否为空注释idint 5010idadmin_numvachar5000管理员编号admin_namev

8、acahr5000管理员名字admin_phoneint1000联系电话权限表(root):字段类型长度主键是否为空注释idint5010idroot_typevachar5000权限类型(学生,辅导员,领导)root_listvachar5000权限集合root_numvachar5000权限编号4. 功能模块设计请假管理系统涉及到学生用户、教师用户和管理员,主要的功能模块为学生管理模块、教师管理模块、请假管理模块、角色管理模块。本系统的功能模块图如图:4-0图4-04.1系统流程4.1.1登陆流程:如图4-1-1图4-1-14.1.2请假流程:需要请假的学生可以在系统中填写请假条进行请假申

9、请,提交请假申请后,提交到辅导员岗进行审核,如果请假时间小于或等于3天,辅导员审核通过后生成请假记录,未通过,请假流程结束,如果请假时间大于3天,若未审核未通过则请假流程结束,若在辅导员岗审核通过,则提交到院领导岗进行审核,审核通过后生成请假记录,未通过则请假流程结束;如图4-1-2图4-1-24.1.3权限设置流程:系统管理员可以通过权限设置进行添加不同的登录角色并可以赋予不同的权限;如图4-1-3图4-1-34.1.4修改权限:系统管理员可以通过查询出系统不同用户类型的权限并可以进行各种权限的添加或者删除进行修改;如图4-1-4图4-1-45. 主要功能的具体实现5.1请假功能的实现学生在

10、需要请假时,进入系统按照要求填写好请假条的内容确认后则提交请假申请交由辅导员进行审核。如图所示:其部分代码如下:Action:/* * 保存请假条信息 * return */public String addLeave()System.out.println("请假表信息:"+leave);String username = (String) getRequest().getSession().getAttribute("username");String rootType = (String) getRequest().getSession().get

11、Attribute("rootType");leaveService.doFirstAudi(leave, username, rootType);return SUCCESS;Struct.xml:<action name="leave_*" class="com.qjglms.struts.action.LeaveAction" method="1"> <result name="success">$forwardpage</result> </ac

12、tion>LeaveServiceImpl:/* * 填写请假表(第一岗) * param leave 请假表对象 * param auditName 审核人,请假学生 * param auditPosi 审核岗位 * param auditStatus 审核状态 1-未审核, 2-已审核 , 3-审核不通过 */Overridepublic void doFirstAudi(Leave leave,String auditName,String auditPosi) System.out.println("保存请假表,生成第一岗记录-");/0-生成流水号UUID

13、uuid = UUID.randomUUID();leave.setLeaveNum(uuid.toString();/保存请假表leaveDAO.save(leave);/3-保存审核表/1.申请登记(学生自己)/(1)办结本岗,流水号、审核人、岗位名称、状态=2(已审核)Audit audit1 = new Audit();audit1.setLeaveNum(uuid.toString();audit1.setAuditName(auditName);audit1.setAuditPosi(auditPosi);audit1.setStuName(auditName);audit1.se

14、tAuditStatus(2);auditDAO.save(audit1);/(2)初始化辅导员岗位,流水号、岗位名称、状态=1(未审核)Audit audit2 = new Audit();audit2.setLeaveNum(uuid.toString();audit2.setStuName(auditName);audit2.setAuditPosi("辅导员");audit2.setAuditStatus(1);auditDAO.save(audit2);5.2审核功能的实现学生提交请假申请后,提交到辅导员岗进行审核,如果请假时间小于或等于3天,辅导员审核通过后生成

15、请假记录,未通过,请假流程结束,如果请假时间大于3天,若未审核未通过则请假流程结束,若在辅导员岗审核通过,则提交到院领导岗进行审核,审核通过后生成请假记录,未通过则请假流程结束;如图5-2-0和图5-2-1图5-1-0图5-2-1其部分代码如下LeaveAction:/* * 第二岗 * return */public String doSecond()System.out.println("审核信息+"+leave);System.out.println("审核批注+"+leave.getAuditNote();String username = (S

16、tring) getRequest().getSession().getAttribute("username");String rootType = (String) getRequest().getSession().getAttribute("rootType");leaveService.doSecond(leave, username, rootType);return null;/* * 最后一岗 * return */public String doEnd()System.out.println("院领导审核信息+"+l

17、eave);System.out.println("院领导审核批注+"+leave.getAuditNote();String username = (String) getRequest().getSession().getAttribute("username");String rootType = (String) getRequest().getSession().getAttribute("rootType");leaveService.doEnd(leave, username, rootType);return null

18、;LeaveServiceImpl:/* * 办结第二岗 * param leave 请假表对象 * param auditNote 审核批注 * param auditName 审核人 * param auditPosi 审核人 */public void doSecond(Leave leave,String auditName, String auditPosi)/(1)办结本岗,流水号、审核人、岗位名称、状态=2(已审核)int days =Integer.parseInt(leave.getLeaveDays();Audit audit1 = new Audit();audit1.s

19、etLeaveNum(leave.getLeaveNum();audit1.setAuditName(auditName);audit1.setAuditPosi("辅导员");audit1.setAuditNote(leave.getAuditNote();audit1.setAuditStatus(2);if(days<=3)/小于等于3天,成功标志设置为1audit1.setAuditEnd(1);Leave lea = new Leave();lea.setAuditName(auditName);lea.setAuditNote(leave.getAudit

20、Note();lea.setLeaveNum(leave.getLeaveNum();leaveDAO.updateLeave(lea);elseaudit1.setAuditEnd(0);auditDAO.updateByLeaveNum(audit1);if(days>3)/大于3天,生成下一岗记录Audit audit2 = new Audit();audit2.setLeaveNum(leave.getLeaveNum();audit2.setStuName(leave.getStuName();audit2.setAuditPosi("院领导");audit

21、2.setAuditStatus(1);auditDAO.save(audit2);/* * 办结最后一岗 * param leave 请假表对象 * param auditNote 审核批注 * param auditName 审核人 * param auditPosi 审核人 */public void doEnd(Leave leave,String auditName, String auditPosi)/(1)办结本岗,流水号、审核人、岗位名称、状态=2(已审核)Audit audit = new Audit();audit.setLeaveNum(leave.getLeaveNum

22、();audit.setAuditName(auditName);audit.setAuditPosi("院领导");audit.setAuditNote(leave.getAuditNote();audit.setAuditStatus(2);audit.setAuditEnd(1);Leave lea = new Leave();lea.setAuditName(auditName);lea.setAuditNote(leave.getAuditNote();lea.setLeaveNum(leave.getLeaveNum();leaveDAO.updateLeave

23、(lea);auditDAO.updateByLeaveNum(audit);5.3权限修改功能系统管理员可以通过查询出系统不同用户类型的权限并可以进行各种权限的添加或者删除进行修改;如图:图5-3图5-3其部分代码如下RoleAction:public String updateRole() throws IOExceptionSystem.out.println("更新的权限列表:"+role.getRootList();roleService.updateUser(role);setForwardpage(JSP_ROLE_LIST);tips = "修改成

24、功!"return SUCCESS;/* * 根据角色id查找权限列表返回前台设置单选框的状态 * return * throws IOException */public String findListByRootID() throws IOExceptionString rootType = role.getRootType();role = roleService.findListByRootID(rootType);System.out.println("返回数据json:"+role);return "json2"RoleServic

25、eImpl:/* * 根据rootType获取权限对象 * return Role */Overridepublic Role findListByRootID(String rootType) return roleDao.findRootListByRoottype(rootType);/* * 更新角色权限 * param role 权限对象 */Overridepublic void updateUser(Role role) Role role_1 = null;List list = roleDao.findByRootType(role.getRootType();if(list

26、.size()>0)role_1 = (Role) list.get(0);role_1.setRootList(role.getRootList();try roleDao.merge(role_1); catch (Exception e) e.printStackTrace();5.4导入功能学生、教师基本信息可以通过导入excel表格的方式进行批量添加,其部分代码如下:JSP:<form action="<%=path %>/teacher_importTchExcel.action" method="post" enct

27、ype="multipart/form-data"><a>教师信息导入 </a><br>ServiceImpl:/* * 导入教师信息表格 */public void importTchExcel(Teacher teacher,String pwd)User user = new User();user.setPassword(pwd);user.setUsername(teacher.getTchName();user.setUserNum(teacher.getTchNum();user.setRootType(teacher

28、.getRootType();userDAO.save(user);teacherDAO.save(teacher);6系统的运行环境需求6.1硬件环境:1) 内存:需要至少512MHZ2) 硬盘:40G以上6.2.软件环境:1) 操作系统:Windows XP/WIndows 7或Windows更高服务器版本2) 数据库:Mysql5.53) 浏览器:IE8.0或更高版本、Chrome浏览器等主流浏览器7测试结果与分析7.1主要测试内容 本次测试主要针对本次开发的请假管理信息系统进行系统测试主要包括功能测试、界面测试、负载测试文档测试。 7.2软件测试的目的 软件质量是由几个方面来衡量的1)

29、 在有限的时间里有效的把一个工作正确无误完成。2) 符合应用标准的要求不同地区不同国家的用户使用习惯不同项目工程中的可维护性、可测试性等要求。3) 质量就是软件达到了最开始客户所想要的需求而代码的优美或精巧的技巧并不代表软件的高质量。4) 质量也代表着它符合客户的需要。作为软件测试这个行业最重要的一件事就是从客户的需求出发从客户的角度去看产品客户会怎么去使用这个产品使用过程中会遇到什么样的问题。 7.2软件测试的目的第一是确认软件的质量能正确的完成任务其一方面是确认软件做了你所期望的事情另一方面是确认软件以正确的方式来做了这个事件。 第二是提供反馈信息比如提供给开发人员或程序经理的反馈信息为风

30、险评估所准备的信息。 7.3软件测试的任务 1) 寻找Bug 2) 避免软件开发过程中的缺陷 3) 衡量软件的品质 4) 关注用户的需求。 总的目标是:确保软件的质量 7.4测试方法 整个系统测试方法包括功能测试、负载测试、文档测试。 7.4.1功能测试 对需求规格说明书中描述的所有功能通过配置Tomcat服务器让客服端进行功能测试。测试中需要考虑恶意测试和正常的测试测试出系统的各种功能死角。 7.4.2负载测试 负载测试主要测试系统在多用户在线登陆操作时候系统的运行情况不出现系统故障。负载测试利用自动测试工具开展网络上有很多压力测试工具。 7.4.3文档测试 文档测试主要包括用户文档、需求文

31、档、设计文档测试测试主要在文档内容的正确性、准确性保证了文档的正确性才能是有效的文档准确性是精确的表达出文档的意思。采用走查的方式进行文档测试。 7.5 测试环境 7.5.1硬件环境 1) 内存:需要至少512MHZ 7.5.2软件环境 1) 作系统:Windows xp/Windows 7的服务器版本 2) 必装软件:Myeclipse9.0 Mysql5.5 Tomcat 6.0.1 7.6 系统具体测试 在此,由于版面有限,不可能将系统的每一个功能的测试都表现出来,下面是用户登录和学生添加请假单及审核功能进行测试。7.6.1用户登录测试:测试内容测试数据测试结果用户名密码输入有效数据adminadmin有效空数据空admin无效admin空无效空空无效7.6.2学生添加请假单测试:填写请假单页面:点击提交后数据库添加请假单成功:7.6.3审核功能测试:请假正常流程:学生填写请假单,然后提交给班主任,如果3天以内的请假单由班主任直接审批,3天以上的请假单,由班主任提交给院长审批,审批通过的任课老师可以查询,然后更新学生考勤未通过直接回退给学生,学生重新提交。 1) 提出假设测试 假设学生提交3天以上的请假单,如请假一周,不通过院长审批,直接由班主任审批通过,完成请假流程。3天以上的请假班主任无权限审核必须传递给院长由院长审核通过。故假设无效。 2)

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论