用户管理系统的设计.doc_第1页
用户管理系统的设计.doc_第2页
用户管理系统的设计.doc_第3页
用户管理系统的设计.doc_第4页
用户管理系统的设计.doc_第5页
已阅读5页,还剩20页未读 继续免费阅读

下载本文档

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

文档简介

武汉理工大学华夏学院课程设计报告书课程名称: 软件开发工具课程设计 题 目: 用户管理系统的设计与开发 系 名: 信息工程系 专业班级: 计网1082 姓 名: 学 号: 10210408218 指导教师: 凌 伟 2011年7月7日课程设计任务书学生姓名: X X 专业班级: 计算机1082 指导教师: 凌 伟 工作单位: 信息系 设计题目: 用户管理系统的设计与开发初始条件:了解软件工程基本知识,掌握JAVA编程基础,了解基本的软件开发工具。要求完成的主要任务:功能:用户可以注册,然后登陆,有错误提示等。登陆成功以后,会列出所有用户的记录信息。登陆用户可对记录进行增加、修改、删除、查询等操作。技术:jsp+servlet+tomcat6.0+mysql设计报告撰写格式要求:一、课程设计说明书(或报告书)正文内容【设计题目】【开发环境】【开发工具】 【完成时间】 2011-6-272011-7-8【设计思想】描述确定设计内容后,自己如何思考的、确定设计的方案是什么?打算如何实现【设计过程及设计步骤】 将设计的步骤及实施过程分步总结写出来【测试运行】描述对于自己给定的数据,运行后的结果如何?【评价与修订】 对自己设计内容及结果进行全面评价描述,包括:创造性、独特性、满意程度及不足处,并提出改进意见;【设计体会】 总结本次实训经验、教训、收获、体会,为今后的实践环节学习打好基础【参考文献】 罗列在设计过程中查阅的文献名称时间安排:2011-6-272011-7-82011-7-7 系统验收;2011-7-72011-7-8 提交课程设计报告;指 导 教 师 签 字: 2011 年 6 月 25 日系 主 任 签 字: 2011 年 6 月 26 日目 录第1章 需求分析11.1 课程设计题目11.2 课程设计要求11.3 课程设计任务11.4 开发环境11.5 开发工具1第2章 概要设计22.1 设计思想22.2 数据库的设计22.3 系统流程图3第3章 详细设计43.1 创建db_user数据库43.2 创建tb_user用户信息表43.3 建立数据库链接43.4 添加用户信息63.5 修改用户信息73.6 删除用户信息73.7 根据用户编号查询83.8 不同属性查询93.9 检验登陆用户10第4章 测试运行与评价114.1运行结果113.1.4 删除用户124.2 结果分析12第5章 小结与体会13参考文献14附录:14第1章 需求分析1.1 课程设计题目用户管理系统的设计与开发。1.2 课程设计要求(1) 了解软件工程基本知识。熟练掌握MyEclipse 7.0,和tomcat 6.0以及MySQL等应用软件得使用。掌握JAVA编程基础。熟练掌握JSP的各种基本语法。了解基本的软件开发工具。(2)用户管理系统抽象于信息管理系统,能进行信息得收集,传递,加工,维护和使用的系统。主要任务是最大限度得利用现代计算机及网络技术加强信息管理,建立正确的数据,并加工成各种信息给管理人员,提高工作效率。1.3 课程设计任务设计一个用户管理系统,用户能够注册、登陆,登陆成功后,会列出所有用户的记录信息。登录用户能够对记录进行增加、删除、修改,查询操作。1.4 开发环境Windows XP系统1.5 开发工具MyEclipse 7.0,tomcat 6.0,MySQL等开发工具。第2章 概要设计2.1 设计思想分析设计的要求,我们需要设计一个系统来实现用户的注册和登陆,以及增加、修改、删除和查询用户的相关信息。明确系统的目标,规模,功能,对系统开发背景,必要性和意义进行调查分析,并且提出系统的逻辑模型和各种可能的方案,从而为系统开发项目的决策提供科学依据,首先需要建立相关数据库,存储用户的信息,实现用户信息的增加、修改、删除和查询功能。然后运用MyEclipse7.0来设计用户登陆界面,实现用户的注册和登陆。并在数据库和登陆界面系统之间建立连接使新添加的信息储存到数据库中。最终实现用户管理系统得各种必要功能。2.2 数据库的设计按照用户管理系统的功能要求,后台数据库主要完成用户信息的存储以及相关操作。根据实际情况,我认为本次课程设计中实体用户至少应赋予用户编号(userId),用户姓名(userName),用户密码(userPass)以及用户年龄(userAge)这四个属性。设计的数据库的数据字典如下表2.1所示属性名表中列名数据类型类型可否为空备注用户编号userIDIntNot null主码,唯一标示,不为空。用户名userNameVarcharNot null该用户的姓名用户密码userPassVarcharNot null该用户的登录密码年龄userAgeIntNot null该用户的年龄表2.1 数据字典2.3 系统流程图如图2.2所示,用户管理系统的流程图分为登陆流程和管理流程两大部分。添加管理查询管理修改管理删除管理基本管理结束开始用户登录身份判定用户界面管理操作图2.2 系统流程图第3章 详细设计3.1 创建db_user数据库在MySQl的终端中创建数据库,其过程如图3.1所示 图3.1 创建数据库db-user3.2 创建tb_user用户信息表在数据库db_user中创建用户信息表tb_user 图3.4 创建用户表tb_user3.3 建立数据库链接数据库链接的实现代码如下:import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;public class DBConnection private static String driverName = com.mysql.jdbc.Driver; private static String userName; private static String userPass; private static String url = jdbc:mysql:/localhost:3306/db_user; public static Connection getConnection(String _url, String _userName,String _userPass) userName = _userName;userPass = _userPass;url = _url;Connection conn = null;try Class.forName(driverName);conn = DriverManager.getConnection(url, userName, userPass); catch (ClassNotFoundException e) e.printStackTrace(); catch (SQLException e) e.printStackTrace();return conn;public static Connection getConnection() return getConnection(url, root, 123456);public static void closeConnection(Connection conn) if (conn != null) try conn.close(); catch (SQLException e) e.printStackTrace();3.4 添加用户信息在用户界面中添加用户,其实现代码如下:public void add(UserDTO user) conn = DBConnection.getConnection();try st = conn.createStatement();sql = insert into tb_user(userName,userPass,userAge) values(+ user.getUserName() + , + user.getUserPass() + ,+ user.getUserAge() + );int m = st.executeUpdate(sql);if (m != 0) System.out.println(添加成功); DBConnection.closeConnection(conn); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();3.5 修改用户信息对于用户信息的改变,我们可以在用户界面系统中直接进行修改,其修改后的信息自动保存到数据库中。其实现代码如下:public void update(UserDTO user) conn = DBConnection.getConnection();try st = conn.createStatement();sql = update tb_user set userName= + user.getUserName()+ ,userPass= + user.getUserPass() + ,userAge=+ user.getUserAge() + where userId= + user.getUserId()+ ;int m = st.executeUpdate(sql);if (m != 0) System.out.println(修改成功); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();3.6 删除用户信息对于一些不需要的用户信息,我们可以在用户界面系统中进行删除,在界面中删除的信息同时在用户数据库中也被删除。其实现代码如下:public void delete(int n) conn = DBConnection.getConnection();try st = conn.createStatement();sql = delete from tb_user where userId= + n + ;int m = st.executeUpdate(sql);if (m != 0) System.out.println(删除成功); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();3.7 根据用户编号查询在对指定用户,如知道用户编号,即userID进行相关的信息查询,其功能实现代码如下:public UserDTO selectById(int n) UserDTO user = new UserDTO();conn = DBConnection.getConnection();try st = conn.createStatement();sql = select * from tb_user where userId= + n + ;rs = st.executeQuery(sql);while (rs.next() user.setUserId(rs.getInt(userId);user.setUserName(rs.getString(userName);user.setUserPass(rs.getString(userPass);user.setUserAge(rs.getInt(userAge); catch (SQLException e) e.printStackTrace();return user;3.8 不同属性查询 在不知道具体的查询需求时,我们可以对数据库进行模糊查询,以达到最大的查询目的,其功能实现代码如下:public ArrayList selectByProperty(String property, String value) ArrayList list = new ArrayList();conn = DBConnection.getConnection();PreparedStatement pst = null;try if (property.equals() | property = null | value.equals()| value = null) sql = select * from tb_user;pst = conn.prepareStatement(sql); else sql = select * from tb_user where + property + like ?;pst = conn.prepareStatement(sql);pst.setString(1, % + value + %);System.out.println(sql);rs = pst.executeQuery();while (rs.next() UserDTO user = new UserDTO();user.setUserId(rs.getInt(userId);user.setUserName(rs.getString(userName);user.setUserPass(rs.getString(userPass);user.setUserAge(rs.getInt(userAge);list.add(user); catch (SQLException e) e.printStackTrace();return list; 3.9 检验登陆用户只有已经成功注册的用户才能登陆系统,外来用户进行登陆操作时,系统会将登陆信息与数据库中的用户信息进行比较,符合要求才能成功登陆,其功能实现代码如下:public boolean checkLoginuser(UserDTO user) boolean flag = false;conn = DBConnection.getConnection();try st = conn.createStatement();sql = select count(*) from tb_user where userName=+ user.getUserName() + and userPass=+ user.getUserPass() + ;userName=+user.getUserName()+;while (rs.next() if (rs.getInt(1) 0) flag = true; catch (SQLException e) e.printStackTrace();return flag; 第4章 测试运行与评价4.1运行结果 4.1.1 登陆界面 在运行tomcat后,打开IE浏览器,输入地址http:/localhost:8080/Loginuser/login.jsp并回车运行,出现如图4.1所示的用户登录界面。 图4.1 用户登录界面4.1.2 增加用户 在添加用户界面中,我们可以直接将要注册的新用户信息添加到数据库中。如图4.2所示。 图4.2增加用户4.1.3 查询用户信息如图4.3,在用户管理界面中,进行相关的查询操作。 图4.3 查询界面3.1.4 删除用户 点击“删除”按钮,删除用户姓名为“a”,即删除。4.2 结果分析本系统采用结构化得方法来实现系统总体功能,提高系统的各项指标,即将整个系统合理划分为各个功能模块,正确得处理模块与模块之间和模块内部得关系以及和数据库的关系,定义个模块的内部结构,通过对模块得设计和模块之间得关系得系统设计来实现整个系统的功能。此次课程设计的用户管理系统基本达到了任务的要求,经过反复的运行和调试,能够成功地进行注册和登陆,登陆成功后,会列出所有用户的信息记录。登陆后可以对用户信息进行添加、删除、修改以及查询操作。设计的过程中依然存在许多不足,主要是由于对开发工具的功能不熟悉,用户界面不够友好,用jsp和java语言来进行编程时不够熟练,测试运行时发现了很多的错误。 第5章 小结与体会在这次软件开发工具课程设计中,我们总共花了两个星期的时间,在这段时间里我感觉自己收获颇丰,在老师的讲解下,我不仅学到了很多关于软件开发工具的新知识,而且对以前学过的东西有了进一步的理解。并且在完成设计的过程中,我也遇到了不少的问题,多亏了老师的耐心辅导和同学的热心帮助,最后我的系统才得以成功实现。本次课程设计基本达到了任务要求,用户在登录界面登录后,经过运行和调试能够成功的注册、登陆,登陆成功后,会列出所有用户的记录信息。最后登陆对用户信息进行添加,删除,修改以及最后进行查询,都达到了预期的结果,如3.1中设计结果的运行和所得出的视图。同时设计过程中依然存在许多不足,主要是对开发工具的不能熟练掌握和功能的运用,从而导致用户界面不够好,编程和运行时出现了些问题。用开发和java语言来进行编程以及对开发工具的使用得到了添加,删除,修改以及查询最终得到了用户界面基本符合课程设计的要求。通过设计和开发一个简单的用户管理系统,我不仅巩固了课堂所学知识,熟悉了软件工程的基本流程,我还发现了自己的很多缺点和不足,努力在以后的学习过程中改进和提高自己。 设计者: 王 卫 设计时间: 2011-7-7 参考文献 1,卫红春 软件工程概论 清华大学出版社, 2007 2 马皓 java语言程序设计 清华大学出版社, 20053 王永茂 jsp程序设计 清华大学出版社, 20104 窦万峰 软件工程方法与实践 机械工业出版社, 2007附录:源代码package com.softeem.dto;public class UserDTO private int userId;private String userName;private String userPass;private String userSex;private int userAge;private String userEmail;public UserDTO() public int getUserId() return userId;public void setUserId(int userId) this.userId = userId;public String getUserName() return userName;public void setUserName(String userName) this.userName = userName;public String getUserPass() return userPass;public void setUserPass(String userPass) this.userPass = userPass;public String getUserSex() return userSex;public void setUserSex(String userSex) this.userSex = userSex;public int getUserAge() return userAge;public void setUserAge(int userAge) this.userAge = userAge;public String getUserEmail() return userEmail;public void setUserEmail(String userEmail) this.userEmail = userEmail;Overridepublic String toString() return UserDTO userAge= + userAge + , userEmail= + userEmail+ , userId= + userId + , userName= + userName+ , userPass= + userPass + , userSex= + userSex + ;package com.softeem.servlet;import java.io.IOException;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import com.softeem.dao.UserDAO;import com.softeem.dto.UserDTO;public class LoginUserCheck extends HttpServlet public LoginUserCheck() super();public void destroy() super.destroy(); public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException String username = request.getParameter(username);String userpass = request.getParameter(userpass);UserDTO user = new UserDTO();user.setUserName(username);user.setUserPass(userpass);UserDAO dao = new UserDAO();boolean flag = dao.checkLoginuser(user);if (flag = true) request.getSession().setAttribute(user, user);request.getRequestDispatcher(/servlet/UserManager).forward(request, response); else request.setAttribute(msg, 用户名或者密码错误);request.getRequestDispatcher(/login.jsp).forward(request,response);public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException doGet(request, response);public void init() throws ServletException ackage com.softeem.dao;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.ArrayList;import com.softeem.dto.UserDTO;public class UserDAO private Connection conn;private Statement st;private ResultSet rs;private String sql;public void add(UserDTO user) conn = DBConnection.getConnection();try st = conn.createStatement();sql = insert into tb_user(userName,userPass,userAge) values(+ user.getUserName() + , + user.getUserPass() + ,+ user.getUserAge() + );int m = st.executeUpdate(sql);if (m != 0) System.out.println(添加成功); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();public void update(UserDTO user) conn = DBConnection.getConnection();try st = conn.createStatement();sql = update tb_user set userName= + user.getUserName()+ ,userPass= + user.getUserPass() + ,userAge=+ user.getUserAge() + where userId= + user.getUserId()+ ;int m = st.executeUpdate(sql);if (m != 0) System.out.println(修改成功); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();public void delete(int n) conn = DBConnection.getConnection();try st = conn.createStatement();sql = delete from tb_user where userId= + n + ;int m = st.executeUpdate(sql);if (m != 0) System.out.println(删除成功); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();public ArrayList selectAll() ArrayList list = new ArrayList();conn = DBConnection.getConnection();try st = conn.createStatement();sql = select * from tb_user;rs = st.executeQuery(sql);while (rs.next() UserDTO user = new UserDTO();user.setUserId(rs.getInt(userId);user.setUserName(rs.getString(userName);user.setUserPass(rs.getString(userPass);user.setUserAge(rs.getInt(userAge);list.add(user); catch (SQLException e) e.printStackTrace();return list;public UserDTO selectById(int n) UserDTO user = new UserDTO();conn = DBConnection.getConnection();try st = conn.createStatement();sql = select * from tb_user where userId= + n + ;rs = st.executeQuery(sql);while (rs.next() user.setUserId(rs.getInt(userId);user.setUserName(rs.getString(userName);user.setUserPass(rs.getString(userPass);user.setUserAge(rs.getInt(userAge); catch (SQLException e) e.printStackTrace();return user;public ArrayList selectByProperty(String property, String value) ArrayList list = new ArrayList();conn = DBConnection.getConnection();PreparedStatement pst = null;try if (property.equals() | property = null | value.equals()| value = null) sql = select * from tb_user;pst = conn.prepareStatement(sql); else sql = select * from tb_user where + property + like ?;pst = conn.prepareStatement(sql);pst.setString(1, % + value + %);System.out.println(sql);rs = pst.executeQuery();while (rs.next() UserDTO user = new UserDTO();user.setUserId(rs.getInt(userId);user.setUserName(rs.getString(userName);user.setUserPass(rs.getString(userPass);user.setUserAge(rs.getInt(userAge);list.add(user); ca

温馨提示

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

评论

0/150

提交评论