项目简述:

基于java web实现学生卡管理系统,用户包括学生和学生处,分别实现以下功能。

学生:

1.对本人登录密码的修改

2.申请补办学生卡

3.查看学生卡补办状态

学生处:

1.对学生信息的管理(包括对信息的增删改查)

2.受理学生证的补办申请

3.查询学生证补办记录


一、项目实现思路

在此次javaweb的项目中,我采用mysql数据库对数据进行管理,前端界面采用JSP编写,利用JavaBean实现用户与数据库之间的映射。难点在于实现学生端与学生处端的信息互动,说到底都是利用嵌入式sql语言对mysql数据库的读取、更新与在前端页面显示的问题。编写代码期间,还设置了session变量,将页面中所涉及并且需要利用的用户变量储存在session变量中。


二、数据库设计

该项目基于mysql数据库,在mysql中创建studentcard数据库,并且在studentcard中建立admin(学生处)、student(学生)、apply_info(申请信息)、log(补办日志)四张表。

数据库操作代码:

    Connection conn = null;
Statement st = null;
ResultSet rs = null;
public BaseDAO()
{
try{
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/studentcard";// 连接url字符串
String user = "root";// 数据库用户名
String password = "";// 数据库密码
this.conn=DriverManager.getConnection(url,user,password);
this.st=this.conn.createStatement();
this.rs=null; }catch(Exception ex)
{ex.printStackTrace();
} } public String doUpgrade(String sql)
{ //数据库更新操作
try{
if(this.st!=null)
this.st.executeUpdate(sql);
return "";
}catch(Exception ex)
{
ex.printStackTrace();
return ex.getMessage();
}
}
public ResultSet doQuery(String sql)
{ //数据库查询操作
try{
this.rs=this.st.executeQuery(sql); }catch(Exception ex)
{
ex.printStackTrace(); }
return this.rs;
}

三、功能展示 & 代码

1.登录

//管理员身份验证登录关键代码
sql="select * from admin where id='"+user.getUserId()+"' and password= '"+user.getUserPassword()+"'";
ResultSet rs=db.doQuery(sql);
if( rs.next())
{
String userName = rs.getString("name");
System.out.println("sessionUserName" + userName);
request.getSession().setAttribute("sessionUserId", user.getUserId());
request.getSession().setAttribute("sessionUserName", userName);
user.setPassed(true);
out.print("Success!");
response.sendRedirect("MainIndex.jsp");
}
else
{
out.print("<font color=red>用户名或口令不正确</font><br>");
}

2.查询全部学生信息 & 查询个人学生信息

//查询全部学生信息& 以表格的形式输出 关键代码
ResultSet rs=db.doQuery("select * from student");
out.println("学生信息如下:<br>");
out.println("<table border=1><thead><tr>");
out.println("<th>学号</th><th>姓名</th><th>学院</th><th>专业</th><th>密码</th></tr></thead>");
out.println("<tbody>");
while(rs.next())
{
String id=rs.getString("id");
String un=rs.getString("sname");
String co=rs.getString("college");
String dp=rs.getString("sdept");
String pd=rs.getString("password"); out.println("<tr><td>"+id+"</td>");
out.println("<td>"+un+"</td>");
out.println("<td>"+co+"</td>");
out.println("<td>"+dp+"</td>");
out.println("<td>"+pd+"</td></tr>");
}
out.println("</tbody></table>");

3.学生申请补办学生卡

    //学生申请补办学生卡 & 将申请信息插入到apply_info表中
String name=request.getParameter("name");
String id=request.getParameter("id");
String college=request.getParameter("college");
String department=request.getParameter("department");
String userId = session.getAttribute("sessionUserId").toString(); if(name!=null && id!=null && college!=null && department!=null && userId.equals(id))
{ String sql="insert into apply_info(id,sname,college,sdept,state) values("+ "'"+ id+"','"+name+"','"+college+"','"+department+"','"+"未补办"+"')";
//System.out.println(sql);
String rs=db.doUpgrade(sql);
out.print("申请成功");
}

4.学生处受理学生卡补办

    //完成补办
String id=request.getParameter("id");
String name = request.getParameter("name"); //System.out.println(id);
if(id != null){
String sql = "update apply_info set state = '补办完成' where id='" + id +"'";
//System.out.println(sql);
String rs1 =db.doUpgrade(sql);
String userId = session.getAttribute("sessionUserId").toString();
String userName = session.getAttribute("sessionUserName").toString();
//System.out.println("userId = "+ userId);
//System.out.println("userUserName = "+ userName);
sql="insert into log(id,name,sid,sname) values("+"'"+userId+"'"+",'"+userName+"','"+id+"','"+name+"')";
//System.out.println(sql);
String rs2 = db.doUpgrade(sql);
response.sendRedirect("Repair.jsp"); sql = "delete from apply_info where state = '补办完成'";
String rs3 = db.doUpgrade(sql);
//response.sendRedirect("Repair.jsp");
}

5.学生查看受理状态

    //在apply_info表中读数据并且输出到jsp界面中,只能查看当前用户的受理补办状态
String userId = session.getAttribute("sessionUserId").toString();
System.out.println(userId);
String sql = "select * from apply_info where id = '" + userId+ "'";
ResultSet rs=db.doQuery(sql);
if(rs.next()){
String id=rs.getString("id");
String name=rs.getString("sname");
String college=rs.getString("college");
String department = rs.getString("sdept");
String state = rs.getString("state");
out.print("您的补办信息:<br>");
out.print("........................................................................<br>");
out.print("学号:"+id+"<br/>");
out.print("姓名:"+name+"<br/>");
out.print("学院:"+college+"<br/>");
out.print("专业:" + department + "<br/>");
out.print("状态:" + state + "<br>");
out.print("........................................................................");
}else{
out.print("无申请,你看什么看!");
}

6.学生处查看受理日志

//从log表中读出所有的补办日志输出到JSP页面中
ResultSet rs=db.doQuery("select * from log");
out.println("发放记录如下:<br>");
out.println("..............................................................................................<br>");
while(rs.next())
{
String userId=rs.getString("id");
String userName=rs.getString("name");
String sid=rs.getString("sid");
String sname=rs.getString("sname");
//String pd=rs.getString("password");
out.print("管理员id:" + userId + " " );
out.println("管理员name:" + userName + "<br>");
out.print("学生id:" + sid + " ");
out.println("学生name:" + sname + "<br>");
out.println("............................................................................................." + "<br>" ); }

对于其他的学生信息增、删、改、查功能不在一一赘述,代码部分与上述功能代码相似。

四、项目地址链接

项目链接请点击:Student_Card_System

web项目_学生证管理系统的更多相关文章

  1. Java Web项目 慧心人力资源管理系统

    题目:慧心人力资源管理系统 文档下载:https://download.csdn.net/download/weixin_44893902/16336711 完整项目下载:https://downlo ...

  2. 第一个Java web项目:员工管理系统

    要求: 做一个登陆页面,实现登录,用户名和密码都是admin,登录成功后,用session记录用户名,登录失败,请提示失败原因. 做一个简单的管理系统,实现注册,修改,查询,删除 员工的功能,注册内容 ...

  3. Java Web项目_部门内部留言板

    t_user用户登录数据表 用户登录界面 JSP开发 通过post请求提交给Servlet处理 Servlet处理连接数据库的处理 登陆成功服务器跳转RequestDispatcher到main.js ...

  4. java web 项目 图书管理系统的设计与实现

     java web 项目 图书管理系统的设计与实现

  5. 简易商品信息管理系统——首个Web项目

    正文之前 在学习了一段时间的Java Web的内容之后,当然需要有个项目来练练手,我相信大多数人的首选项目都是信息管理系统吧,所以我选择了商品信息管理系统 目前项目源码已全部上传至GitHub,欢迎大 ...

  6. 【Java Web】简易商品信息管理系统——首个Web项目

    正文之前 在学习了一段时间的Java Web的内容之后,当然需要有个项目来练练手,我相信大多数人的首选项目都是信息管理系统吧,所以我选择了商品信息管理系统 目前项目源码已全部上传至GitHub,欢迎大 ...

  7. web项目自定义路由_实现静态资源URL控制

    前言: IIS会默认把:图片.JS.HTML.CSS这些文件当成静态资源处理,为了减少服务器压力,默认这些静态资源是不走URL路由规则控制的. 作为小白及初学者,本人对这些了解甚少,补充基础知识吧: ...

  8. Spring_day01--注入对象类型属性(重点)_P名称空间注入_注入复杂类型属性_IOC和DI区别_Spring整合web项目原理

    注入对象类型属性(重点) Action要new一个service对象,Service中又要new一个Dao对象,现在把new的过程交给spring来操作 1 创建service类和dao类 (1)在s ...

  9. Maven创建web项目:SpringMVC+Mybatis 【转】

    IDEA14创建Maven管理的SpringMVC+Mybatis,web项目 项目构建步骤 1.File->New->Project 勾选Create from archetype 点击 ...

随机推荐

  1. 转:把存储过程结果集SELECT INTO到临时表

    把存储过程结果集SELECT INTO到临时表   在开发过程中,很多时候要把结果集存放到临时表中,常用的方法有两种.   一. SELECT INTO  1. 使用select into会自动生成临 ...

  2. ETL技巧应用(高级应用介绍:准备区运用、 时间戳的运用、日志表的运用、使用调度)

    1.1    准备区运用 a.在构建数据仓库时,数据源位于一服务器上,数据仓库在另一服务器端,数据源Server端访问频繁,并且数据量大,需要不断更新, b.建立准备区数据库: >将数据抽取到准 ...

  3. CentOS7 配置静态 ip

    1. 为 CentOS7 配置静态 ip 1.1 修改文件/etc/sysconfig/network-scripts/ifcfg-ens33 sudo vi /etc/sysconfig/netwo ...

  4. 《Effective C++》 目录:

    转自:http://blog.csdn.net/KangRoger/article/details/44706403 目录 条款1:视C++为一个语言联邦 条款2:尽量以const.enum.inli ...

  5. Beta阶段第二次冲刺

    Beta阶段第二次冲刺 严格按照Git标准来,组员有上传Git的才有贡献分没有的为0 代码签入图 1.part1 -站立式会议照片 2.part2 -项目燃尽图 3.part3 -项目进展 1.正在进 ...

  6. 如何修改word文档中每行字符的最大默认值和每页最大行数默认值

    事情起因是这样的,小明在写论文的过程中,发现自己的文档的字与字的间距看起来比其他人的字符间距大,于是觉得奇怪,明明设置了一样的格式啊,设置每行38个字符,每页34行,为什么小明写的文档字符间距看着比较 ...

  7. saltstack二次开发(二)

    Saltstack的api Salt-api有两种方式,一种是函数的形式,有人家定义好的函数,我们可以直接调用,直接写python代码调用函数或者类就可以了.第二种形式是salt-api有封装好的ht ...

  8. div设置contenteditable="true" 光标消失:原因

    原因1:document.onselectstart= function(){return false;}; 原因2:父层设置了user-select:none 导致 子层设置了 contentedi ...

  9. 【洛谷】【单调队列】P2032 扫描

    [题目描述:] 有一个 1 ∗ n 的矩阵,有 n 个正整数. 现在给你一个可以盖住连续的 k 的数的木板. 一开始木板盖住了矩阵的第 1 ∼ k 个数,每次将木板向右移动一个单位,直到右端与第 n ...

  10. python-json模块扩展

    sort_keys=True, indent=4, separators=(',', ': ') 格式 json.dumps(response,sort_keys=True, indent=4, se ...