




已阅读5页,还剩19页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
OA办公自动化系统详细设计说明书1引言1.1编写目的 OA办公自动化系统详细设计是设计的第三个阶段,这个阶段的主要任务是在OA办公自动化系统概要设计书基础上,对概要设计中产生的功能模块进行过程描述,设计功能模块的内部细节,包括算法和详细数据结构,为编写源代码提供必要的说明。 概要设计解决了软件系统总体结构设计的问题,包括整个软件系统的结构、模块划分、模块功能和模块间的联系等。详细设计则要解决如何实现各个模块的内部功能,即模块设计。具体的说,模块设计就是要为已经产生的OA办公自动化各子系统设计详细的算法。但这并不等同于系统实现阶段用具体的语言编码,它只是对实现细节作精确的描述,这样编码阶段就可以将详细设计中对功能实现的描述,直接翻译、转化为用某种程序设计语言书写的程序。1.2背景 为了能跟上现代社会社会生活中高效率的工作节奏,根据企业需求编写了OA办公自动化系统,以达到提高企业工作效率的目的。1.3定义SQL Server 2005: 数据库管理软件Vsual Studio 2005: 开发工具OA是OFFICE AUTOMATION的缩写,本意为利用技术的手段提高办公的效率,进而实现办公的自动化处理。采用Internet/Intranet技术,基于工作流的概念,使企业内部人员方便快捷地共享信息,高效地协同工作;改变过去复杂、低效的手工办公方式,实现迅速、全方位的信息采集、信息处理,为企业的管理和决策提供科学的依据。一个企业实现办公自动化的程度也是衡量其实现现代化管理的标准。OA从最初的以大规模采用复印机等办公设备为标志的初级阶段,发展到今天的以运用网络和计算机为标志的现阶段,对企业办公方式的改变和效率的提高起到了积极的促进作用。1.4参考资料2程序系统的结构OA办公自动化管理系统登录个人空间代办事宜个人设置修改口令在线用户系统消息在线帮助日程安排领导办公系统电子邮件领导个人信息维护信息分类领导主页信息维护领导主页浏览行政办公系统会议管理督查督办值班管理接待管理信访管理专线办管理政务资源管理个人办公系统政务资源管理文件中心机关名录大事记规章制度电子论坛信息报送电子刊物电子公告图1 程序系统结构3程序1登录功能设计说明3.1程序描述改程序时OA办公自动化的入口,体现了程序的安全性 (1)功能类型:查询数据 (2)功能描述:提高系统的安全性 (3)前提业务:无 (4)后继业务:04(日程管理) (5)功能约束:权限约束 (6)操作权限:系统管理员,登录用户。3.2功能 (1)录入项检测使用javascript和后台代码实现(各项必须非空) (2)在Login.aspx.cs中只提交用户名和密码;数据处理:1.登录验证,2.记录登录用户信息3.3性能确保系统能正确运行和进行高效访问。3.4输入项表1输入项字段名称长度录入方式是否非空项数据检验默认显示管理员ID小于12文本框YN管理员密码小于12PasswordYN3.5输出项页面能正确的跳转到日程管理模块下的个人便签页面下。3.6算法1. 登录验证 UserInfo user; LoginLog log = new LoginLog(); log.UserId = txtUserId.Value; log.LoginTime = DateTime.Now; log.LoginUserIp = Request.UserHostAddress.ToString(); if (this.txtUserId.Value.Trim().Length = 0) this.Page.ClientScript.RegisterStartupScript(this.GetType(), , alert(用户名不能为空!);); txtUserId.Focus(); return; if (this.txtPassword.Value.Trim().Length = 0) this.Page.ClientScript.RegisterStartupScript(this.GetType(), , alert(密码不能为空!);); txtPassword.Focus(); return; string login = this.txtUserId.Value.ToString(); bool yes = UserInfoManager.IsUserIdExist(login); if (yes) log.LoginDesc = 用户登录失败,用户名或密码不正确。; log.IfSuccess = 0; LoginLogManager.AddLoginLog(log); this.Page.ClientScript.RegisterStartupScript(this.GetType(), , alert(用户名或密码 不正确!);); else this.Page.ClientScript.RegisterStartupScript(this.GetType(), , alert(您输入的用户名不存在,请重新输入!);); this.txtUserId.Value = ; this.txtUserId.Focus(); 2. 记录登录用户信息 UserInfo user; LoginLog log = new LoginLog();/获取用户登录名 log.UserId = txtUserId.Value;/获取登录时间 log.LoginTime = DateTime.Now; log.LoginUserIp = Request.UserHostAddress.ToString(); log.LoginDesc = 用户登录成功; log.IfSuccess = 1;/数据验证成功着将数据传入查询方法进行数据操作 LoginLogManager.AddLoginLog(log);/获取当前登录用户 SessionCurrentUser = user;/判断用户角色进行页面转换 if (user.RoleInfo.RoleId = 1) Response.Redirect(/ManualSign/ManualSign.aspx); else Response.Redirect(/ScheduleManage/PersonNote/PersonNote.aspx); 3.7流程逻辑登录提交填写内容录入项校验成功登录数据处理理登录成功功失败成功功主界面失败图2流程逻辑3.8接口本模块式系统的启动模块,他需要用户交互输入用户ID、密码;它调用系统的主控制模块。3.9存储分配表2用户信息数据表序号字段名类型长度精度小数位数默认值允许空主键说明1(UserId)管理员IDvarchar502(password)管理员密码varchar504UserName(登录用户姓名)varchar504DepartId(部门ID)int105Gender(性别)int106RoleId(角色ID)int107UserStateId(状态ID)int103.10注释设计模块首部的注释:用户验证程序。对调用函数的注释:调用加密函数MD5.3.11限制条件当系统第一次使用时,具有统一的用户ID和密码;管理员账号和*。在三次验证错误后,系统将自动关闭。3.12测试计划初次安装该系统后,测试初始用户ID和密码能否正确登录到系统;正确登陆后,对用户名和密码进行更改;采用刚修改过的用户ID和密码登陆,应该能够正确登录。3.13尚未解决的问题暂时还没有发现。4.程序2主页设计说明4.1程序描述(1)功能类型:查询、添加、修改数据(2)功能描述:按照要求对数据进行查找、添加、修改(3)前提业务:登录用户为系统管理员(4)后继业务:密码修改、重新登录、(5)功能约束:权限约束(6)操作权限:登录用户4.2功能1. 重新登录,回转到登录页面进行重新输入数据进行登录;2. 修改密码,通过Session获取当前登录用户信息,根据用户信息进行密码修改;3个人便签盒添加便签在日程管理有讲解;4.3性能能进行数据的高效访问4.4输入项表3重新登录和修改密码输入项字段名称长度录入方式是否非空项数据检验默认显示管理员ID小于12文本框YN管理员密码小于12passwordYN注:添加便签和修改便签输入项在日程管理中有说明4.5输出项个人日程信息4.6 流程逻辑1. 重新登录图3重新登录2. 修改密码 图4修改密码注:添加和修改便签在日程管理中有说明;4.7接口图5接口4.8存储分配表4用户信息数据表序号字段名类型长度精度小数位数默认值允许空主键说明1(UserId)管理员IDvarchar502(password)管理员密码varchar503UserName(登录用户姓名)varchar504DepartId(部门ID)int105Gender(性别)int106RoleId(角色ID)int107UserStateId(状态ID)int104.9注释设计1.加在模块首部的注释;2.加在各分枝点处的注释;3.对各变量的功能、范围、缺省条件等所加的注释;4.对使用的逻辑所加的注释4.10限制条件修改密码时,需先输入原始的密码,验证正确后方可进行重新设置密码的操作。4.11测试计划主要对主页设计的几个模块进行测试,用户界面测试:测试对象控件或访问入口正确,符合用户需求;界面风格统一,界面美观,直观。操作有好,人性化,易操作。4.12尚未解决的问题在文件中存储文档文件中,不能储存文件名相同,但类型不同的文档可以通过在文件名忠加入文件类型来解决。但因时间关系,尚未解决。5程序3日程管理设计说明5.1程序描述(1)功能类型:查看、添加、修改、删除数据(2)功能描述:按照要求对数据进行查查看、添加、修改并删除(3)前提业务:登录用户为系统管理员(4)后继业务:031(我的日程)032(部门日程)033(我的便签)(5)功能约束:权限约束(6)操作权限:系统管理员、一般登录用户,5.2功能1. 利用树形控件加载出功能页面的链接2. 在我的日程子模块中添加日程是在时间列表控件中点击链接进行跳转 5.3性能确保系统能高效的进行数据访问5.4输入项表5添加我的日程安排字段名称长度录入方式是否非空项数据检验默认显示我的日程主题文本框YN预约地点文本框YN开始时间文本框YN结束时间文本框YN日程内容文本框YN预约对象树形控件N是否公开复选框N表6添加便签字段名称长度录入方式是否非空项数据检验默认显示便签标题文本框YN便签内容文本框YN表7查询部门日程字段名称长度录入方式是否非空项数据检验默认显示机构名称下拉列表YN部门名称下拉列表YN姓名文本框YN时间文本框YN5.5输出项查看:显示数据库中存在的数据删除:显示删除后数据库中存在的数据添加:将数据天津啊进入数据库在显示添加后的数据信息修改:对数据库中原本存在的某条数据进行修改后在进行展示5.6算法 HyperLink link = new HyperLink(); link.ImageUrl = /images/add_Schedule.gif; link.ToolTip = 新增个人日程; link.NavigateUrl = SaveMySchedule.aspx?userid= + user.UserId + &today= + day.Date.ToShortDateString(); tc.Controls.Add(link);5.7流程逻辑1. 部门日程图6部门日程2. 我的日程图7我的日程3. 我的便签图8我的便签5.8接口图9接口5.9存储分配表8日程信息表序号字段名类型长度精度小数位数默认值允许空主键说明1ScheduleId(日程ID)Int10Y2Title(标题)varchar50Y3Address(预约地点)varchar50Y4MeetingId(会议ID)IntY5BeginTime(开始时间)datetimeN6EndTime(结束时间)datetimeN7SchContent(日程内容)varchar500Y8CreateUser(创建用户)varchar50Y9CreateTime(创建时间)datetimeN10IfPrivate(是否公开)int是Y5.10注释设计1.加在模块首部的注释;2.加在各分枝点处的注释;3.对各变量的功能、范围、缺省条件等所加的注释;4.对使用的逻辑所加的注释5.11限制条件 在界面上控制输入输出,服务器端如果出错也会也会返回出错信息5.12测试计划对日程设计进行项目跟踪测试,对输入信息和输出信息进行对比,找出其中可能出现的异常,对此进行改善。5.13尚未解决的问题暂时还没有发现6程序4系统管理设计说明6.1程序描述(1)功能类型:查看、添加、修改、删除数据 (2)功能描述:按照要求对数据进行查查看、添加、修改并删除 (3)前提业务:登录用户为系统管理员 (4)后继业务:051 角色管理 052 登陆日志 053操作日志 054 菜单排序 (5)功能约束:权限约束 (6)操作权限:系统管理员6.2功能图10功能图组织机构部门设置、用户管理、流程管理、表单管理、公文模版管理、角色管理、系统设置、系统日志、数据备份和恢复管理6.3性能系统能高效的进行数据访问和各项操作的更改6.4输入项表9输入功能图字段名称长度录入方式是否非空项数据检验默认显示角色名称文本框NN角色描述文本框YN人事管理复选框YN机构信息复选框YN部门信息复选框YN员工管理复选框YN日程管理复选框YN部门日程复选框YN我的日程复选框YN个人便签复选框YN消息传递复选框YN消息管理复选框YN信箱复选框YN系统管理复选框YN角色管理复选框NN登录日志复选框YN操作日志复选框YN菜单排序复选框YN6.5输出项角色管理:输出角色信息;登录日志:输出相应时间内的登录日志操作日志:输出相应时间内的操作日志菜单排序:输出通过上下移动后的树形菜单排序情况6.6算法1.分配角色权限中关于复选框选择的问题,怎样处理好选择一个模块时选择其下的子模块而不选中其他模块的子模块,需要使用用户自定义控件来完成,在后台代码显示方法中这样写/得到所有父级点信息 IList sysFuns = SysFunManager.GetAllParentNodeInfo(); /根据父节点得到对应子节点生成用户控件,然后循环插入到PlaceHolder容器中 foreach (SysFun sysFun in sysFuns) /得到父节点Id string nodeId = sysFun.NodeId.ToString(); /得到父节点名称 string displayName = sysFun.DisplayName; /实例化用户控件 SysManage_RoleManage_WebUserControl roleCotrol = (SysManage_RoleManage_WebUserControl)LoadControl(RoleUserControl.ascx); /实例化隐藏区域,用以存父节点Id HtmlInputHidden hidParentMeu = (HtmlInputHidden)roleCotrol.FindControl(hidParentMenu); hidParentMeu.Value = nodeId; /实例化隐藏区域,用以存储角色Id HtmlInputHidden hidRoleId = (HtmlInputHidden)roleCotrol.FindControl(hidRoleId); hidRoleId.Value = roleId.ToString(); /实例化用户控件中的CheckBox CheckBox chkParentMenu = (CheckBox)roleCotrol.FindControl(chkParentMenu); /显示父菜单名称 chkParentMenu.Text = displayName; if (arrRoleParentNodes.Contains(nodeId) chkParentMenu.Checked = true; /把父节点生成的用户控件追加打破PlaceHolder容器中 phRoleDistribute.Controls.Add(roleCotrol); 2.查看登录日志和操作日志时,开始时间和结束时间的获取使用javascript代码来实现function fillstring(str)if(str.length=1)str = 0 + str; return(str);function quickseldate(type)var begintime,endtime;var oneminute = 60*1000;var onehour = 60*oneminute;var oneday = 24*onehour;var oneweek = 7*oneday;var todayDate = new Date();var date = todayDate.getDate();var month= todayDate.getMonth() +1;var year= todayDate.getYear();var day = todayDate.getDay();if(navigator.appName = Netscape)year = 1900 + year;/-if(type=day)begintime = year.toString() + - + fillstring(month.toString() + - + fillstring(date.toString();endtime = begintime;else if(type=week)var daytoMon = day-1;if(day=0) daytoMon = 6;todayDate.setTime(todayDate.getTime()-daytoMon*oneday);date = todayDate.getDate();month= todayDate.getMonth() +1;year= todayDate.getYear();day = todayDate.getDay();begintime = year.toString() + - + fillstring(month.toString() + - + fillstring(date.toString();todayDate.setTime(todayDate.getTime()+6*oneday);date = todayDate.getDate();month= todayDate.getMonth() +1;year= todayDate.getYear();endtime = year.toString() + - + fillstring(month.toString() + - + fillstring(date.toString();else if(type=month)var dateto1 = date-1;todayDate.setTime(todayDate.getTime()-dateto1*oneday);date = todayDate.getDate();month= todayDate.getMonth() +1;year= todayDate.getYear();day = todayDate.getDay();begintime = year.toString() + - + fillstring(month.toString() + - + fillstring(date.toString();todayDate.setMonth(month);todayDate.setTime(todayDate.getTime()-oneday);date = todayDate.getDate();month= todayDate.getMonth() +1;year= todayDate.getYear();endtime = year.toString() + - + fillstring
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025版智能通风排烟系统安装与智能化改造合同文本
- 2025版智能建筑项目施工班组承包服务合同范本
- 2025版全新员工试用期入职劳动合同及福利待遇协议
- 2025年度高性能河沙资源买卖合同
- 2025年度维修保养外包服务合同
- 2025诚意金协议范本:企业项目合作诚意保证金
- 2025版石材及辅料一体化建筑施工总承包合同
- 2025房地产战略合作地产项目工程监理合同
- 2025年度WTO与全球供应链金融服务合同
- 2025年度医院食堂配餐安全责任协议书范本
- 2024骨髓移植患者营养治疗专家共识(全文)
- HGT 3652-1999(2009) 快装管接头标准规范
- 如何正确使用和佩戴劳动防护用品培训课件
- 《应收应付管理》课件
- 重症医学资质培训血流动力学监测和应用
- 《文化经济学》课件
- 《MySQL网络数据库项目化教程(新形态活页式)》 课件 3.1.1 -3.1.2创建和管理数据库
- 学校中层干部的职责和角色定位
- 《成功的八大心态》课件
- 苍天般的阿拉善合唱简谱
- QFD质量功能展开课件
评论
0/150
提交评论