




已阅读5页,还剩16页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
沈航北方科技学院JSP程序设计报告 程序名称 学生成绩管理系统 教 学 系 专 业 班 级 学 号 学生姓名 指导教师 2014年12月目录一、设计目的3二、设计思路3三、具体实现41.功能介绍:42.数据库构成53.程序构成7四、设计体会与小结10附录1用户手册11附录2源程序13 一、设计目的1.通过开发具体系统,了解并熟悉jsp2.掌握网络编程的一般模式,使用jsp+javabean+servlet编写具体可用的系统3.通过开发学生成绩管理系统,充分体会MVC模式的优点及在网络开发的流行性,培养运用此模式解决实际问题的能力4.通过设计系统,在开发过程中碰到问题解决问题的过程中,逐渐提高自己的开发能力二、设计思路本系统采用传统的MVC开发模式,即Jsp+Javabean+Servlet,使用mysql数据库。其中Jsp实现视图端,Javabean是模型端,Servlet是控制端。Servlet担当主要逻辑控制,通过接受Jsp传来的用户请求,调用以及初始化JavaBean,再通过Jsp传到客户端,本系统中SqlBean担当主要的与数据库的连接与通信,JavaBean在本系统中主要担当配合Jsp以及Servlet来完成用户的请求,而Jsp主要担当接受与响应客户端。体系结构图如图1所示:浏览器servlet览器jsp览器JavabeanDatabase览器请求 响应应、 图1 体系结构图三、具体实现1.功能介绍:管理员端管理员可以进行的操作如下: 1、对学生信息进行增加、删除、修改、查询2、对教师信息进行增加、删除、修改、查询3、对课程信息进行增加、删除、修改、查询4、查看个人信息并进行性修改5、查看学生的选课信息、学生的成绩以及排名情况,其中在查看学生排名时,可以根据学生的所学课程和所在专业进行排名查询6、 对学生的选课信息进行添加、删除等操作教师端教师可以进行的操作如下:1、查看个人信息并修改登录密码2、查看学生信息,其中包括对学生成绩进行查询与修改,在本系统中,将教师 的成绩录入功能与成绩修改功能合并3、查看学生的排名情况,包括学生的课程排名与专业排名学生端学生可以进行的操作如下:1、修改个人登录系统的密码2、查看自己的课表3、进行选课4、查询自己成绩以及成绩排名情况,同时拥有通过学号查询其他人成绩的权利框图结构 程序的框图结构如图2所示: 图2 框架结构2.数据库构成数据库作为后台数据存储空间,由7张表组成,设计遵循数据库设计要求,力求规范,各表的结构如下:manager 管理员信息表teacher 教师信息表student 学生信息表course 课程信息表studentcourse 学生选课信息表score 学生成绩表rank 学生平均学分积点表3.程序构成Jsp各个输入界面,显示界面,用于信息的输入输出以及显示Errorpage.jsp错误信息显示界面Exist.jsp退出系统Login.jsp登录界面Manager:addcourse.jsp添加课程界面addstucourse.jsp为学生选课界面addstudent.jsp添加学生界面addteacher.jsp添加教师操作m1.jsp显示页面的上栏信息m2.jsp显示页面左栏信息m3.jsp显示页面右栏信息manager.jsp划分分配页面比例Searchonescore.jsp查看某个学生成绩界面Showcourse.jsp显示课程信息界面Showstucou.jsp显示学生选课信息界面Showstudent.jsp显示学生信息Showteacher.jsp显示教师信息Updatecourse.jsp更改课程信息updateMpassword.jsp更改密码界面Updatescore.jsp更改成绩界面Updatestudent.jsp更改学生信息界面Updateteacher.jsp更改教师信息界面Teacher:Rankcourse.jsp输入课程号进行排名界面Rankcourse2.jsp显示按课程排名信息Rankmajor.jsp输入专业名进行排名界面Rankmajor2.jsp显示按专业排名信息Searchonescore.jsp查看某个学生成绩界面Showstudent.jsp显示学生信息showTinfo.jsp显示个人信息T1.jsp显示页面的上栏信息T2.jsp显示页面左栏信息T3.jsp显示页面右栏信息Teacher.jsp划分分配页面比例Updatescore.jsp更改成绩界面updateTpassword更改密码界面StudentS1.jsp显示页面的上栏信息S2.jsp显示页面左栏信息S3.jsp显示页面右栏信息Searchmyself.jsp查看个人成绩Searchoneself1.jsp显示其他人成绩Searchothers.jsp输入要查询其他人的学号界面Selectcourse.jsp选课界面Showstucou.jsp显示个人选课信息Student.jsp划分分配页面比例updateSpassword.jsp修改密码JavaBeanJavaBean定义各种功能类sqlBean 对数据库的各种操作coursescore 课程成绩信息lstudent 学生类lteacher 教师类lcourse 课程lstudentcourse 学生选课信息Servelet作为整个系统的控制者,Servlet接受Jsp的请求与数据,调用JavaBean完成程序功能,并将结果转交给Jsp显示各Servlet如下:Addcourse添加课程Addstudent添加学生Addteacher添加教师Check验证登录信息Delcourse删除课程Delstucou删除学生选课信息Delstudent删除学生信息Delteacher删除教师M_selectcourse管理员为学生选课M_updatescore管理员更改成绩Selectcourse学生选课Updatecourse更改课程信息updateMpassword更改教师密码Updatescore更改成绩updateSpassword更改学生密码Updatestudent更改学生信息Updateteacher更改教师信息updateTpassword更改教师密码四、设计体会与小结通过学生成绩管理系统的设计,我对软件开发又有了更深一些的认识,对MVC模式的特点有了一定的看法。在软件设计中,再碰到问题及解决问题的过程中有了一定的提高。做程序一定要提前做好规划,这样会避免在系统开发过程中出现混乱,并且在对程序进行修改时也能减少附带的错误。系统是不可能完美的,我们要做的就是要在现实需求的基础上尽量减少用户操作的繁琐,为用户提供便利,尽量使系统人性化。要解决问题拖沓,要及时有效地处理问题及及时完成任务,编程是个慢活细活,要有耐性。要充分利用网络的便利,遇到一些想不通的地方可以上网查询,对平时没有及时对所学的东西进行扩展和提高。同时周围的同学也是很好的老师,有些问题自己想可能想不通,但是让别人帮自己看看就能很轻易解决问题。不要局限在课本内容,也不要只看课本,最好的方法就是编程,在实践中学习。当碰到问题时就去查资料,去学习,然后把学到的知识运用到程序中,这样对知识的掌握就更加彻底。一开始我采取的办法就是看课本,但是课本看完了,自己还是很头晕,知识点太琐碎,看一遍根本记不住多少东西,后来就采取上面的办法,这样对JSP程序设计理解的越来越清楚。附录1用户手册运行程序,程序显示登录界面如图1所示 图1 登录界面输入用户名和密码后,选择相应的身份,点击登录系统。出现如图2所示的程序界面。 图2 程序运行界面附录2源程序package servlet;import java.io.IOException;import java.io.PrintWriter;import java.sql.ResultSet;import java.sql.SQLException;import javax.servlet.RequestDispatcher;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.servlet.http.HttpSession;import bean.sqlBean;public class check extends HttpServlet /* * Constructor of the object. */public check() super();/* * Destruction of the servlet. */public void destroy() super.destroy(); / Just puts destroy string in log/ Put your code here/* * The doGet method of the servlet. * * This method is called when a form has its tag value method equals to get. * * param request the request send by the client to the server * param response the response send by the server to the client * throws ServletException if an error occurred * throws IOException if an error occurred */public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException response.setContentType(text/html;charset=utf-8);PrintWriter out = response.getWriter();String id=null;String password=null;String kind=null;id=request.getParameter(id);HttpSession session=request.getSession(true);session.setAttribute(id, String.valueOf(id);password=request.getParameter(password);kind=request.getParameter(kind);sqlBean db=new sqlBean();String pw=;String sql=select password from +kind+ where id=+id+;ResultSet rs=db.executeQuery(sql);tryif(rs.next()pw=rs.getString(password);if(password.equals(pw)goo(request,response,kind);elseSystem.err.println(用户名或密码错误!);doError(request,response,用户名或密码错误!);catch(SQLException e)System.err.println(用户名或密码错误!+e.getMessage();System.out.print(用户名或密码错误!+e.getMessage();catch(ServletException f)System.err.println(用户名或密码错误!+f.getMessage();catch(IOException g)System.err.println(用户名或密码错误!+g.getMessage();/* * The doPost method of the servlet. * * This method is called when a form has its tag value method equals to post. * * param request the request send by the client to the server * param response the response send by the server to the client * throws ServletException if an error occurred * throws IOException if an error occurred */public void goo(HttpServletRequest request,HttpServletResponse response,String kind)throws ServletException,IOExceptionif(kind.equals(student)/控制页面跳转RequestDispatcher rd=getServletContext().getRequestDispatcher(/student/student.jsp);rd.forward(request, response);if(kind.equals(teacher)RequestDispatcher rd=getServletContext().getRequestDispatcher(/teacher/teacher.jsp);rd.forward(request, response);if(kind.equals(manager)RequestDispatcher rd=getServletContext().getRequestDispatcher(/manager/manager.jsp);rd.forward(request, response);public void doError(HttpServletRequest request,HttpServletResponse response,String str)throws ServletException,IOExceptionrequest.setAttribute(problem, str);getServletConfig().getServletContext().getRequestDispatcher(/errorpage.jsp);public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException doGet(request,response);/* * Initialization of the servlet. * * throws ServletException if an error occurs */public void init() throws ServletException / Put your code herepackage servlet;import java.io.IOException;import java.io.PrintWriter;import java.sql.*;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.servlet.http.HttpSession;import bean.studentcourse;import bean.course;import bean.coursescore;public class selectcourse extends HttpServlet /* * Constructor of the object. */public selectcourse() super();/* * Destruction of the servlet. */public void destroy() super.destroy(); / Just puts destroy string in log/ Put your code here/* * The doGet method of the servlet. * * This method is called when a form has its tag value method equals to get. * * param request the request send by the client to the server * param response the response send by the server to the client * throws ServletException if an error occurred * throws IOException if an error occurred */public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException request.setCharacterEncoding(utf-8);response.setContentType(text/html;charset=utf-8);PrintWriter out = response.getWriter();String sid,cid,clsid;HttpSession session=request.getSession();sid=(String)session.getAttribute(id);cid=request.getParameter(cid);course cou=new course();studentcourse selcou=new studentcourse();coursescore sc=new coursescore();sc.addsid(sid);if(selcou.isValid(sid,cid)=false)ResultSet rs=cou.getCinfo(cid);try while(rs.next()selcou.setSid(sid);selcou.setCid(cid);selcou.setClnum(rs.getString(clnum);selcou.setCname(rs.getString(cname);selcou.setCredit(rs.getDouble(credit);selcou.setCapacity(rs.getInt(capacity);selcou.addstucourse();out.print(选课成功!正在返回,请稍候);response.setHeader(refresh, 2;url=/stu_score_ms/student/showstucou.jsp); catch (NumberFormatException e) e.printStackTrace(); catch (SQLException e)e.printStackTrace();elseout.print(对不起,您已经选过该课程了!);response.setHeader(refresh, 2;url=/stu_score_ms/student/selectcourse.jsp);/* * The doPost method of the servlet. * * This method is called when a form has its tag value method equals to post. * * param request the request send by the clien
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 高中影视作品鉴赏课件
- 瑜伽导师与瑜伽馆合作合同范本专业指导与授课协议
- 车场租赁与商业地产:三方商业停车场租赁合同
- 离异家庭房产过户子女财产权保护及传承协议范本
- 离婚协议补充:房产分割及使用权调整协议
- 品牌季节性广告代理执行合同
- 员工职离职合同申请规程
- 服装生产车间安全管理规定
- 并行计算实施细则
- 人工智能在农业领域的应用细则
- 框架合作协议书合同模板
- 2025年辅警招聘考试试题库(附答案)(满分必刷)
- CQB战术课件教学课件
- 汽车客运服务合同协议书
- 稽核培训课件
- 制鞋工岗前考核试卷及答案
- 郑州市突发应急预案
- 2025广东肇庆市怀集县卫生事业单位招聘102人考试备考试题及答案解析
- 2025-2026年秋季学期一年级开笔礼校长致辞稿:执笔启智 向新而行
- 原发性胆汁性胆管炎的诊断和治疗课件
- 中医医疗技术相关性感染防控考试卷(附答案)
评论
0/150
提交评论