学生网上选课系统毕业设计.docx
- 文档编号:27521877
- 上传时间:2023-07-02
- 格式:DOCX
- 页数:35
- 大小:316.20KB
学生网上选课系统毕业设计.docx
《学生网上选课系统毕业设计.docx》由会员分享,可在线阅读,更多相关《学生网上选课系统毕业设计.docx(35页珍藏版)》请在冰豆网上搜索。
学生网上选课系统毕业设计
实训报告
课题名称:
学生网上选课系统
系别:
经济与信息管理系
班级:
13级软件班
学号:
学生姓名:
指导老师:
完成日期:
2015.11.15
目录
一、设计任务与目的…………………………………………………3
二、需求分析………………………………………………………3
三、总体设计…………………………………………………………3
3.1、系统功能结构示意图………………………………………3
3.2、系统功能说明………………………………………………4
3.3、数据库E-R图………………………………………………4
3.4、主要功能流程图……………………………………………5
四、详细设计…………………………………………………………6
4.1、系统文件框架图……………………………………………6
4.2、设计模式及关键技术………………………………………6
4.3、数据库设计…………………………………………………7
五、测试与运行结果…………………………………………………8
六、参考文献…………………………………………………………9
七、设计心得…………………………………………………………10
附录……………………………………………………………………11
一、设计任务与目的
传统的手工选课不仅复杂,也牵涉了很多的人力,对管理也造成了诸多不变,而借助网上选课系统,学生在规定选课时间段内,可以不受地点和时间的限制完成选修课的申请,而学校也可以方便地对系统进行管理和控制,提高工作效率。
通过设计网上学生选课系统,使我们对JAVA的JSP编程以及数据库(SQLServer)的搭建的认识更加熟悉了解。
二、需求分析
本系统首先分为两大块:
1、学生模块;2、管理员(老师)模块。
●学生模块
1、学生登录;
2、学生注册;
3、学生选课;
4、学生退课;
5、查看已选课程;
6、学生成绩查询。
●管理员(老师)模块
1、管理员登录(usename:
admin;password:
admin);
2、查看已开课程信息;
3、增加新开课程;
4、删除已有课程信息;
5、修改课程信息;
6、录入学生成绩。
三、总体设计
3.1、系统功能结构示意图
3.2、系统功能说明
●前台管理
1、注册登录:
用户的注册登录,包括学生用户的注册登录和管理员(老师)用户登录。
2、选课退课:
学生对已有课程的选择或对已选课程的退选功能。
3、查询信息:
学生对选课和成绩的查询以及管理员(老师)对课程信息的查询。
4、修改信息:
管理员(老师)对课程信息的修改。
5、增减课程:
管理员(老师)增加新课程或删除已有课程。
6、录入成绩:
管理员(老师)录入学生课程学习的成绩。
●后台管理
1、查询学生信息:
已登录管理员查看学生属性信息,包括学生的姓名,性别,院系,以及联系电话。
2、查询课程信息:
已登录管理员查看课程信息列表,包括课程的名字,上课时间,上课地点,任课老师,任课老师电话,以及课程学分。
3、查询选课信息:
已登录管理员查看学生选课课程情况,包括学生姓名,课程名称,上课时间,上课地点,任课老师,学生电话,课程学分,以及学生课程成绩。
3.3、数据库E-R图
3.4、主要功能流程图
四、详细设计
4.1、系统文件框架图
4.2、设计模式及关键技术
●设计模式
系统中有管理员(老师)对学生选课的管理包括添加课程,删除课程及录入成绩等功能,学生可以注册和登录到该系统,登录该系统之后可以查看学校所开的课程的基本信息,学生可以选修其中的一些比较喜欢的课程,当学生又有其它想法对某课程不感兴趣的时候也可以退选已选的课程,然后重新选择喜欢的课程,选课结束后老师就给同学们上课,最后老师根据各个学生的表现或通过考试给同学们相应的考试分数(通过系统录入),最后学生可以通过此系统来查询所选课程的考试成绩。
如果学生发现成绩或其他信息出现问题,可以通过提供的教师电话联系该开课老师,老师核对后可以进行相应的修改。
Jsp页面用于给用户提供界面,提交参数及显示结果。
通过JavaBean处理参数并连接数据库,从数据库中获得用户请求的信息再交付给Servlet处理交付个用户显示在jsp页面。
●关键技术
ØJavaBean、Servlet技术
JavaBean封装了程序的页面逻辑,可以实现代码的重复利用,容易维护和使用,利用
useBean>动作元素就可以很容易的在各个jsp页面使用JavaBean,将要用到的方法都封装到java文件中通过JavaBean技术,直接调用其中的各种方法实现与jsp页面的交互。 ØJDBC数据库连接技术 数据库的连接在整个选课系统中是必不可少的,而且经常用到,于是我将它封装到dbcon.java的java文件中,其中有数据库连接的几个基本步骤: 加载驱动,获得连接,创建Statement对象等等,这样做的好处是在当有与数据库连接的相关操作时就直接利用JavaBean技术就能很方便的实现。 Ø登录注册的验证技术 登陆注册的验证主要通过专门编写的几个用于验证的函数和JavaScript脚本语言技术,以及数据库的创建时的数据的完整性约束等等来实现简单的验证 Ø各页面之间跳转时参数的传递技术 各个页面之间的跳转时参数的传递主要用到了几个jsp内置对象: request,session等。 在整个系统所有页面都要用到的参数就用session对象的setAttribute()方法将参数存储到session对象中,然后利用getAttribute()方法获取参数。 request对象的getPatameter()方法用于获取表单提交的参数。 Ø编码解码技术 字符转换的函数codeToString()方法来处理系统中出现的乱码问题。 通过对可能出现乱码的字符重新编码来解决乱码问题。 4.3、数据库设计 数据库: SQLServer2000个人版 数据库名: jsp_db(jsp_db_Data.MDF;jsp_db_Log.LDF); 学生信息表(stuInfo): 课程表(course) 学生选课表(sc) 管理员登录信息表(adminInfo) 4.4、关键程序代码(见附录)。 五、测试与运行结果 六、参考文献 1、王珊,萨师煊,数据库系统概论,北京高等教育出版社,2006.7; 2、[美]布鲁斯•埃克尔(Eckel,B.),陈昊鹏译,Java编程思想(第4版),机械工业出版社,2007.6;3、[美]鲍格斯坦(Bergsten,H.),林琪、朱涛江译,JSP设计(第三版),中国电力出版社,2004; 4、刘卫国,严晖,数据库技术应用----SQLServer,清华大学出版社,2007.1 七、设计心得 通过这次课程设计,对JSP、SQL Server 2000有了进一步的了解,也对网页设计有了一定的见解,对我们的网上选课系统进行分析,设计,实现。 进一步的了解了JAVA编程和数据库。 也增强了团队合作意识,共同合作精神。 对以后的设计实现有了一定的基础,在这次课程设计中得到了很大的收获。 附录: adminbean.java packagebean; importbean.dbcon; importjava.sql.*; publicclassadminbean{ privateStringtno; privateStringpassword; privateResultSetrs; privatedbcondb=newdbcon(); publicadminbean() { } publicStringgetTno(){ returntno; } publicvoidsetTno(Stringtno){ this.tno=tno; } publicStringgetPassword(){ returnpassword; } publicvoidsetPassword(Stringpassword){ this.password=password; } publicStringcheckTeacher() {//教师登陆验证 Stringbackstr=""; booleanmark=true; if(this.tno==null||this.tno.equals("")) { backstr+="
";
mark=false;
}
if(this.password==null||this.password.equals(""))
{
backstr+="
";
mark=false;
}
if(mark)
{
Stringsql="select*fromadminInfowheretno='"+this.tno+"'andpassword='"+this.password+"'";
try{
rs=db.getRs(sql);
if(!
rs.next())
backstr="false";
else
backstr="true";
}catch(Exceptione){e.printStackTrace();}
}
db.closed();
returnbackstr;
}
}
courseInfo.java
packagebean;
publicclasscourseInfo{
privateStringcno;
privateStringcname;
privateStringtime;
privateStringaddress;
privateStringteacher;
privateStringphone;
privateStringxuefen;
privateStringzno;
privateStringzy;
privateStringzx;
publicStringgetZno(){
returnzno;
}
publicvoidsetZno(Stringzno){
this.zno=zno;
}
publicStringgetZy(){
returnzy;
}
publicvoidsetZy(Stringzy){
this.zy=zy;
}
publicStringgetZx(){
returnzx;
}
publicvoidsetZx(Stringzx){
this.zx=zx;
}
publicStringgetCno(){
returncno;
}
publicvoidsetCno(Stringcno){
o=cno;
}
publicStringgetCname(){
returncname;
}
publicvoidsetCname(Stringcname){
ame=cname;
}
publicStringgetTime(){
returntime;
}
publicvoidsetTime(Stringtime){
this.time=time;
}
publicStringgetAddress(){
returnaddress;
}
publicvoidsetAddress(Stringaddress){
this.address=address;
}
publicStringgetTeacher(){
returnteacher;
}
publicvoidsetTeacher(Stringteacher){
this.teacher=teacher;
}
publicStringgetPhone(){
returnphone;
}
publicvoidsetPhone(Stringphone){
this.phone=phone;
}
publicStringgetXuefen(){
returnxuefen;
}
publicvoidsetXuefen(Stringxuefen){
this.xuefen=xuefen;
}
}
dbcon.java
packagebean;
importjava.sql.*;
importjava.util.*;
importbean.scoretable;
publicclassdbcon
{
privatestaticConnectioncon;
privateStatementstm;
privateResultSetrs;
privatestaticStringclassname="com.microsoft.jdbc.sqlserver.SQLServerDriver";
privatestaticStringurl="jdbc:
microsoft:
sqlserver:
//localhost:
1433;DatabaseName=jsp_db";
publicdbcon()
{
}
publicstaticConnectiongetConnection()
{//连接数据库
try
{
Class.forName(classname);
}
catch(Exceptione)
{
System.out.println("getConnection方法异常!
");
e.printStackTrace();
}
try{
con=DriverManager.getConnection(url,"sa","");
}
catch(Exceptione)
{
e.printStackTrace();
con=null;
}
returncon;
}
publicStatementgetStm()
{
try{
getConnection();
stm=con.createStatement();
}catch(Exceptione)
{
e.printStackTrace();
System.out.println("getStm()方法异常!
");
}
returnstm;
}
publicResultSetgetRs(Stringsql){
getStm();
if(sql==null)sql="";
try{
rs=stm.executeQuery(sql);
}catch(Exceptione){
e.printStackTrace();
System.out.println("getRs()方法异常!
");
rs=null;
}returnrs;
}
publicvoidclosed(){
try{
if(rs!
=null)rs.close();
}
catch(Exceptione){e.printStackTrace();}
try{
if(stm!
=null)stm.close();
}catch(Exceptione){e.printStackTrace();}
try{
if(con!
=null)con.close();
}catch(Exceptione){e.printStackTrace();}
}
publicStringcodeToString(Stringstr)
{//处理中文字符串的函数
Strings=str;
try
{
bytetempB[]=s.getBytes("ISO-8859-1");
s=newString(tempB);
returns;
}
catch(Exceptione)
{
returns;
}
}
publicvoidadduser(userbeanuser)throwsSQLException
{//注册用户信息入数据库
try
{
con=dbcon.getConnection();
PreparedStatementpstmt=con.prepareStatement("insertintostuInfovalues(?
?
?
?
?
?
?
?
)");
pstmt.setString(1,codeToString(user.getSno()));
pstmt.setString(2,codeToString(user.getSname()));
pstmt.setString(3,codeToString(user.getPassword()));
pstmt.setString(4,codeToString(user.getSdept()));
pstmt.setString(5,codeToString(user.getSex()));
pstmt.setString(6,codeToString(user.getPhone()));
pstmt.setString(7,codeToString(user.getQuestion()));
pstmt.setString(8,codeToString(user.getAnswer()));
pstmt.execute();
con.close();
}
catch(Exceptione)
{
}
}
publicvoidaddcourse(courseInfocourse)throwsSQLException
{//增加的课程信息入数据库
try
{
con=dbcon.getConnection();
PreparedStatementpstmt=con.prepareStatement("insertintocoursevalues(?
?
?
?
?
?
?
)");
pstmt.setString(1,codeToString(course.getCno()));
pstmt.setString(2,codeToString(course.getCname()));
pstmt.setString(3,codeToString(course.getTime()));
pstmt.setString(4,codeToString(course.getAddress()));
pstmt.setString(5,codeToString(course.getTeacher()));
pstmt.setString(6,codeToString(course.getPhone()));
pstmt.setString(7,codeToString(course.getXuefen()));
pstmt.execute();
con.close();
}
catch(Exceptione)
{
System.out.println("addcourse()异常!
");
}
}
//管理员用删除课程信息
publicvoiddeletecourse(StringcourseId)
{
Stringsql="deletefromcoursewherecno="+"'"+courseId+"'";
try{
con=getConnection();
Statementstm=con.createStatement();
stm.execute(sql);
con.close();
stm.close();
}catch(Exceptione)
{
e.printStackTrace();
System.out.println("deletecourse()函数异常!
");
}
}
//验证函数集
publicbooleancheckcourse(Stringnumber)
{//添加课程信息时的验证
booleannum=false;
try{
con=getConnection();
Statementstm=con.createStatement();
ResultSetresult=stm.executeQuery("select*fromcoursewherecno='"+number+"'");
if(result.next())
num=true;
else
num=false;
con.close();
stm.close();
result.close();
}
catch(Exceptione)
{
System.out.print("添加课程验证异常");
num=false;
}
returnnum;
}
publicbooleancheckuser_regester(Stringnumber)
{//
booleannum=false;
try{
con=getConnection();
Statementstm=con.createStatement();
ResultSetresult=stm.executeQuery("select*fromstuInfowheresno='"+numbe
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 学生 网上 选课 系统 毕业设计