1.团队课程设计博客

团队课程设计博客链接

2.个人负责模块或任务说明

①.Menu

  • Menu.jsp

    • 在页面中给出提示,用HTML的<input.../>,与下一个跳转页面进行连接,即点击后进入下一个页面
  • MenuTeacher.jsp

    • 利用Menu.jsp进行具体化完善和修改,由于教师与学生的权限不同,将教师和学生的功能选择进行区分

    • 教师:增、删、改、查

    • 学生:改,查(个人)

    • 确认后跳转到相应的页面

②Login

  • Login.jsp

    • 通过账号和密码匹配正确后,进入Menu界面

    • 教师与学生分别位于不同的表中,需要分开处理

  • StudentLogin.jsp

    • 学生通过在页面输入学号密码进行账号登录

    • 将输入的学号在数据库中进行查找,找到后进行密码比较,一直即进入菜单界面

③Delete

  • Delete.jsp

    • 提示输入需要删除的学生学号
    • 确认后,通过delete(String stuno)方法,最后跳转至删除成功与否界面
  • DeleteSuccess.jsp

    • Delete页面中的学号存在,显示该学生信息;否则,提示找不到,删除失败

    • 返回菜单界面

3.自己的代码提交记录截图

4.自己负责模块或任务详细说明

①Login----提示输入账户和密码进行登录,教师与学生在不同的数据库表中,教师的表名为teachers,内含账号和密码;学生的表名为students,内含学生个人信息与成绩。

  • 登陆界面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>学生登录</title>
</head>
<body>
<form name="postForm" action="LoginStuSuccess.jsp" method="post">
<p>账号 :<input type="text" name="stuno" /></p>
<p>密码 :<input type="password" name="password" /></p>
<input type="submit" value="登录" />
</form>
</body>
</html>
  • 登录页面

  • 登录后(数据库找到对应学号,比较密码,成功即登录,失败即刷新重新输入)
<%@ page language="java" import="java.util.*,StudentScore.*" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>学生登录成功</title>
</head>
<body>
<form name="postForm" action="MenuStudent.jsp" method="post">
<%
StudentDao sdao = new StudentDaoJDBC();
String no = request.getParameter("stuno");
int stuno = Integer.parseInt(no);
String password = request.getParameter("password");
if(sdao.login(stuno,password)!=1){
response.sendRedirect("StudentLogin.jsp"); }
else
{ %>
<td>学号:<input type="text" id="a" name="stuno" value=<%=no%>></td>
<p>登陆成功!</p>
<input type="submit" value="Menu" />
<%
}
%>
</form>
</body>
</html>
  • 学生登录成功进入菜单界面(登录失败刷新页面重新输入)

  • 登录过程方法(可具体提示登录失败的原因,密码错误或学号不存在)
		@Override
public int login(int no, String password) {
// TODO Auto-generated method stub
int result=-1;
Connection conn = null;
PreparedStatement pstat = null;
ResultSet rs = null;
String sql = "select * from students where stuno=?";//表中有id和name这列
try {
conn = JDBCUtil.getConnection();
pstat = conn.prepareStatement(sql);
pstat.setInt(1,no);
rs = pstat.executeQuery();
int stu = 0;
String stupassword=null;
while(rs.next()){
stupassword=rs.getString("password");
stu=rs.getInt("stuno");
}
if(stu>0){
if(stupassword.equals(password)){
System.out.println("登录成功!");
result = 1;
}
else{
System.out.println("登录失败,密码错误!");
}
}else {
System.out.println("登录失败,学号不存在!");
}
}catch (SQLException sqle) {
sqle.printStackTrace();
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCUtil.realeaseAll(rs,pstat, conn);
}
return result;
}

②Menu----根据学生与老师的权限进行排版,(教师:增、删、改、查; 学生:改,查(个人)),每一个选择按钮点击之后进入到相应界面

  • 初步界面(未修订)
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title> 菜单选项</title>
</head>
<body>
<form name="fm" method="post">
<p>功能选择</p>
<p>1.录入学生成绩,点击<input type="button" name="btn2" onclick="document.fm.action='EnterStudentScore.jsp';document.fm.submit();"
value="录入"/></p>
<p>2.删除学生信息,点击<input type="button" name="btn1" onclick="document.fm.action='Delete.jsp';document.fm.submit();"
value="删除"/></p>
<p>3.修改学生信息,点击<input type="button" name="btn2" onclick="document.fm.action='UpdateView.jsp';document.fm.submit();"
value="修改"/></p>
<p>4.查找学生信息,点击<input type="button" name="btn2" onclick="document.fm.action='findStudent.jsp';document.fm.submit();"
value="查找"/></p>
</form>
</body>
</html>
  • 老师界面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title> 老师菜单</title>
</head>
<body>
<form name="fm" method="post">
<p>功能选择</p>
<p>1.录入学生成绩,点击<input type="button" name="btn2" onClick="document.fm.action='MenuCourse.jsp';document.fm.submit();"
value="录入"/></p>
<p>2.删除学生信息,点击<input type="button" name="btn1" width="100" heigth="20" onClick="document.fm.action='Delete.jsp';document.fm.submit();"
value="删除"/></p>
<p>3.修改学生信息,点击<input type="button" name="btn2" onClick="document.fm.action='UpdateView1.jsp';document.fm.submit();"
value="修改"/></p>
<p>4.查找学生信息,点击<input type="button" name="btn2" onClick="document.fm.action='findStudent.jsp';document.fm.submit();"
value="查找"/></p>
<p>5.所有学生信息,点击<input type="button" name="btn2" onClick="document.fm.action='ShowStudentMessage.jsp';document.fm.submit();"
value="导出"/></p>
</form>
</body>
</html>

③Delete

  • delete方法(信息仅学号唯一,根据学号进行删除操作)
@Override
public int delete(String no) {
// TODO Auto-generated method stub
Connection conn = null;
Statement st= null;
ResultSet resultset=null;
String sql = "delete from students where stuno="+no;
int result = -1;
try {
conn = JDBCUtil.getConnection();
st = conn.createStatement();
int i=st.executeUpdate(sql);
}catch (SQLException sqle) {
sqle.printStackTrace();
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCUtil.realeaseAll(null,st, conn);
}
return result;
}
  • delete界面
<%@ page language="java" import="java.util.*,StudentScore.*" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>删除学生</title>
</head>
<body>
<form name="postForm" action="DeleteSuccess.jsp" method="post">
<p>请输入需要删除的学生学号</p>
<p>
学号:<input type="text" name="stuno" />
</p>
<input type="submit" value="Delete" />
</form>
</body>
</html>

  • delete成功或失败
<%@ page language="java" import="java.util.*,StudentScore.*" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>删除成功</title>
</head>
<body>
<form name="postForm" action="MenuTeacher.jsp" method="post">
<%
StudentDao sdao = new StudentDaoJDBC();
String no = request.getParameter("stuno");
int s = sdao.delete(no);
%>
<p>删除成功!返回菜单</p>
<input type="submit" value="MENU" />
</form>
</body>
</html>

5.课程设计感想

 通过这次课设,对数据库,Dao,JDBC等认识加深了很多,不仅如此,还积累了一些课外的新知识;虽然过程中碰到许多令人崩溃和无语的问题,,在jsp与Java还有一些不熟悉的地方,所幸最终大部分问题都能解决;还有重要的一点是团队协作很重要,有时候你忽略的小问题别人一眼就能发现,虽然我的能力不够好,但是到最后看到自己的代码(虽然不多)能在整个项目中运行还是很激动很开心的;遗憾的是时间紧,技术弱,没能把想法更加完善出来。

Java课程设计

Java课程设计—学生成绩管理系统(201521123004-林艺如)的更多相关文章

  1. Java课程设计—学生成绩管理系统(201521123002 林楚虹)

    1. 团队课程设计博客链接 团队博客链接 2.个人责模块或任务说明 根据学生学号查找学生成绩 根据学生姓名(支持模糊匹配)查找学生成绩 用POI技术导出Excel文件 3.自己的代码提交记录截图 4. ...

  2. Java课程设计——学生成绩管理系统(201521123003 董美凤)

    Java课程设计--学生成绩管理系统(201521123003 董美凤) 1.团队课程设计博客链接 学生成绩管理系统博客链接 2.个人负责模块或任务说明 信息修改 密码修改 部分界面设计 3.自己的代 ...

  3. Java课程设计—学生成绩管理系统(201521123005 杨雪莹)

    一.团队课程设计博客链接 学生成绩管理系统 二.个人负责模块或任务说明 学生成绩录入 显示所有学生信息 显示各科平均成绩 显示学生成绩(按降序排序) 三.自己的代码提交记录截图 四.自己负责模块或任务 ...

  4. Java课程设计—学生成绩管理系统

    一. 团队名称.团队成员介绍(需要有照片) 团队名称:进击的712 团队成员 杨雪莹[组长] 201521123005 网络1511 林楚虹 201521123002 网络1511 董美凤 20152 ...

  5. Java课程设计—学生成绩管理系统(54号童欢)

    1. 团队课程设计博客链接 http://www.cnblogs.com/wufuckshuo/p/7063183.html 2.个人责模块或任务说明 负责模块/任务:主函数(调用其他的功能函数),添 ...

  6. Java课程设计--学生成绩管理系统

    一.团队名称: 团队成员 林艺薇 201721123032 网络1712 黄毓颖 201721123033 网络1712 唐川 201721123034 网络1712 梁才玉 201721123038 ...

  7. JAVA课程设计 学生成绩管理

    学生成绩管理 可实现功能: 添加学生功能:姓名.学号.性别.出生年月日.(学号自动生成且唯一) 添加学生成绩功能:每个人都有数学.Java与体育四门课,可分课程输入成绩. 根据学生学号查找学生成绩功能 ...

  8. Java课程设计 学生基本信息管理系统 团队博客

    学生基本信息管理系统团队博客 项目git地址 https://git.oschina.net/Java_goddess/kechengsheji 项目git提交记录截图 项目功能架构图与主要功能流程图 ...

  9. JAVA课程设计---学生基本信息管理系统(201521123039 王兴)

    1.团队课程设计博客链接 http://www.cnblogs.com/zyjjj/p/7061880.html 2.个人负责模块或任务说明 函数 功能说明 Search 查找学生信息,分为两种查找方 ...

随机推荐

  1. 安卓开发中Spinner控件的使用

    在安卓手机应用开发中,Spinner对象常用方法有以下五种. 用法 1 :以资源方式,静态展示 Spinner 选项 用法 2 :以代码方式,动态展示 Spinner 选项 用法 3 :同时显示图片和 ...

  2. MJExtension框架源码分析

    iOS开发中经常会用到数据和模型的互相转换,大致有两种转换方式:1.手动写转换的代码,2.利用开源库进行转换.常用的开源库有:JSONModel.Mantle.MJExtension.YYModel等 ...

  3. HTTP协议发展介绍

    HTTP协议工作于C/S架构上,是万维网服务器传输超文本到本地客户端的一种应用层协议,全称是:Hyper Text Transfer Protocol(超文本传输协议),HTTP是基于TCP/IP通信 ...

  4. 基于FPGA的均值滤波算法实现

    我们为了实现动态图像的滤波算法,用串口发送图像数据到FPGA开发板,经FPGA进行图像处理算法后,动态显示到VGA显示屏上,前面我们把硬件平台已经搭建完成了,后面我们将利用这个硬件基础平台上来实现基于 ...

  5. Oracle 与Mysql区别

    1.组函数用法规则 mysql中组函数在select语句中可以随意使用,但在oracle中如果查询语句中有组函数,那其他列名必须是组函数处理过的,或者是group by子句中的列否则报错 eg: se ...

  6. LAMP环境的搭建(四)----Apache下部署项目

    根据前文完成了LAMP基本环境的安装,那么接下来就是部署线上的环境了. yum 安装的apache 目录存在于  /etc/httpd apache最重要的文件就是 httpd.conf.  目录再 ...

  7. Win7里面如何把这一堆图标放进那个右下角的小三角框框

    Win7里面如何把这一堆图标放进那个右下角的小三角框框.. Win7里面如何把这一堆图标放进那个小框框:1.在任务栏空白处右击,点击属性:2.在属性中的通知区域-->点击自定义按钮:3.去除勾选 ...

  8. Java中的标识符和关键字

    1.标识符 含义:标识符用于给程序中的类.变量.方法命名的符号. 组成:数字(0-9).字母(a-z)(A-Z).下划线(_).美元符号$. 命名规则:1.数字不能够作为命名符号的开头 2.不能够使用 ...

  9. 十条最有效的PCB设计黄金法则

    十条最有效的PCB设计黄金法则 尽管目前半导体集成度越来越高,许多应用也都有随时可用的片上系统,同时许多功能强大且开箱即用的开发板也越来越可轻松获取,但许多使用案例中电子产品的应用仍然需要使用定制PC ...

  10. C/C++资料网站

    1.C语言基础知识讲解 http://c-faq-chn.sourceforge.net/ccfaq/node1.html 2.C++参考手册中文版 http://zh.cppreference.co ...