Jsp课程设计企业信息管理系统设计_第1页
Jsp课程设计企业信息管理系统设计_第2页
Jsp课程设计企业信息管理系统设计_第3页
Jsp课程设计企业信息管理系统设计_第4页
Jsp课程设计企业信息管理系统设计_第5页
已阅读5页,还剩23页未读 继续免费阅读

下载本文档

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

文档简介

1、企业信息管理系统网站设计1 需求分析设计一个小型企业信息管理系统网站,实现企业基本信息的在线管理。该系统主要包括三大基本模块和六个功能扩展模块,模块简介如下:(1)用户登录模块:只有注册了的用户才可以登录系统,需要提供登录的用户名和密码即可登录系统。(2)用户注册模块:未注册的用户可以提供简单的个人信息注册成为注册用户。该模块的输入数据项包括:用户名、密码和E-mail。(3)用户退出模块:通过对该模块的调用,用户离开系统后其他人不能进行操作,提高了系统的安全性。(4)通讯录管理模块:用作当前的登录用户添加、修改、删除和查看自己的日程安排列表。输入数据项包括:姓名、性别、手机、E-mail、Q

2、Q、工作单位、地址、邮政编码。(5)短消息管理模块:用作当前的登录用户给系统内的其他用户发送短消息,并可以查看其他用户发来的消息。输入数据项包括:接收者、发送者、消息内容、发送时间、是否阅读。(6)日程安排模块:用作当前的登录用户添加、修改、删除和查看自己的日程安排列表。输入数据项包括:用户名、年份、月份、日期、安排内容。(7)工作记录模块:用作当前的登录用户添加、修改、删除和查看自己的工作日志列表。输入数据项包括:用户名、年份、月份、日期、日志标题、日志内容、记录时间。(8)公司公告模块:用户发送通知,大家都可以查看,只有发送通知的用户才有权修改、删除该通知。输入数据项包括:公告填写人、公告

3、标题、公告内容、公告时间。(9)工作会议模块:用户发送会议通知,供所有用户查看,且只有发送通知的用户才有权修改、删除该通知。输入数据项包括:会议填写人、会议开始时间、会议结束时间、会议地点、会议标题、会议内容。2 总体设计在任何一个管理信息系统中,都包含3个最基本的功能:登录、退出与注册。在这个功能的基础上,我们可扩展各种业务管理系统的功能,如图2.1所示。注册原型扩展功能登陆退出图2.1 系统基础功能状态图系统基础功能涉及三个角色:未注册用户、未登录用户、登录用户。这三种用户执行如下三种需求功能:用户登录功能、用户注册功能、用户退出功能。短消息管理通讯录管理日程安排工作记录 公司公告 工作会

4、议通信工具个人管理企业管理登录退出注册根据以上的基础功能扩展开发出一个企业信息管理系统,它包含通信工具、个人管理和企业管理三大方面。提供的功能包括:通讯录管理模块、短消息管理模块、日程安排模块、工作记录模块、公司公告模块和工作会议模块。各功能模块间的结构如图2.2所示。图2.2 功能结构图该系统采用JSP技术实现页面的设计,主要页面组成如表2.1所示:表2.1 主要页面组成表页面名称JSP页面页面名称JSP页面页面名称JSP页面登陆页面login.jsp通讯录页面address.jsp工作记录页面worklog.jsp注册页面register.jsp短消息页面sms.jsp公司公告页面noti

5、ce.jsp登陆欢迎页面welcome.jsp日程安排页面schedule.jsp工作会议页面meeting.jsp课程设计说明书3 详细设计3.1 数据库设计本系统所用到的数据库数据信息如下表所示:表3.1 数据库逻辑表表格名称说明user用户表用户信息address通讯录管理表通讯录信息sms短消息管理表短消息信息schedule日程安排表日程安排信息worklog工作记录表工作记录信息notice公司公告表公司公告信息meeting工作会议表工作会议信息表3.2用户表名称类型长度说明idint10用户编号(唯一,索引)usernamevarchar50用户名passwordvarchar

6、50用户密码emailvarchar50用户E-mail表3.3短消息管理表名称类型长度说明idint10消息编号usernamevarchar50接收者用户名sendervarchar50发送者用户名messagetext消息内容sendtimevarchar20发送时间isrendvarchar1是否已读课程设计说明书 NO.4表3.4通讯录管理表名称类型长度说明idint10记录编号usernamevarchar50录入者用户名namevarchar50联系人用户名sexvarchar10联系人性别mobilevarchar20联系人手机号码emailvarchar50联系人E-mail

7、地址qqvarchar20联系人QQ号码companyvarchar100联系人公司addressvarchar100联系人地址postcodevarchar10联系人邮编表3.5日程安排表名称类型长度说明idint10安排表编号usernamevarchar50用户名yearint4日程年份monthint2日程月份dayint2日程日期plantext日程内容表3.6公司公告表名称类型长度说明idint10公告表编号sendervarchar50公告提交人用户名titlevarchar100公告标题contenttext公告内容sendtimevarchar20公告发布时间课程设计说明书

8、NO.5表3.7 工作记录表名称类型长度说明idint10记录编号usernamevarchar50记录人员用户名yearint4工作年份monthint2工作月份dayint2工作日期titlevarchar100工作标题descriptiontext工作具体内容logtimevarchar20记录时间表3.8 工作会议表名称类型长度说明idint10会议记录编号sendervarchar50会议记录员startimevarchar20会议开始时间endtimevarchar20会议结束时间addressvarchar100会议地址titlevarchar100会议主题contenttext

9、会议内容数据库采用MySQL进行存储,其实施情况如图所示:图3.1 数据库表课程设计说明书 NO.6图3.2 user表属性 图3.3schedule表属性图3.4sms表属性图3.5 meeting表属性图3.6notice表属性 图3.7 worklog表属性3.2 动态网页设计3.2.1 MySQL参数文件db.jsp的设计由于每一个需要访问MySQL的文件都需要创建数据库连接,因此会多次访问MySQL连接的参数,为了防止多次参数的不同,我们统一了一个MySQL参数文件inc/db.jsp,该文件定义如下:沈 阳 大 学课程设计说明书 NO.73.2.2 检查用户名功能模块checkUs

10、ername.jsp的设计通过JDBC连接MySQL数据库,实现对user用户表的检查,执行的SQL语句为:select * from user where username = username取得结果集ResultSet对象后,使用next()判断是否有记录,如果有记录则该用户名就存在返回true,否则就不存在返回false,程序段如下:response.setContentType(text/xml);response.setHeader(Cache-Control,no-cache);String username = request.getParameter(username);bo

11、olean isValid = false;String sql = select * from user where username=+username+;try Class.forName(drv).newInstance();Connection conn = DriverManager.getConnection(url, usr, pwd);Statement stm = conn.createStatement();ResultSet rs = stm.executeQuery(sql);if(rs.next()isValid = true;rs.close();stm.clos

12、e();conn.close(); catch (Exception e) e.printStackTrace();out.println(e); finally if(isValid) out.println(该用户名已经存在!);elseout.println(ok);沈 阳 大 学课程设计说明书 NO.83.2.3 登陆验证功能模块login.jsp的设计该模块需要实现如下功能:l 包含数据库子文件db.jsp,以可以去的数据库的参数变量;l 使用request的getParameter()函数取得用户输入的用户名参数username和密码参数password;l 根据username和

13、password组合查询user表的SQL语句;创建数据库连接,执行SQL语句的查询,如果查询结果不为空,即rs.next()返回值为ture,则表示验证成功,否则验证失败;l 验证成功则将用户名保存在session中,并使用response.sendRedirect()跳转到欢迎页面welcome.jsp,验证失败则返回登陆页面login.jsp。该文件的代码如下:沈 阳 大 学课程设计说明书 NO.93.2.4 注册功能模块register.jsp的设计该模块需要实现以下功能:l 包含数据库子文件db.jsp,以可以取得数据库参数变量。l 使用request的getParameter()函

14、数取得用户输入的用户名参数username、密码参数password、E-mail参数emaill 创建数据库的连接,查询user表中是否存在该usernamel 如果查询结果为空,即rs.next()返回值为false,则表示不存在,否则该用户名不可重复使用。l 当用户名可用时,组合插入表user的SQL,执行一个用户的插入。l 如果执行了插入则跳转到登录页面login.jsp,否则返回注册页面register.jsp该文件的代码如下:沈 阳 大 学课程设计说明书 NO.103.2.5 通讯录管理功能模块address.jsp的设计该页面首先需要数据库参数文件db.jsp。然后取得请求参数m

15、ethod,用来决定执行什么操作。根据method的参数值决定调用的处理函数如下:l 如果method参数值为list,则调用列表函数list();l 如果method参数值为delete,则调用删除函数delete();l 如果method参数值为insert,则调用插入函数insert();l 如果method参数值为edit,则调用修改函数edit();l 如果method参数值为update,则调用更新函数update();完整的框架代码如下:jsp:forward page= / 1 ? pageNo - 1 : 1;/ 前一页int pageNextNo = pageNo page

16、Count ? pageNo + 1 : pageCount;/ 后一页request.setAttribute(pageFirstNo, pageFirstNo);request.setAttribute(pageLastNo, pageLastNo);request.setAttribute(pagePreNo, pagePreNo);request.setAttribute(pageNextNo, pageNextNo);rs1.close();/ 取得当前页数据SQLString sql2 = select * from address where username= + userna

17、me+ order by name limit + start + , + pageSize;ListHashtable list = new ArrayListHashtable();ResultSet rs2 = stm.executeQuery(sql2);ResultSetMetaData rsmd = rs2.getMetaData();int cols = rsmd.getColumnCount();while (rs2.next() / 查询每行数据的各个字段数据Hashtable hash = new Hashtable();for (int i = 1; i 沈 阳 大 学课

18、程设计说明书 NO.143.2.6 日程安排功能模块schedule.jsp的设计该模块需要实现以下功能:l 提取address表的分页数据,显示schedule.jsp页面中。l 执行address表的删除功能,删除按钮在schedule.jsp页面中。l 跳转到新增页功能,新增按钮在schedule.jsp页面中。l 执行插入address表数据的功能能,为schedule_add.jsp提交时调用。l 跳转到修改页功能,执行数据的查询,修改按钮在schedule.jsp页面中。l 执行修改address表数据的功能能,为schedule_edit.jsp提交时调用。该文件代码如下:3.2

19、.7 短消息管理功能模块sms.jsp的设计该功能模块需要完成的任务如下:沈 阳 大 学课程设计说明书 NO.17l 提取sms表的分页数据,显示在sms.jsp页面中。l 执行sms表的删除功能,删除按钮在sms.jsp页面中。l 跳转到新增页功能,新增按钮在sms.jsp页面中。l 执行插入sms表数据的功能,为sms_add.jsp提交时调用。l 执行修改sms表数据的功能,设置为已读,设置按钮在sms.jsp页面中。该文件代码如下:%String method = request.getParameter(method);/ 操作方法String topage = ./sms.jsp;/ 跳转页地址if (session.getAttribute(username) = null) topage = ./login.jsp; else String username = (String) session.getAttribute(username);/ 当前登录用户名String pageSize = request.getParameter(pageSize);/ 每页显示行数String pageNo = request.getParameter(pageNo);/ 当前显示页次if (pageSize = null) / 为空

温馨提示

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

评论

0/150

提交评论