




已阅读5页,还剩18页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
软 件 学 院课程设计报告书课程名称 Java EE 课程设计 设计题目 学生个人学分统计系统 专业班级 学 号 姓 名 指导教师 2011 年 12 月目 录1 设计时间 32 设计目的 33设计任务 34 设计内容 3 4.1 抽象数据类型的定义.34.1.1程序所建立的包 .34.1.2 程序所需要导入的包 .34.2数据库部分的实现 .44.2.1 E-R图 .44.2.2 逻辑设计 .44.3程序流程 .54.4模块间层次关系 .64.5 系统代码实现 64.6 测试结果 .184.6.1 登录测试结果 .184.6.2 显示测试结果 .194.6.3 统计测试结果 .19 4.6.4 添加测试结果 .19 4.6.5 删除测试结果 .205 总结与展望 .21参考文献 .221 设计时间2011/12/12-2011/12/162 设计目的JavaEE课程设计是对所学JavaEE与中间件课程的小结,是提高学生对所学知识综合应用能力的一种方式,是集中实践性环节之一。要求同学们对课程中所学习到的知识综合运用,开发有一定规模的Java Web程序。3设计任务(一)必备功能说明:(1)功能描述:用户以合法身份登录系统后,才能进行所有操作;用户可以添加、查看和删除课程信息(课程编码、课程名称、课程类别(选修和必修)、学分数);统计出自己添加的必修课的学分和选修课的学分。(2)添加课程信息(3)查看课程信息(4)删除课程信息(5)分别统计必修课和选修课的总学分(二)开发语言与开发环境:MyEclipse、Java、数据库(sqlserver2000、mysql、oracle等任选一种)4 设计内容 4.1 抽象数据类型的定义4.1.1程序所建立的包com.jdbc.domaincom.jdbc.daocom.jdbc.servletcom.jdbc.servicecom.jdbc.util4.1.2程序所需要导入的包import java.sql.*;import java.util.A*t;import java.io.*;import javax.servlet.*;import javax.servlet.http.*;4.2数据库部分的实现4.2.1 E-R图课程名称课程类别学分数课程信息课程编码图1 课程信息E-R图4.2.2 逻辑设计1.关系模式课程信息(课程编号,课程名称,课程类别,学分数)2. 系统表表1 数据包course列名数据类型长度是否为空含义idbigint8N课程编码,主键,自动增长namevarchar50Y课程名称cclassvarchar50Y课程类别countsbigint8Y学分数4.3程序流程开始图登录界面输入用户名称和用户密码是否成功成功页面错误页面对数据库进行操作显示课程信息NY结束图2 程序流程图4.4模块间层次关系登录模块密器、解密模块成功模块密器、解密模块失败模块密器、解密模块统计模块删除模块显示模块添加模块图3 层次(调用)关系图4.5 系统代码实现 1.页面的实现本程序有四个主要页面:“login.jsp”,“error.jsp”,“showAllBooks.jsp”和“savaBook”, “login.jsp”用于用户登录,它的关键代码如下: My JSP login.jsp starting page 学生个人学分统计系统 用户名称: 用户密码: “error.jsp”当登录失败时,跳转到本页面,然后超链接到登录页面,它的关键代码如下: 错误页面 你的用户名或密码错误,请重新登录 “showAllBooks.jsp”用于显示所有的课程信息和学分统计,它的关键代码如下: base href= 显示页面 课程编码 课程名称 课程类别 学分数 添加图书信息 必修学分: 选修学分: 删除课程信息: “savaBook.jsp”用于填写要保存的课程信息,它的关键代码如下: 保存页面 课程名称: 课程类别: 学分数: 2.工具类的实现工具的类名为“DBConnection”,该类用于获得数据库的连接,它的实现代码如下:public class DBConnection public static Connection getConnection()final String driverName=com.microsoft.jdbc.sqlserver.SQLServerDriver;final String url=jdbc:microsoft:sqlserver:/localhost:1433;databasename=book_shop;tryClass.forName(driverName);catch(ClassNotFoundException e)e.printStackTrace();tryConnection con=DriverManager.getConnection(url, sa, sa);con.setAutoCommit(false);return con;catch(SQLException e)e.printStackTrace();return null;3.实体类的实现实体类的类名有“User”和“Book”,“User”类拥有用户名称和用户密码的私有属性及各个属性的set、get方法,它的实现代码如下:public class User private String username;private String password;public String getUsername() return username;public void setUsername(String username) this.username = username;public String getPassword() return password;public void setPassword(String password) this.password = password;“Book”类拥有一些代表课程信息的私有属性以及各个属性的set、get方法,它的实现代码如下:public class Book private long id;private String name;private String cclass;private int counts;public long getId() return id;public void setId(long id) this.id = id;public String getName() return name;public void setName(String name) = name;public String getCclass() return cclass;public void setCclass(String cclass) this.cclass = cclass;public int getCounts() return counts;public void setCounts(int counts) this.counts = counts;4.DAO类的实现DAO类的类名为“BooksDao”,该类使用JDBC技术实现,用于和数据库交互,进行相关的增、删、改、查操作,它的实现代码如下:public class BooksDAO public List getAllBooks()Connection con=DBConnection.getConnection();List list=new ArrayList();tryPreparedStatement ps=con.prepareStatement(select * from course);ResultSet rs=ps.executeQuery();while(rs.next()Book book=new Book();book.setId(rs.getLong(id);book.setName(rs.getString(name);book.setCclass(rs.getString(cclass);book.setCounts(rs.getInt(counts);list.add(book);return list;catch(SQLException e)e.printStackTrace();return null;public boolean saveUser(Book book) throws ExceptionConnection conn=DBConnection.getConnection();String listSQL=insert into course values(?,?,?);PreparedStatement pstmt=conn.prepareStatement(listSQL);trypstmt.setString(1, book.getName();pstmt.setString(2, book.getCclass();pstmt.setInt(3, book.getCounts();pstmt.executeUpdate();mit();return true;catch(SQLException e)e.printStackTrace();finallyconn.close();return false;public boolean deleteBook(Book book)throws ExceptionConnection conn=DBConnection.getConnection();String listSQL=delete from course where id=?;PreparedStatement pstmt=conn.prepareStatement(listSQL);trypstmt.setLong(1, book.getId();pstmt.executeUpdate();mit();return true;catch(SQLException e)e.printStackTrace();finallyconn.close();return false;5.控制器类的实现控制器类的类名有“LoginServlet”、“ListAllBooksServlet”和“deleteServlet”类,它们都继承了“HttpServlet”,用于接收页面表单中的数据和将DAO类传递的数据发送到页面中以及控制页面的转向,它们的实现代码分别如下:public class LoginServlet extends HttpServlet public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException doPost(request,response);public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException String username=request.getParameter(username);String password=request.getParameter(password);User user=new User();user.setUsername(username);user.setPassword(password);HttpSession session=request.getSession();String forward=;if(UserService.CheckLogin(user)forward=/index.jsp;session.setAttribute(name, username);elseforward=/error.jsp;RequestDispatcher rd=request.getRequestDispatcher(forward);rd.forward(request, response);public class ListAllBooksServlet extends HttpServlet public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException BooksService bookService=new BooksService();List list=bookService.getAllBooks();request.setAttribute(allbooks, list);request.getRequestDispatcher(/showAllBooks.jsp).forward(request, response);public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException request.setCharacterEncoding(GBK);String name=(String)request.getParameter(name);String author=(String)request.getParameter(cclass);int counts=Integer.parseInt(request.getParameter(counts);Book book=new Book();book.setName(name);book.setCclass(author);book.setCounts(counts);BooksDAO bookDao=new BooksDAO();trybookDao.saveUser(book);BooksService bookService=new BooksService();List list=bookService.getAllBooks();request.setAttribute(allbooks, list);request.getRequestDispatcher(/showAllBooks.jsp).forward(request, response);catch(Exception e)e.printStackTrace();bookDao.getAllBooks();public class deleteServlet extends HttpServlet public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException doPost(request,response);public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException int id=Integer.parseInt(request.getParameter(delete);Book book=new Book();book.setId(id);BooksDAO bookDao=new BooksDAO();trybookDao.deleteBook(book);BooksService bookService=new BooksService();List list=bookService.getAllBooks();request.setAttribute(allbooks, list);request.getRequestDispatcher(/showAllBooks.jsp).forward(request, response);catch(Exception e)e.printStackTrace();bookDao.getAllBooks();6.Servic类的实现Service类的类名有“UserServlet”和“BooksServlet”类,是用于控制器类和DAO类之间的数据传递的连接,它们的实现代码分别如下:public class UserService public static boolean CheckLogin(User user)if(user.getUsername().equals(admin)&user.getPassword().equals()return true;else return false;public class BooksService public List getAllBooks()BooksDAO booksDAO=new BooksDAO();return boo
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 45824-2025废旧农业机械回收体系建设规范
- 2025年中国可伸缩乒乓球网行业市场全景分析及前景机遇研判报告
- 2024-2025学年吉林省通化市梅河口五中高二下学期4月月考政治试题及答案
- 中国橡胶和塑料制品行业调查测报告
- 2025年中国电脑充电器行业市场发展现状及投资战略咨询报告
- 2025-2031年中国家用机器人行业市场需求预测及投资战略规划报告
- 中国商业收款机行业市场调查研究及投资前景展望报告
- 男士发型培训课件
- 中国水晶灯工程市场竞争格局及投资战略规划报告
- 2025-2030年中国液冷数据中心行业市场全景调研及未来趋势研判报告
- 人工智能在教育行业的创新应用研究
- 常州大学《工程热力学》2022-2023学年第一学期期末试卷
- 新能源行业光伏发电技术操作指南
- 全国托育职业技能竞赛(保育师赛项)选拔赛考试题及答案
- 金字塔原理完整版-课件
- 全国大学生数学建模大赛D题(会议筹备优化模型)
- 中考物理考前指导最后一课
- 盐酸罂粟碱在疼痛治疗中的应用
- 中国近代史纲要-期末考试复习重点
- 企业法务概论智慧树知到期末考试答案2024年
- (高清版)DZT 0331-2020 地热资源评价方法及估算规程
评论
0/150
提交评论