Servlet+JSP实现人员新增
来源:互联网 发布:风险矩阵应用 编辑:程序博客网 时间:2024/06/18 16:56
什么是mvc
Controller(**Servlet)把数据封装成Model发给View显示
Model (Person)用户输入放到Model中传给Controller
View(jsp)只写for循环、颜色控制显示等,不在jsp中写业务逻辑代码
【知识点】
forward和sendRedirect都会导致浏览器收到一个响应,由于http协议规定一个请求只能对应一个响应,所以在进行forward或sendRedirect操作后,立即return,这样可以避免后面的代码再次生成响应从而导致错误
【注意】
setAttribute的使用周期
sendRedirect和forward的选择
【PersonServlet.java】
查询和新增功能
package com.rupeng.web2;import java.io.IOException;import java.sql.ResultSet;import java.sql.SQLException;import java.util.LinkedList;import java.util.List;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class PersonServlet extends HttpServlet{@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException{this.doGet(req, resp);}@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException{String action = req.getParameter("action");if (action.equals("list")){try{ResultSet rs = JdbcUtils.executeQuery("select * from T_Persons2");// req.setAttribute("rs", rs);List<Person> list = new LinkedList<Person>();while (rs.next()){int id = rs.getInt("Id");String name = rs.getString("Name");int age = rs.getInt("Age");Person p = new Person();p.setId(id);p.setName(name);p.setAge(age);list.add(p);}JdbcUtils.closeAll(rs);// /REsultSet等一般不要传给jspreq.setAttribute("persons", list);// request中的数据有效期是“当前请求”// jsp中就可以从request总取出"persons"的值//!!!如果逻辑是服务器处理的,那么"/"一般可以表示“项目的WebRoot根目录”//如果逻辑是浏览器端处理的。req.getRequestDispatcher("/PersonList2.jsp").forward(req, resp);//req.getRequestDispatcher("/PersonList2_2.jsp").forward(req, resp);//resp.sendRedirect("/PersonList2.jsp");//resp.sendRedirect("PersonList2.jsp");//!!!如果写成sendRedirect,那么浏览器是发出两次请求的,两次请求中的request数据不能共享// 让/PersonList2.jsp进行数据的显示} catch (SQLException e){resp.getWriter().write("数据库查询错误");}}else if(action.equals("addnew")){//MVC中用户不直接和JSP打交道(地址栏中不会出现jsp),JSP只是负责//req.getRequestDispatcher("/PersonList2.jsp").forward(req, resp);//之后数据的显示。用户永远直接和普通的Servlet打交道//由/PersonAddNew.jsp帮我处理吧。req.getRequestDispatcher("/PersonAddNew.jsp").forward(req, resp);}else if(action.equals("addnewSubmit")){String name= req.getParameter("name");int age = Integer.parseInt(req.getParameter("age"));try{JdbcUtils.executeUpdate("insert into T_Persons2(Name,Age) values(?,?)", name,age);resp.sendRedirect("person?action=list");} catch (SQLException e){req.setAttribute("msg","插入数据执行失败");//把jsp要用的数据放到reques中//让"/MyError.jsp"去显示数据req.getRequestDispatcher("/MyError.jsp").forward(req, resp);//resp.sendRedirect("MyError.jsp");}}else if(action.equals("edit")){int id = Integer.parseInt(req.getParameter("id"));try{ResultSet rs = JdbcUtils.executeQuery("select * from T_Persons2 where Id=?", id);if(rs.next()){Person person = new Person();person.setId(id);person.setName(rs.getString("Name"));person.setAge(rs.getInt("Age"));req.setAttribute("person", person);req.getRequestDispatcher("/PersonEdit.jsp").forward(req, resp);}else{req.setAttribute("msg", "没有找到id="+id+"的人员");req.getRequestDispatcher("/MyError.jsp").forward(req, resp);}JdbcUtils.closeAll(rs);} catch (SQLException e){req.setAttribute("msg", "数据查询出错");req.getRequestDispatcher("/MyError.jsp").forward(req, resp);}}else if(action.equals("editSubmit")){int id = Integer.parseInt(req.getParameter("id"));String name = req.getParameter("name");int age = Integer.parseInt(req.getParameter("age"));try{JdbcUtils.executeUpdate("Update T_Persons2 set Name=?,Age=? where Id=?", name,age,id);resp.sendRedirect("person?action=list");} catch (SQLException e){req.setAttribute("msg", "保存出错");req.getRequestDispatcher("/MyError.jsp").forward(req, resp);}}else if (action.equals("delete")){int id = Integer.parseInt(req.getParameter("id"));try{JdbcUtils.executeUpdate("delete from T_Persons2 where Id=?",id);resp.sendRedirect("person?action=list");} catch (SQLException e){req.setAttribute("msg", "删除出错");req.getRequestDispatcher("/MyError.jsp").forward(req, resp);}}}}
【PersonList2.jsp】
显示人员列表
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><%@page import="java.util.List"%><%@page import="com.rupeng.web2.Person"%><!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><p><a href="person?action=addnew">新增</a></p><table><thead><tr><td>Id</td><td>姓名</td><td>年龄</td><td>编辑</td><td>删除</td></tr></thead><tbody><%List<Person> persons = (List<Person>)request.getAttribute("persons");for(Person person : persons){%><tr><td><%=person.getId() %></td><td><%=person.getName() %></td><td><%=person.getAge() %></td><td><a href="person?action=edit&id=<%=person.getId() %>">编辑</a></td><td><a href="person?action=delete&id=<%=person.getId() %>">删除</a></td></tr><%} %></tbody></table></body></html>
【PersonAddNew.jsp】
显示新增人员页面
<%@ 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 action="person" method="post"><input type="hidden" name="action" value="addnewSubmit"/>姓名:<input type="text" name="name"/>年龄:<input type="text" name="age"/><input type="submit" value="保存"/></form></body></html>
【PersonEdit.jsp】
<%@ page language="java" contentType="text/html; charset=UTF-8"<span style="white-space:pre"></span>import="com.rupeng.web2.Person" 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><%Person person = (Person)request.getAttribute("person");%><form action="person" method="post"><input type="hidden" name="action" value="editSubmit"/><input type="hidden" name="id" value="<%=person.getId() %>"/>姓名:<input type="text" name="name" value="<%=person.getName() %>"/>年龄:<input type="text" name="age" value="<%=person.getAge() %>"/><input type="submit" value="保存"/></form></body></html>
【MyError.jsp】
显示错误页面
<%@ 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> <%=request.getAttribute("msg") %></body></html>
【web.xml】
<?xml version="1.0" encoding="UTF-8"?><web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"><welcome-file-list><welcome-file>index.jsp</welcome-file></welcome-file-list><error-page><exception-type>java.lang.Throwable</exception-type><location>/Error.jsp</location></error-page><error-page><error-code>404</error-code><location>/muyou.html</location></error-page> <servlet><servlet-name>personServlet</servlet-name><servlet-class>com.rupeng.web2.PersonServlet</servlet-class></servlet><servlet-mapping><servlet-name>personServlet</servlet-name><url-pattern>/person</url-pattern></servlet-mapping></web-app>
package com.rupeng.web2;public class Person{private int id;private String name;private int age;public int getId(){return id;}public void setId(int id){this.id = id;}public String getName(){return name;}public void setName(String name){this.name = name;}public int getAge(){return age;}public void setAge(int age){this.age = age;}}
其余引用【JdbcUtils.java】
0 0
- Servlet+JSP实现人员新增
- JSP+Servlet培训班作业管理系统[6]-人员管理功能实现
- JSP+Servlet培训班作业管理系统[11] -通用CRUD后端的实现(以人员管理为例)
- JSP+SERVLET实现“上传”
- jsp+servlet实现登陆
- servlet jsp 实现分页
- jsp+Servlet实现上传
- jsp+servlet实现javamail(2)
- jsp+servlet实现上传文件
- JSP+JavaBean+Servlet实现分页
- JSP+servlet+javabean实现分页
- jsp+servlet+javaBean实现分页
- jsp+servlet 实现登录功能
- jsp+Servlet验证码实现
- JSP+Servlet+JavaBean实现分页
- jsp+servlet实现文件上传
- Servlet/Jsp实现购物车
- JSP+servlet实现上传文件
- TCP 协议中MSS的理解
- QT5下SQLite的增删改查示例代码
- 深入理解----ThreadLocal的工作原理
- Hibernate学习笔记之ORM实体间关系“OneToOne”详解
- 九度OJ 1123 采药 0/1背包问题
- Servlet+JSP实现人员新增
- 安卓实现右滑返回效果
- 【NOIP2012借教室】(线段树区间操作)
- float 转定点计算加法和乘法
- php date函数各参数含义
- OCR文字识别可以帮你节省纸
- java对象和xml互转
- 判断素数(质数)
- MHA (二)