博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JSP&Servlet牛刀小试:学生信息管理系统
阅读量:4322 次
发布时间:2019-06-06

本文共 20340 字,大约阅读时间需要 67 分钟。

    小弟这学期的JSP&JAVA SERVLET课程上完了,课程作业是学生信息管理系统,在开发过程遇到了许多问题,记录下来,作为自己学习的总结,也可以给大家作为参考。如果有错误的地方,多多包涵。

github地址如下:

    一、新建JAVA项目

            File->New->DynamicWebProject

            然后就是配置服务器,我用的是Tomcat,配置很简单,到官网下载好之后在项目新建中添加进去就可以了

            

二、引入Mysql的jar包

    因为要用到数据库和服务端交互,因此要引入mysql的jar包,然后在项目中利用JDBC技术操作数据库就可以了

    mysql的jar包在官网可以找到,我也上传到了百度网盘,分享给大家

    https://pan.baidu.com/s/1YfucuLovNKBa4JMci1gfCg

    然后在Java Resources中新建一个lib文件夹,把mysql的jar包粘贴到这里面;

    

    右键,如上图一样选择Add to Build Path就可以了,为了保险起见,可以在WebContent的lib文件中也这样引入一个sql的jar包。

    三、建立数据库连接工具

    把项目构建好了,引入了需要用的jar包,我们就可以开始进行开发了。我们与服务端交互,首先就要有个工具,来打开与数据库的连接。话不多说,直接上代码

package javabean;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class ConnDB {	private static String URL = "jdbc:mysql://localhost:3306/";	//数据库连接  "student"是数据库名	private static String USER = "root";//数据库账号	private static String PASSWORD = "root";//数据库密码	private  Connection conn = null;			/**	 * 无参构造函数默认的数据库为student	 */	public ConnDB() {		try {			URL="jdbc:mysql://localhost:3306/student?characterEncoding=utf-8";			Class.forName("com.mysql.jdbc.Driver");			} catch (ClassNotFoundException e) {			e.printStackTrace();			}	}		public ConnDB(String databaseName) {		try {		Class.forName("com.mysql.jdbc.Driver");		URL=URL+databaseName+"?characterEncoding=utf-8";		} catch (ClassNotFoundException e) {		e.printStackTrace();		}	}		//获取数据库连接	public Connection getConnction() {	try {	conn = DriverManager.getConnection(URL, USER, PASSWORD);	} catch (SQLException e) {	e.printStackTrace();	}	return conn;	}			//关闭数据库连接	public void closeCon(Connection con) throws Exception{	if(con!=null){	con.close();	}	}		 /**      * 根据传入的SQL语句返回一个结果集      *       * @param sql      * @return      * @throws Exception      */  	public ResultSet select(String sql) throws Exception {          Statement stmt = null;          ResultSet rs = null;          try {              stmt = conn.createStatement();              rs = stmt.executeQuery(sql);              return rs;          } catch (SQLException sqle) {              throw new SQLException("select data exception: "                      + sqle.getMessage());          } catch (Exception e) {              throw new Exception("System e exception: " + e.getMessage());          }        }        /**      * 根据传入的SQL语句向数据库增加一条记录      *       * @param sql      * @throws Exception      */  	public void insert(String sql) throws Exception {          PreparedStatement ps = null;          try {                ps = conn.prepareStatement(sql);               ps.executeUpdate();           } catch (SQLException sqle) {              throw new Exception("insert data exception: " + sqle.getMessage());          } finally {              try {                  if (ps != null) {                      ps.close();                  }              } catch (Exception e) {                  throw new Exception("ps close exception: " + e.getMessage());              }          }          try {              if (conn != null) {                  conn.close();              }          } catch (Exception e) {              throw new Exception("connection close exception: " + e.getMessage());          }      }        /**      * 根据传入的SQL语句更新数据库记录      *       * @param sql      * @throws Exception      */  	public void update(String sql) throws Exception {          PreparedStatement ps = null;          try {              ps = conn.prepareStatement(sql);              ps.executeUpdate();          } catch (SQLException sqle) {              throw new Exception("update exception: " + sqle.getMessage());          } finally {              try {                  if (ps != null) {                      ps.close();                  }              } catch (Exception e) {                  throw new Exception("ps close exception: " + e.getMessage());              }          }          try {              if (conn != null) {                  conn.close();              }          } catch (Exception e) {              throw new Exception("connection close exception: " + e.getMessage());          }      }        /**      * 根据传入的SQL语句删除一条数据库记录      *       * @param sql      * @throws Exception      */  	public void delete(String sql) throws Exception {           PreparedStatement ps = null;          try {              ps = conn.prepareStatement(sql);              ps.executeUpdate();          } catch (SQLException sqle) {              throw new Exception("delete data exception: " + sqle.getMessage());          } finally {              try {                  if (ps != null) {                      ps.close();                  }              } catch (Exception e) {                  throw new Exception("ps close exception: " + e.getMessage());              }          }          try {              if (conn != null) {                  conn.close();              }          } catch (Exception e) {              throw new Exception("connection close exception: " + e.getMessage());          }      }  			public static void main(String[] args) {		ConnDB connDB=new ConnDB();		try {			Connection connection=connDB.getConnction();			System.out.println("连接成功");			Statement stmt=connection.createStatement();			ResultSet rs=stmt.executeQuery("select * from studentdata");			while(rs.next()){				System.out.println(rs.getString(1));			}			connDB.closeCon(connection);		} catch (Exception e) {			// TODO: handle exception		}	}}

这里数据库连接的URL为jdbc:mysql://localhost:3306/  其中localhost:3306为用户名和端口,用':'分隔,用navicat连接到sql后就可以查看(navicat是一个很好用的数据库可视化工具,大家可以去官网下载一个来用)

        在navicat中可以看到我们的主机名为localhost,端口号为3306,OK,这就是我们要在jdbc:mysql://后面加的东西。大家可以看到我写了两个构造函数,一个无参,默认连接到student这个库,另一个需要一个String指定数据库名。

        拿默认连接来说,也就是student这个库,完整URL为:jdbc:mysql://localhost:3306/student?characterEncoding=utf-8 这里需要注意的是:如果我用jdbc:mysql://localhost:3306/student也是可以连接的上数据库的,但是在JDBC写入数据库的时候,会出现写入的值如果是中文,则会在数据库中乱码,所以我们可以在jdbc:mysql://localhost:3306/student加上?characterEncoding=utf-8指定我们写入时候的编码。

        大家在写完这个工具的时候可以在main中测试下,是否连接成功

    这样,我们的数据库连接工具就写好了。

    四、接下来就是jsp网页了

    我先把实现的成果图贴出来

 

    

 注册

 

注册成功

然后数据库中就会多出注册的信息(这里我新建了一个user表用来记录用户名和密码)

 

登陆

 

密码错误或用户未进行注册时会提醒,并且重新返回登录界面

 

登录成功后,直接进入学生信息管理系统界面,这里可以看到所有学生的信息(各位同学看到不要打我敲打)

在这个界面,可以对学生信息进行修改,删除,查询操作

 

 

 

添加学生

 

添加成功后:

 

系统会倒数,然后自动跳转至信息页面

 

 

 

删除学生

在删除前,系统会弹窗和用户再一次确认是否删除信息,以防误删

 

删除成功后

 

可以看到,刚才新增的记录已经被删除了

修改学生

点击修改按钮,即可进入修改页面,修改页面会自动填充好要修改学生的信息,用户只需要少许的改动即可修改信息

 

e.g.把姓名修改成“陈思成已被修改”

 

更改后的学生信息

 

查找学生

查询功能分为按学号查找,按姓名查找,按SQL语句查找

界面做的很简单,只是用来练习,没必要花大精力在界面上

 

按学号查找

 

按姓名查找

 

按SQL语句查找

例如,要查找地信2班的学生的学院,专业,名字信息,SQL语句如下图所示

 

查询结果如下图所示

系统自动对未加入查询的属性列赋null值

 

 

    好了,这就是我们要实现的功能,下面就来看代码吧,新建若干个jsp文件

 

 

    项目代码结构:

    

    每个页面的功能,我已经标注出来了,名字也能看出来哈哈。。

    接下来又是贴代码

    

Login_deal.jsp

 

<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%>
学生管理系统登录页

学生信息管理系统

用户名:
密码:

要注意的是,要把开头三个charset都改成UTF-8,这样才能在JSP中使用中文

这里用了一个脚本来验证用户名密码是否非空。

 

Register.jsp(注册页面)

 

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
注册管理员

管理员注册页面

用户名:
密码:

Register_done.jsp(注册处理页面)

 

<%@page import="javabean.ConnDB"%><%@page import="java.sql.*"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
<%request.setCharacterEncoding("UTF-8"); %>
注册结果<%try{ConnDB db=new ConnDB();Connection connection=db.getConnction();String sql="insert into user values("+user.getUsername()+","+user.getPassword()+")";db.insert(sql);out.print(""); }catch(Exception e){e.printStackTrace();out.print(""); }%>

Table.css(css文件,用于控制表格布局)

@charset "UTF-8";body{padding:0px;margin:0px;font-size:12px;}body a{color:#03515d;text-decoration:none;}body button{color:#03515d;}body span{color:#03515d;}.center_bottom input{color:#03515d;font-size:12px;height:20px;width:40px;padding:2px;vertical-align:middle;text-align:center;margin-bottom:6px;}/**************************布局部分********************/.table_div{width:1000px;padding:10px;margin:0 auto;}.div_clear{clear:both;}.left_top{background:url("./tab/images/leftbottom.gif");height:30px;width:12px;float:left;}.left_center{background:url("./tab/images/rfcenter.gif");height:530px;width:12px;float:left;}.left_bottom{background:url("./tab/images/leftbottom.gif");height:35px;width:12px;float:left;}.center_top{background:url("./tab/images/center.gif") repeat-x;height:30px;line-height:30px;width:900px;float:left;}.center_center{height:400px;width:900px;float:left;}.center_bottom{background:url("./tab/images/center.gif") repeat-x;height:35px;width:900px;float:left;line-height:35px;}.right_top{background:url("./tab/images/leftbottom.gif");height:30px;width:15px;float:left;}.right_center{background:url("./tab/images/rfcenter.gif");height:530px;width:15px;float:left;}.right_bottom{background:url("./tab/images/leftbottom.gif");height:35px;width:15px;float:left;}/**************************************表格内容***********************************/.table_content{margin:5px;border:1px solid #B5D6E6;width:890px;height:520px;overflow-x:hidden;overflow-y:auto;}.table_content table{width:100%;border:0;border-collapse:collapse;font-size:12px;}.table_content table tr:hover{background-color:#C1EBFF;}.table_content table th{border-collapse:collapse;height:22px;background:url("./tab/images/bg.gif");border-right:1px solid #B5D6E6;border-bottom:1px solid #B5D6E6;}.table_content table td{height:22px;word-wrap:break-word;max-width:200px;text-align:center;vertical-align:middle;border-right:1px solid #B5D6E6;border-bottom:1px solid #B5D6E6;}

 

studentInfo.jsp(学生信息管理页)

 

<%@page import="java.sql.ResultSet"%><%@page import="java.sql.Connection"%><%@page import="javabean.ConnDB"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><%request.setCharacterEncoding("UTF-8"); %>
学生信息查询结果
<%ConnDB connDB=new ConnDB();Connection connection=connDB.getConnction();String sql="select * from studentdata";ResultSet rs=connDB.select(sql);%>
学生信息:
下面的表格就是查询结果:
你当前的位置:[学生信息管理系统]-[学生信息表]
<%int count=0;while(rs.next()){out.print("
"); out.print("
"); out.print("
"); out.print("
"); out.print("
");out.print("
");out.print("
"); out.print("
");count++;}%>
学院名称 专 业 班 级 学 号 姓 名 操作
" + rs.getString(1).toString()+ " " + rs.getString(2).toString() + " " + rs.getString(3).toString() + " " + rs.getString(4).toString() + " " + rs.getString(5).toString() + " 删除"); out.print(" 编辑
  共有<%=count %>条记录,当前第 1/1 页
跳转到
<%if (rs != null) { rs.close(); } %>

这里就从数据库读取数据,然后输出成表格

Insert.jsp(增加学生记录页)

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
添加学生信息记录

添加学生信息记录

学院名称:
专  业:
班  级:
学  号:
姓  名:

 

InsertDeal.jsp(添加学生信息处理页)

 

<%@page import="javabean.ConnDB"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><%request.setCharacterEncoding("UTF-8"); %>
学生信息添加页<%String academy=request.getParameter("academy");String major=request.getParameter("major");String classs=request.getParameter("classs");String sno=request.getParameter("sno");String name=request.getParameter("name");try{ConnDB db=new ConnDB();db.getConnction();//String sql="insert into studentdata values('"+academy+"','"+major+"','"+classs+"','"+sno+"','"+name+"')";String sql=String.format("insert into studentdata (academy,major,class,sno,name)"+"values('%s','%s','%s','%s','%s')",academy,major,classs,sno,name);System.out.println(sql);db.insert(sql);out.print("
"); String jsscript=" ";out.print(jsscript); }catch(Exception e){e.printStackTrace();out.print("
"); String jsscript=" ";out.print(jsscript); }%>

 

Update.jsp(信息更新页)

 

<%@page import="java.sql.*"%><%@page import="javabean.ConnDB"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
更新学生信息<%ConnDB db=new ConnDB();db.getConnction();String id=request.getParameter("id");String sql="select * from studentdata where id='"+id+ "'";ResultSet rs=db.select(sql);rs.next();%>

修改学生信息页

学院名称: />
专  业: />
班  级: />
学  号: />
姓  名: />
/><%if(rs!=null){rs.close();}%>

 

UpdateDeal.jsp(信息更新处理页)

 

<%@page import="javabean.ConnDB"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><%request.setCharacterEncoding("UTF-8"); %>
更新学生信息<%String academy=request.getParameter("academy");String major=request.getParameter("major");String classs=request.getParameter("classs");String sno=request.getParameter("sno");String name=request.getParameter("name");int id=Integer.parseInt(request.getParameter("id"));System.out.println(id);System.out.println(academy);System.out.println(major);System.out.println(classs);System.out.println(sno);System.out.println(name);ConnDB db=new ConnDB();db.getConnction();String sql="update studentdata set academy='"+academy+"', major='"+major+"',class='"+classs+"',sno='"+sno+"',name='"+name+"' where id="+id;try{db.update(sql);out.print("
"); String jsscript=" ";out.print(jsscript); }catch(Exception e){e.printStackTrace();out.print("");out.print("
"); String jsscript=" ";out.print(jsscript); }%> 成功修改数据! 查看当前数据库数据

 

Delete.jsp(删除信息页面)

 

<%@page import="javabean.ConnDB"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><%request.setCharacterEncoding("UTF-8"); %>
学生信息删除页面<%try{ConnDB db=new ConnDB();db.getConnction();String id=request.getParameter("id");System.out.println(id);String sql_delete="delete from studentdata where id= '" +id+"'";db.delete(sql_delete);out.print("
"); String jsscript=" ";out.print(jsscript); }catch(Exception e){e.printStackTrace();out.print("");out.print("
"); String jsscript=" ";out.print(jsscript); }%>

 

Query.jsp(查询页面)

 

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
选择查询方式

 

queryByXueHao.jsp(按学号查询页面)

 

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
学生信息查询

请输入学号,进行查询

学号:
          

 

QueryByXingMing.jsp(按姓名查询)

 

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
学生信息查询

请输入姓名,进行查询

姓名:
          

 

QueryByXingMingDone.jsp(姓名查询界面)

 

<%@page import="java.sql.ResultSet"%><%@page import="java.sql.Connection"%><%@page import="javabean.ConnDB"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><%request.setCharacterEncoding("UTF-8"); %>
学生信息查询结果
<%String name=request.getParameter("name");ConnDB connDB=new ConnDB();Connection connection=connDB.getConnction();String sql="select * from studentdata where name='"+name+"'";ResultSet rs=null;try{rs=connDB.select(sql);}catch(Exception e){e.printStackTrace();out.print("");out.print("window.location='query.jsp'");}%>
学生信息:
下面的表格就是查询结果:
你当前的位置
[学生信息管理系统]-
[学生查询]-[按姓名语句查询]
<%int count=0;if(!rs.next()){out.print("
"); out.print("
");out.print("
");}else{rs.beforeFirst();while(rs.next()){out.print("
"); out.print("
"); out.print("
"); out.print("
"); out.print("
");out.print("
");out.print("
"); out.print("
");count++;}}%>
学院名称 专 业 班 级 学 号 姓 名 操作
"); out.print("
查询失败:未查询到该学生记录"+ "
8秒后系统会自动跳转,也可点击本处直接跳转重新查询 "+ "
"); String jsscript=" ";out.print(jsscript);out.print("
" + rs.getString(1).toString()+ " " + rs.getString(2).toString() + " " + rs.getString(3).toString() + " " + rs.getString(4).toString() + " " + rs.getString(5).toString() + " 删除"); out.print(" 编辑
  共有<%=count %>条记录,当前第 1/1 页
跳转到
<%if (rs != null) { rs.close(); } %>

 

QueryBySQL.jsp(按照SQL语句进行查询)

 

<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>
学生信息查询

使用SQL查询语句进行查找

SQL语句:          
以下是注意事项

只支持简单查询,例如select [属性] from [表] where [约束]。不支持连接查询

  • 学生信息表名称--->studentdata
  • 属性列:academy--->学院名
  • 属性列:major--->专业名
  • 属性列:class--->班级
  • 属性列:sno--->学号
  • 属性列:name--->姓名

 

QueryBySQLDone.jsp(按SQL语句查询结果)

 

<%@page import="java.util.*"%><%@page import="java.sql.ResultSetMetaData"%><%@page import="java.sql.ResultSet"%><%@page import="java.sql.Connection"%><%@page import="javabean.ConnDB"%><%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><%request.setCharacterEncoding("UTF-8"); %>
学生信息查询结果
<%String sql=request.getParameter("sql");ConnDB connDB=new ConnDB();Connection connection=connDB.getConnction();ResultSet rs=null;try{rs=connDB.select(sql);}catch(Exception e){e.printStackTrace();out.print("");out.print("window.location='query.jsp'");}%>
学生信息:
下面的表格就是查询结果:
你当前的位置
[学生信息管理系统]-
[学生查询]-[按SQL语句查询]
name=new ArrayList
();String columnName;//定义开关,true的位置说明是有数据的boolean[] switchs=new boolean[]{false,false,false,false,false,false};for(i=1;i<=numColumn;i++){columnName=resultSetMetaData.getColumnName(i);System.out.println(columnName);switch(columnName){case "academy":switchs[0]=true; break;case "major":switchs[1]=true; break;case "class":switchs[2]=true; break;case "sno":switchs[3]=true; break;case "name":switchs[4]=true; break;case "id":break;default:break;}}//定义rs的列数int rsColumn;while(rs.next()){//i确定位置,rsColumn确定数据在rs中的位置i=1;rsColumn=0;out.print("
<%int count=0;if(!rs.next()){out.print("
"); out.print("
");out.print("
");}else{rs.beforeFirst();//获取列数ResultSetMetaData resultSetMetaData=rs.getMetaData();int numColumn=resultSetMetaData.getColumnCount();int i;List
"); for(;i<=6;i++){if(switchs[i-1]){if(rsColumn<=numColumn){rsColumn++;}out.print("
");}else{if(i!=6){out.print("
");}else{out.print("
");}}}out.print("
");count++;}}%>
学院名称 专 业 班 级 学 号 姓 名 操作
"); out.print("
查询失败:未查询到该学生记录"+ "
8秒后系统会自动跳转,也可点击本处直接跳转重新查询 "+ "
"); String jsscript=" ";out.print(jsscript);out.print("
" + rs.getString(rsColumn).toString()+ " " +"null"+ " " +"暂不支持操作"+ "
  共有<%=count %>条记录,当前第 1/1 页
跳转到
<%if (rs != null) { rs.close(); } %>

 

 

 

 

 

 

转载于:https://www.cnblogs.com/zhongHW/p/11047025.html

你可能感兴趣的文章
【转载】OmniGraffle (一)从工具栏开始
查看>>
初识ionic
查看>>
java 中打印调用栈
查看>>
开发 笔记
查看>>
数据挖掘算法比赛 - 简单经验总结
查看>>
生成商户订单号/退款单号
查看>>
使用Android OpenGL ES 2.0绘图之六:响应触摸事件
查看>>
我们过去几年做对了哪些事
查看>>
ubuntu 16.04LTS
查看>>
javascript深入理解js闭包
查看>>
Java Bigdecimal使用
查看>>
SQL注入之绕过WAF和Filter
查看>>
jquery validate使用方法
查看>>
DataNode 工作机制
查看>>
windows系统下安装MySQL
查看>>
错误提示总结
查看>>
实验二+070+胡阳洋
查看>>
Linux IPC实践(3) --具名FIFO
查看>>
Qt之模拟时钟
查看>>
第一次接触安卓--记于2015.8.21
查看>>