欢迎来到三一文库! | 帮助中心 三一文库31doc.com 一个上传文档投稿赚钱的网站
三一文库
全部分类
  • 研究报告>
  • 工作总结>
  • 合同范本>
  • 心得体会>
  • 工作报告>
  • 党团相关>
  • 幼儿/小学教育>
  • 高等教育>
  • 经济/贸易/财会>
  • 建筑/环境>
  • 金融/证券>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 三一文库 > 资源分类 > DOC文档下载  

    软件工程大型实验课程设计说明书-大学自动排课算法设计与实现系统——登陆及用户管理子系统.doc

    • 资源ID:9398939       资源大小:910KB        全文页数:36页
    • 资源格式: DOC        下载积分:6
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录   微博登录  
    二维码
    微信扫一扫登录
    下载资源需要6
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    软件工程大型实验课程设计说明书-大学自动排课算法设计与实现系统——登陆及用户管理子系统.doc

    中北大学课 程 设 计 说 明 书软件工程大型实验学生姓名:史东海学 号:0706054208学 院:电子与计算机科学技术学院专 业:软件工程题 目:大学自动排课算法设计与实现系统登陆及用户管理子系统成绩指导教师: 职称: 讲师 2010 年 1 月 21 日351.设计目的该系统并不是所有人都能随便使用的。系统应该有不同的权限用于排课和课表的查询,通过登陆可以解决权限问题。而用户是会经常变动的(比如毕业生的离校),所以需要对用户进行相应的管理(如添加、删除及密码的修改),所以需要实现用户管理功能。2.设计内容在整个系统中本人主要负责登陆和用户管理功能的实现,同时也参加算法的设计与实现。本系统要涉及到管理人员、教师、学生三个不同的参与者,有两个不同的权限。管理员可以录入教师、教室、班级等基本的信息然后进行排课,而教师和学生只具有查询课表的权限。所以在登录的时候要把不同的权限划分出来。程序在设计好后数据库中有一个默认的管理员的用户名和密码,通过该用户名和密码可以登陆系统,然后通过用户管理模块可以添加教师、学生或管理员。为了防止用户忘记密码,管理员可以在不知道原始密码的情况下修改用户的密码。而教师或学生若想修改自己的密码必须输入旧密码。3.需求描述图1 登陆及用户管理子系统用例图用例描述如下:表1 UserManagement用例描述表用例编号UC00用例名称UserManagement用例概述实现用户的添加、删除及密码修改主参与者管理员次要参与者教师、学生前置条件用户成功登陆后置条件显示出添加、修改用户及密码修改的子菜单基本事件流1.用户点击用户管理菜单项2.用户管理菜单项显示添加用户、删除用户、修改密码三个子菜单扩展事件流无表2 Login用例描述表用例编号UC01用例名称Login用例概述用户输入账号和密码登陆主参与者管理员、教师、学生次要参与者无前置条件用户打开应用程序后置条件登陆失败时显示登陆失败信息,成功时进入系统基本事件流1.用户输入用户信息2.用户合法则进入系统扩展事件流用户不合法时,则提示登陆失败消息表3 AddUser用例描述表用例编号UC000用例名称AddUser用例概述实现用户的添加主参与者管理员次要参与者无前置条件管理员成功登陆,并点击了添加用户菜单项后置条件弹出添加用户对话框,输入用户名及密码基本事件流1.管理员点击添加用户菜单项2.管理员输入用户名、密码并选择所添加用户的身份,点击确定扩展事件流1.若用户存在则提示“用户名已存在”2.若没有选择用户身份则提示“请选择用户身份”3.若用户不存在且两次输入密码不同则提示“两次输入密码不同”4.若用户名不存在且两次输入密码相同并选择了身份,则给出“添加成功”提示表4 DeleteUser用例描述表用例编号UC001用例名称DeleteUser用例概述实现用户的删除主参与者管理员次要参与者无前置条件管理员成功登陆,并点击了删除用户菜单项后置条件弹出删除用户对话框,输入用户名及密码基本事件流1.管理员点击删除用户菜单项2.管理员输入用户名及密码,点击确定扩展事件流1.若用户名或密码错误则给出相应的提示2.若用户名和密码正确则提示删除成功表5 ModifyPassword用例描述表用例编号UC002用例名称ModifyPassword用例概述实现用户密码的修改主参与者管理员、教室、学生次要参与者无前置条件用户成功登陆,并点击密码修改菜单项后置条件弹出密码修改对话框,输入用户名及密码基本事件流1.用户点击密码修改菜单项2.用户输入用户名及密码,点击确定扩展事件流1.若用户名或旧密码错误则给出相应的提示2.若用户名和密码正确则提示修改成功4.系统详细分析设计 4.1顺序图(1)登陆顺序图:图2 登陆顺序图登陆首先输入用户名和密码,然后程序到数据库中查询用户名是否存在,密码是否正确,如果正确则登陆成功;不正确登陆失败,可以继续登陆或关闭登陆窗口。(2)添加用户顺序图:图3 添加用户顺序图 管理员输用户名、密码和确认密码。如果数据库对应表中有所输入的用户名则给出提示;没有则比较两次输入密码是否相同,相同条件成功;不同则给出相应提示。删除用户顺序图:图4 删除用户顺序图管理员输入用户名和密码。如果数据库中不存在所输入的用户名则给出相应提示;存在则检查密码是否匹配,匹配则删除成功;不匹配则删除失败。修改密码顺序图:图5 修改密码顺序图 用户输入用户名、旧密码(非管理员输入)、新密码。程序检查数据库中所输入用户名是否存在,不存在则给出提示;存在则检查旧密码(非管理员)是否匹配,不匹配则给出提示;匹配则检查新密码是否为空,为空则给出提示;不为空则修改表中数据,密码修改成功。4.2 活动图登陆活动图:图6 登陆活动图 登陆首先输入用户名和密码,然后程序到数据库中查询用户名是否存在,密码是否正确,如果正确则登陆成功;不正确登陆失败,可以继续登陆或关闭登陆窗口。添加用户活动图:图7 添加用户活动图 管理员输用户名、密码和确认密码。如果数据库对应表中有所输入的用户名则给出提示;没有则比较两次输入密码是否相同,相同条件成功;不同则给出相应提示。删除用户活动图:图8 删除用户活动图管理员输入用户名和密码。如果数据库中不存在所输入的用户名则给出相应提示;存在则检查密码是否匹配,匹配则删除成功;不匹配则删除失败。修改密码活动图:图9 修改密码活动图 用户输入用户名、旧密码(非管理员输入)、新密码。程序检查数据库中所输入用户名是否存在,不存在则给出提示;存在则检查旧密码(非管理员)是否匹配,不匹配则给出提示;匹配则检查新密码是否为空,为空则给出提示;不为空则修改表中数据,密码修改成功。4.3类图图10 登陆及用户管理模块类图 本系统有五个类,分别是Login、UserManagement、AddUser、DeleteUser和ModifyPassword,其中AddUser、DeleteUser、ModifyPassword是UserManagement的泛化。4.4部署图图11 登陆及用户管理模块部署图系统通过应用服务器与数据库连接,可分为四个模块,都可以单独编译执行。四个模块的所有动作都需要连接到数据库并查询。4.5构件图图12 登陆及用户管理模块构件图本人将此系统分成了四个模块,分别是登录、添加用户、删除用户和修改密码。在这四个子系统中,程序都是独立编写,每个程序之间通过对类的调用实现的联系。4.6 数据库表表6 教师信息表字段名称中文含义字段类型长度是否为空备注Username教师用户名Char20否主键Password教师密码Char20否表7 学生信息表字段名称中文含义字段类型长度是否为空备注Username学生用户名Char20否主键Password教师密码Char20否表8 管理员信息表字段名称中文含义字段类型长度是否为空备注Username管理员用户名Char20否主键Password管理员密码Char20否5.系统实现5.1开发工具及系统运行环境 开发工具:Java运行平台(JDK 1.6.0_17)、MyEclipse、Microsoft Office Access 2003。 运行环境:装有Java运行平台的任何PC机。5.2 登陆及用户管理子系统实现登陆模块伪代码如下: Username=textfield.getText(); Password=textfield2.getText(); if(signA=true) try rs=sql.executeQuery("SELECT * FROM guanliyuan"); while(rs.next() getUsername=rs.getString(1); getPassword=rs.getString(2); if(getUsername.equals(Username)&&getPassword.equals(Password) this.dispose(); ClassroomSchedulerFrame win=new ClassroomSchedulerFrame("大学自动排课系统"); sign1=true; break; if(sign1=false) JOptionPane.showMessageDialog(this,"用户名或密码错误,请重新输入","信息提示",JOptionPane.WARNING_MESSAGE); textfield2.setText(null); catch(SQLException ee) System.out.println(""+ee); else if(signT=true) try rs=sql.executeQuery("SELECT * FROM teacher"); while(rs.next() getUsername=rs.getString(1); getPassword=rs.getString(2); if(getUsername.equals(Username)&&getPassword.equals(Password) this.dispose(); ClassroomSchedulerFrame win=new ClassroomSchedulerFrame("大学自动排课系统"); sign2=true; break; if(sign2=false) JOptionPane.showMessageDialog(this,"用户名或密码错误,请重新输入","信息提示",JOptionPane.WARNING_MESSAGE); textfield2.setText(null); catch(SQLException ee) System.out.println(""+ee); else if(signS=true) try rs=sql.executeQuery("SELECT * FROM student"); while(rs.next() getUsername=rs.getString(1); getPassword=rs.getString(2); if(getUsername.equals(Username)&&getPassword.equals(Password) this.dispose(); ClassroomSchedulerFrame win=new ClassroomSchedulerFrame("大学自动排课系统"); sign3=true; break; if(sign3=false) JOptionPane.showMessageDialog(this,"用户名或密码错误,请重新输入","信息提示",JOptionPane.WARNING_MESSAGE); textfield2.setText(null); catch(SQLException ee) System.out.println(""+ee); 登陆模块窗口图如下:图13 登陆窗口图 登陆界面是运行排课程序或查课的入口,只有成功登陆才能做相应的一些操作。当选择管理员、教师、学生不同身份登陆者的时候程序会到相应的表中查找用户名和密码,如果存在对应用户并且密码正确则登陆成功,进入系统;如果用户名或密码不正确则登陆失败并给出相应的错误提示。添加用户的伪代码如下:Username=textfield.getText(); Newpassword=textfield1.getText(); Newpassword2=textfield2.getText(); if(signA=true) try rs=sql.executeQuery("SELECT * FROM guanliyuan"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); if(getUsername.equals(Username) JOptionPane.showMessageDialog(this,"用户名已存在!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; if(Newpassword.equals(Newpassword2)&&sign=false) if(Username.equals("")&&Newpassword.equals("") JOptionPane.showMessageDialog(this,"用户名和密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else if(Username.equals("") JOptionPane.showMessageDialog(this,"用户名不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else if(Newpassword.equals("") JOptionPane.showMessageDialog(this,"密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else sql.executeUpdate("INSERT INTO guanliyuan VALUES("+Username+","+Newpassword+")"); this.dispose(); JOptionPane.showMessageDialog(this,"添加成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; else if(sign=false) JOptionPane.showMessageDialog(this,"两次输入密码不同!请重新输入!","信息提示",JOptionPane.WARNING_MESSAGE); catch(SQLException ee) System.out.println(""+ee); sign=false; if(signT=true) try rs=sql.executeQuery("SELECT * FROM teacher"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); if(getUsername.equals(Username) JOptionPane.showMessageDialog(this,"用户名已存在!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; if(Newpassword.equals(Newpassword2)&&sign=false) if(Username.equals("")&&Newpassword.equals("") JOptionPane.showMessageDialog(this,"用户名和密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else if(Username.equals("") JOptionPane.showMessageDialog(this,"用户名不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else if(Newpassword.equals("") JOptionPane.showMessageDialog(this,"密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else sql.executeUpdate("INSERT INTO teacher VALUES("+Username+","+Newpassword+")"); this.dispose(); JOptionPane.showMessageDialog(this,"添加成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; else if(sign=false) JOptionPane.showMessageDialog(this,"两次输入密码不同!请重新输入!","信息提示",JOptionPane.WARNING_MESSAGE); catch(SQLException ee) System.out.println(""+ee); sign=false; if(signS=true) try rs=sql.executeQuery("SELECT * FROM student"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); if(getUsername.equals(Username) JOptionPane.showMessageDialog(this,"用户名已存在!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; if(Newpassword.equals(Newpassword2)&&sign=false) if(Username.equals("")&&Newpassword.equals("") JOptionPane.showMessageDialog(this,"用户名和密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else if(Username.equals("") JOptionPane.showMessageDialog(this,"用户名不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else if(Newpassword.equals("") JOptionPane.showMessageDialog(this,"密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); else sql.executeUpdate("INSERT INTO student VALUES("+Username+","+Newpassword+")"); this.dispose(); JOptionPane.showMessageDialog(this,"添加成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; else if(sign=false) JOptionPane.showMessageDialog(this,"两次输入密码不同!请重新输入!","信息提示",JOptionPane.WARNING_MESSAGE); catch(SQLException ee) System.out.println(""+ee); sign=false; else if(signC=false) JOptionPane.showMessageDialog(this,"请选择要添加用户的身份!","信息提示",JOptionPane.WARNING_MESSAGE); 添加用户模块窗口图如下:图14 添加用户窗口图添加用户模块可以向数据库中对应的表中添加新的用户。当选择添加不同身份的用户的时候程序会到相应的表中查找所添加的用户是否存在,如果存在则给出对应提示;如果不存在则检查两次输入的密码是否相同,如果相同则添加成功,不同则给出错误提示。删除用户模块伪代码如下:Username=textfield.getText(); Password=textfield1.getText(); try rs=sql.executeQuery("SELECT * FROM guanliyuan"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); getPassword=rs.getString(2); if(getUsername.equals(Username)&&getPassword.equals(Password) sql.executeUpdate("DELETE FROM guanliyuan WHERE name = "+Username+" "); this.dispose(); JOptionPane.showMessageDialog(this,"删除成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; catch(SQLException ee) System.out.println(""+ee); try rs=sql.executeQuery("SELECT * FROM teacher"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); getPassword=rs.getString(2); if(getUsername.equals(Username)&&getPassword.equals(Password) sql.executeUpdate("DELETE FROM teacher WHERE name = "+Username+" "); this.dispose(); JOptionPane.showMessageDialog(this,"删除成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; catch(SQLException ee) System.out.println(""+ee); try rs=sql.executeQuery("SELECT * FROM student"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); getPassword=rs.getString(2); if(getUsername.equals(Username)&&getPassword.equals(Password) sql.executeUpdate("DELETE FROM student WHERE name = "+Username+" "); this.dispose(); JOptionPane.showMessageDialog(this,"删除成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; if(sign=false) JOptionPane.showMessageDialog(this,"用户名或密码错误!","信息提示",JOptionPane.WARNING_MESSAGE); catch(SQLException ee) System.out.println(""+ee); sign=false; 删除用户模块窗口图如下:图15 删除用户窗口图 删除用户模块可以从数据库对应表中删除用户。程序首先在三张表中查找是否存在所要删除的用户,如果不存在则给出提示;存在则检查所输入的密码是否为该用户密码,如果密码匹配则删除成功;不匹配则给出对应提示。修改密码模块伪代码如下:Username=textfield.getText(); if(Login.signA=false) Oldpassword=textfield1.getText(); Newpassword=textfield2.getText(); try rs=sql.executeQuery("SELECT * FROM guanliyuan"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); getOldpassword=rs.getString(2); if(Login.signA=true) if(getUsername.equals(Username) if(Newpassword.equals("") JOptionPane.showMessageDialog(this,"新密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; else sign=false; sql.executeUpdate("UPDATE guanliyuan SET password = "+Newpassword+" WHERE name = "+Username+""); this.dispose(); JOptionPane.showMessageDialog(this,"修改成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; catch(SQLException ee) System.out.println(""+ee); try rs=sql.executeQuery("SELECT * FROM teacher"); sql=con.createStatement(); while(rs.next() getUsername=rs.getString(1); getOldpassword=rs.getString(2); if(Login.signA=true) if(getUsername.equals(Username) if(Newpassword.equals("") JOptionPane.showMessageDialog(this,"新密码不能为空!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; else sign=false; sql.executeUpdate("UPDATE teacher SET password = "+Newpassword+" WHERE name = "+Username+""); this.dispose(); JOptionPane.showMessageDialog(this,"修改成功!","信息提示",JOptionPane.WARNING_MESSAGE); sign=true; break; if(Login.signA=false) if(getUsername.equals(Username)&&ge

    注意事项

    本文(软件工程大型实验课程设计说明书-大学自动排课算法设计与实现系统——登陆及用户管理子系统.doc)为本站会员(rrsccc)主动上传,三一文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    经营许可证编号:宁ICP备18001539号-1

    三一文库
    收起
    展开