上一次的文章,我们讲解了如何用JAVA访问MySql数据库,对数据进行增加删除修改查询。那么这次我们把具体的页面的数据库操作结合在一起,进行一次简单的学生信息操作案例。

  首先我们创建一个专门用于学生管理的ManageServlet。

  

  接着我们需要一个展现数据的页面,也就是 UserList.jsp

<%@page import="com.babybus.sdteam.vo.Student"%>
<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%
  String path = request.getContextPath();
  String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>学生信息管理</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body>
  <%=basePath %>
  <table border="1" width="100%" >
  <tr>
    <th>uid</th>
  <th>学生姓名</th>
  <th>年龄</th>
<th>班级</th>
<th>操作</th>
  </tr>
  <%
// 获取学生列表数据
List<Student> lsUser=(List)request.getAttribute("students");
if(lsUser==null||lsUser.size()==0){
    pageContext.setAttribute("theUser","1");
}else{
  // 遍历列表生成表格数据
   for(int i=0;i<lsUser.size();i++){
      pageContext.setAttribute("theUser",lsUser.get(i));
%>
<tr>
    <td>${theUser.id}</td>
     <td>${theUser.studentname}</td>
  <td>${theUser.age}</td>
  <td>${theUser.classname}</td>
    <td>
    <a href="AddUser.jsp?id=${theUser.id}">修改<a/>|
  <a href="Mangage?method=del&userid=${theUser.id}" onclick="return confirm('确定要删除么?')" }>删除</a>
  </td>
</tr>
<%
   }
}
%>
</table>
             <a href="AddUser.jsp">增加<a/>
</body>
</html>

  接下来我们需要一个进行增加修改的页面AddUser.jsp

<%@page import="com.babybus.sdteam.bo.ManageServlet"%>
<%@page import="com.babybus.sdteam.vo.Student"%>
<%@page import="com.babybus.sdteam.bo.LoginServlet"%>
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
response.setContentType("text/html;charset=UTF-8");
request.setCharacterEncoding("UTF-8");
%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
     <title>My JSP 'AddUser.jsp' starting page</title>
  <meta http-equiv="pragma" content="no-cache">
  <meta http-equiv="cache-control" content="no-cache">
  <meta http-equiv="expires" content="0">
  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  <meta http-equiv="description" content="学生信息管理">
  <link rel="stylesheet" type="text/css" href="styles.css">
  </head>
  <body>
  <%
  String id= request.getParameter("id");
   if(id!=null){
    ManageServlet loginServlet =new ManageServlet();
    Student student = loginServlet.getStudentById(id);
    pageContext.setAttribute("theUser",student);
    pageContext.setAttribute("method","update");
    pageContext.setAttribute("title","修改");
  }
  else{
    pageContext.setAttribute("method","add");
    pageContext.setAttribute("title","添加");
  }
  %>
  <form action="Mangage?method=${method}" method="post" >
  <input type="hidden" name="userid" value="${theUser.id}">
  <table width="100%" height="200px" border="1">
  <tr>
    <td colspan="2">${title}</td>
  </tr>
  <tr>
    <td align="right">学生名</td>
    <td>
  <input type="text" name="studentname" value="${theUser.studentname}">
</td>   
</tr>
  <tr>
    <td align="right">年龄:</td>
    <td> 
  <input type="text" name="age" value="${theUser.age}">
</td>   
</tr>     
<tr>
    <td align="right">班级:</td>
    <td> 
  <input type="text" name="classname" value="${theUser.classname}">
</td>   
</tr>
  <tr>
    <td colspan='2' align="center">     
  <input type="submit" value="保存" name="btnSubmit">        
  <input type="reset" value="重置" name="btnCancel">     
</td>
  </tr>
</table>
</form>
  </body>
</html>

  有了页面支撑,我们需要后台的Servlet进行数据处理转发

/**
* 业务处理
* @param req
* @param rep
* @throws IOException
* @throws ServletException
*/
public void process(HttpServletRequest req,HttpServletResponse rep) throws ServletException, IOException {
  String method = req.getParameter("method");
  System.out.println("操作:" + method);
  Student student = new Student();
  if(!"del".equals(method)) {
    // 进行编码转换,避免中文乱码
    String studentname = new String(req.getParameter("studentname").getBytes("ISO-8859-1"),"utf-8");
    int age = Integer.parseInt(req.getParameter("age"));
    String classname = new String(req.getParameter("classname").getBytes("ISO-8859-1"),"utf-8");
    student.setStudentname(studentname);
    student.setAge(age);
    student.setClassname(classname);
  }   StudentDao dao = new StudentDao();
  // 修改
  if("update".equals(method)) {
    String id = req.getParameter("userid");
    student.setId(Integer.parseInt(id));
    try {
      dao.updateStudent(student);
    } catch (SQLException e) {
      e.printStackTrace();
    }
  }
  // 增加
  else if("add".equals(method)) {
    try {
      dao.insertStudent(student);
    } catch(SQLException e) {
      e.printStackTrace();
    }
  }
  // 删除
  else if("del".equals(method)) {
    try {
      String id = req.getParameter("userid");
      dao.deleteStudent(Integer.parseInt(id));
    }catch (SQLException e) {
      e.printStackTrace();
    }
  }   ManageServlet manageservlet = new ManageServlet();
  // 获取全部列表
  List<Student> resultlist = manageservlet.getStudentByCondition(null);
  req.setAttribute("students", resultlist);
  RequestDispatcher dispatcher = req.getRequestDispatcher("UserList.jsp");
  dispatcher.forward(req, rep);
}

  上面就是全部的增加删除修改的代码。下面给出两个页面的截图效果

  通过上面的例子我们就可以很好的掌握了J2EE的入门

结语

  • 受益,掌握了J2EE的入门

本站文章为宝宝巴士 SD.Team原创,转载务必在明显处注明:(作者官方网站:宝宝巴士)

转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4579275.html

[JavaWeb基础] 004.用JSP + SERVLET 进行简单的增加删除修改的更多相关文章

  1. javaweb练手项目jsp+servlet简易购物车系统

    简易购物车项目 这是一个用intellij IDEA做的简易的javaweb项目,开发环境使用的jdk1.8和tomcat8以及mysql数据库. 1.项目开发准备: 创建github仓库 项目框架搭 ...

  2. jsp/servlet实现简单上传和下载

    使用JSP/Servlet简单实现文件上传与下载 jsp上传页面代码: <%@ page language="java" import="java.util.*&q ...

  3. javaweb基础(22)_Servlet+JSP+JavaBean实战登陆

    一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...

  4. IDEA+JSP+Servlet+Tomcat简单的登录示例

    1.用IDEA新建Java WEB项目并配置Tomcat 这一部分可以参考之前的一篇随笔 https://www.cnblogs.com/lbhym/p/11496610.html 2.导入Servl ...

  5. jsp+servlet+mysql简单实现用户登陆注册

    原码,项目中遇到的错误,解决方法,文章最后有链接可以获取 项目简介 *有的网友说在修改和删除时会触发error,建议各位不要去把用户名命名为中文! 功能描述 登陆,注册,用户一览表,修改,删除,添加, ...

  6. jsp+servlet的简单实现

    开发环境 tomcat7.0,MyEclipse 10 1.建一个简单的Web Project ,项目名jspServlet: 2.在src目录下建一个package ,为com.fandy.serv ...

  7. [JavaWeb基础] 007.Struts2的配置和简单使用

    1.框架简介 采用Struts能开发出基于MVC(Model-View-Controller)设计模式的应用构架,用于快速开发Java Web应用.Struts实现的重点在C(Controller), ...

  8. JSP+Servlet+mysql简单示例【图文教程】

    下载MYSQL:http://dev.mysql.com/downloads/ 下载安装版的 然后安装(安装步骤就不详细说了) 安装好之后,点击托盘图标,打开管理工具 创建一个数据库   数据库的名字 ...

  9. [JavaWeb基础] 006.Struts1的配置和简单使用

    1.框架简介 采用Struts能开发出基于MVC(Model-View-Controller)设计模式的应用构架,用于快速开发Java Web应用.Struts实现的重点在C(Controller), ...

随机推荐

  1. C. Game with Chips(陷阱暴力题)

    \(为什么说这是个陷阱呢??\) \(因为不管你脑洞多大,数学多好,都发现会束手无策\) \(每移动一次不知道往哪个方向,不知道先访问哪个点,同时要记录所有点的坐标,记录每个点是否访问过目标点.... ...

  2. 补 第三场多校杭电 费用流 K Subsequence

    K Subsequence 这个题目是这个人想吃东西,但是他每次吃的都是他的美味值都必须不递减,可以吃k次,问这个最大的美味值是多少. 这个是一个比较明显的费用流,建图也很好建,但是呢,这个题目卡sp ...

  3. jQuery的相关尺寸获取 - 学习笔记

    获取元素相对于文档的偏移量 获取当前元素相对于父级元素的偏移量 获取文档滚动距离 获取元素的宽度和高度 设置元素的宽度和高度 获取可视区域的宽度和高度 获取文档的宽度和高度 获取元素相对于文档的偏移量 ...

  4. java读源码 之 map源码分析(HashMap,图解)一

    ​ 开篇之前,先说几句题外话,写博客也一年多了,一直没找到一种好的输出方式,博客质量其实也不高,很多时候都是赶着写出来的,最近也思考了很多,以后的博客也会更注重质量,同时也尽量写的不那么生硬,能让大家 ...

  5. 一文搞懂HMM(隐马尔可夫模型)-转载

    写在文前:原博文地址:https://www.cnblogs.com/skyme/p/4651331.html 什么是熵(Entropy) 简单来说,熵是表示物质系统状态的一种度量,用它老表征系统的无 ...

  6. JVM入门--类加载器

    一.基础架构 概览 我们平时说的栈是指的Java栈,native method stack 里面装的都是native方法 细节架构图 二.类加载器 1.类的加载 方法区并不是存放方法的区域,其是存放类 ...

  7. layui的layer.msg,form提交

    layer.msg('提示文字',{shift:1,time:2000},function(){ location.reload();});其中shift是提示框的动画样式,-1为无动画form.on ...

  8. Docker之commit制作镜像

    一.docker是什么? Docker是一个为开发人员和系统管理员提供分布式应用程序的开放平台.它是一个开源的容器引擎,基于Go语言并遵从Apche2.0协议开源. 功能:Docker可以让开发者打包 ...

  9. ql的python学习之路-day3

    字典操作 特性: 1.无序的 2.key是唯一的 , ,,], ,,], ,,], }, ,,], 'bbb' : ['a', 'b', 'c'], }}

  10. R的安装以及包安装

        今天看论文,需要用到R语言的库,于是又折腾了半天..     其实并没有什么太大的问题,只是在第三方包的下载方面还有python中使用R方面遇到了问题: 第三方包的导入      其实在网上有 ...