第二十天:Servlet+mysql+html 增删改查 (代码)

本文介绍了一个简单的用户管理系统实现,包括用户注册、展示、修改和删除等功能。系统使用了HTML、Java Servlet和MySQL数据库。

0.数据库的sql如下:

[sql]  view plain  copy
  1. <span style="font-size:14px;">create table user(  
  2.  id int primary key auto_increment,  
  3.  name varchar(20),  
  4.  salary varchar(9),  
  5.  age varchar(2),  
  6.  sex char(2),  
  7.  tel varchar(11));</span>  

1.index.html 用户注册的首页:

[html]  view plain  copy
  1. <span style="font-size:14px;"><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  2. <html>  
  3.   <head>  
  4.     <base href="<%=basePath%>">  
  5.       
  6.     <title>用户注册!</title>  
  7.     <meta http-equiv="pragma" content="no-cache">  
  8.     <meta http-equiv="cache-control" content="no-cache">  
  9.     <meta http-equiv="expires" content="0">      
  10.     <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">  
  11.     <meta http-equiv="description" content="This is my page">  
  12.     <!-- 
  13.     <link rel="stylesheet" type="text/css" href="styles.css"> 
  14.     -->  
  15.   </head>  
  16.     
  17.   <body>    
  18.         <form action="add" method="post" align="center">  
  19.         <h1> 这是一个用户注册页面!</h1>  
  20.             <table align="center">  
  21.                 <tr><td>name:</td><td><input type="text" name="name"/></td></tr>  
  22.                 <tr><td>salary</td><td><input type="text" name="salary"/></td></tr>  
  23.                 <tr><td>age:</td><td><input type="text" name="age"/></td></tr>  
  24.                 <tr><td>sex:</td><td>M:<input type="radio" name="sex" value="M"/>  
  25.                 W:<input type="radio" name="sex" value="W"/></td></tr>  
  26.                 <tr><td>tel:</td><td><input type="text" name="tel"/></td></tr>  
  27.             </table>  
  28.             <input type="submit" value="提交"/>  
  29.         </form> <br>  
  30.   </body>  
  31. </html>  
  32. </span>  
2.add的Servlet

[java]  view plain  copy
  1. <span style="font-size:14px;">package com.user.servlet;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5. import java.sql.Connection;  
  6. import java.sql.DriverManager;  
  7. import java.sql.PreparedStatement;  
  8. import java.sql.SQLException;  
  9.   
  10. import javax.servlet.http.HttpServlet;  
  11. import javax.servlet.http.HttpServletRequest;  
  12. import javax.servlet.http.HttpServletResponse;  
  13.   
  14. //页面注册用户的Servlet  
  15. @SuppressWarnings("serial")  
  16. public class Add extends HttpServlet{  
  17.     protected void service(HttpServletRequest request,HttpServletResponse response) throws IOException{  
  18.         //避免出现乱码可以提前设置一下  
  19.         request.setCharacterEncoding("GBK");  
  20.         response.setContentType("text/html;charset=gbk");  
  21.         PrintWriter pw=response.getWriter();  
  22.         try {  
  23.             Class.forName("com.mysql.jdbc.Driver");  
  24.             Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test01","root","1234");  
  25.             String sql="insert into user(name,salary,age,sex,tel) values(?,?,?,?,?)";  
  26.             PreparedStatement ps= conn.prepareStatement(sql);  
  27.             ps.setString(1, request.getParameter("name"));  
  28.             ps.setString(2, request.getParameter("salary"));  
  29.             ps.setString(3, request.getParameter("age"));  
  30.             ps.setString(4, request.getParameter("sex"));  
  31.             ps.setString(5, request.getParameter("tel"));  
  32.             pw.println("<h1>"+"用户注册成功!"+"</h>");  
  33.             System.out.println(ps.executeUpdate());  
  34.             response.sendRedirect("list");  
  35.            // pw.println("<h1><a href='list'>"+"查看所有用户列表!"+"</a></h>");  
  36.         } catch (ClassNotFoundException e) {  
  37.             // TODO Auto-generated catch block  
  38.             e.printStackTrace();  
  39.         } catch (SQLException e) {  
  40.             // TODO Auto-generated catch block  
  41.             e.printStackTrace();  
  42.         }  
  43.     }  
  44. }  
  45. </span>  
3.delete的Servlet
[java]  view plain  copy
  1. <span style="font-size:14px;">package com.user.servlet;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5. import java.sql.Connection;  
  6. import java.sql.DriverManager;  
  7. import java.sql.SQLException;  
  8. import java.sql.Statement;  
  9.   
  10. import javax.servlet.http.HttpServlet;  
  11. import javax.servlet.http.HttpServletRequest;  
  12. import javax.servlet.http.HttpServletResponse;  
  13.   
  14. //从查出来的表上,删除已经注册的用户的Servlet  
  15. @SuppressWarnings("serial")  
  16. public class Delete extends HttpServlet{  
  17.     protected void service(HttpServletRequest request,HttpServletResponse response) throws IOException{  
  18.             response.setContentType("text/html;charser=gbk");  
  19.             PrintWriter pw=response.getWriter();  
  20.             try {  
  21.                 //查找驱动  
  22.                 Class.forName( "com.mysql.jdbc.Driver");  
  23.                 //驱动管理器建立链接  
  24.                 Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test01","root","1234");  
  25.                 //创建含有操作数据库方法的statement  
  26.                  Statement st=conn.createStatement();  
  27.                  String sql="delete from user where id='"+request.getParameter("deleteId")+"'";  
  28.                  st.executeUpdate(sql);  
  29.                  response.sendRedirect("list");  
  30.                  conn.close();pw.close();  
  31.                  //pw.println("<h1><a href='list'>list</a></h1>");  
  32.             } catch (ClassNotFoundException e) {  
  33.                 // TODO Auto-generated catch block  
  34.                 e.printStackTrace();  
  35.             } catch (SQLException e) {  
  36.                 // TODO Auto-generated catch block  
  37.                 e.printStackTrace();  
  38.             }  
  39.     }  
  40. }  
  41. </span>  
4.list的Servlet

[java]  view plain  copy
  1. <span style="font-size:14px;">package com.user.servlet;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5. import java.sql.Connection;  
  6. import java.sql.DriverManager;  
  7. import java.sql.ResultSet;  
  8. import java.sql.SQLException;  
  9. import java.sql.Statement;  
  10.   
  11. import javax.servlet.http.HttpServlet;  
  12. import javax.servlet.http.HttpServletRequest;  
  13. import javax.servlet.http.HttpServletResponse;  
  14.   
  15. //从数据库查询数据显示到表格的Servlet  
  16. @SuppressWarnings("serial")  
  17. public class List extends HttpServlet{  
  18.     protected void service(HttpServletRequest request,HttpServletResponse response) throws IOException{  
  19.         request.setCharacterEncoding("GBK");  
  20.         response.setContentType("text/html;charset=gbk");  
  21.         try {  
  22.             //查找驱动  
  23.             Class.forName("com.mysql.jdbc.Driver");  
  24.             //建立链接  
  25.             Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test01""root""1234");  
  26.             //获取支持sql的statement  
  27.             Statement st=conn.createStatement();  
  28.             //根据写的sql语句查询结果到ResultSet集合中去  
  29.             String sql="select * from user";  
  30.             ResultSet  set=st.executeQuery(sql);  
  31.             PrintWriter pw=response.getWriter();  
  32.             //定义一个表头  
  33.             pw.println("<table border='2px'><tr>"  
  34.                     + "<td>id</td>"  
  35.                     + "<td>name</td>"  
  36.                     + "<td>salary</td>"  
  37.                     + "<td>age</td>"  
  38.                     + "<td>sex</td>"  
  39.                     + "<td>tel</td>"  
  40.                     + "<td>delete</td>"  
  41.                     + "<td>update</td>"  
  42.                     + "</tr>");  
  43.             while(set.next()){  
  44.                     int id=set.getInt(1);  
  45.                     String name=set.getString(2);  
  46.                     String salary=set.getString(3);  
  47.                     String age=set.getString(4);  
  48.                     String sex=set.getString(5);  
  49.                     String tel=set.getString(6);  
  50.                     pw.println("<tr>"  
  51.                             + "<td>"+id+"</td>"  
  52.                             + "<td><a href='view?viewId="+id+"'>"+name+"</a></td>"  
  53.                             + "<td>"+salary+"</td>"  
  54.                             + "<td>"+age+"</td>"  
  55.                             + "<td>"+sex+"</td>"  
  56.                             + "<td>"+tel+"</td>"  
  57.                             +"<td>"+"<a href='delete?deleteId="+id+"'>delete</a>"+"</td>"          
  58.                             +"<td>"+"<a href='modify?updateId="+id+"'>update</a>"+"</td>"          
  59.                             + "<tr>");  
  60.             }  
  61.                 pw.println("</table>");  
  62.                 pw.println("</h1><a href='login.html'>add</a></h1>");  
  63.                 pw.close();    conn.close();  
  64.         } catch (ClassNotFoundException e) {  
  65.             // TODO Auto-generated catch block  
  66.             e.printStackTrace();  
  67.         } catch (SQLException e) {  
  68.             // TODO Auto-generated catch block  
  69.             e.printStackTrace();  
  70.         }  
  71.               
  72.     }  
  73. }  
  74. </span>  
5.modify+update的Servlet,通过modify相当去一个第三方

[java]  view plain  copy
  1. <span style="font-size:14px;">package com.user.servlet;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5. import java.sql.Connection;  
  6. import java.sql.DriverManager;  
  7. import java.sql.PreparedStatement;  
  8. import java.sql.ResultSet;  
  9. import java.sql.SQLException;  
  10.   
  11. import javax.servlet.http.HttpServlet;  
  12. import javax.servlet.http.HttpServletRequest;  
  13. import javax.servlet.http.HttpServletResponse;  
  14. //修改页面的servlet  
  15. @SuppressWarnings("serial")  
  16. public class Modify extends HttpServlet{  
  17.     protected void service(HttpServletRequest request,HttpServletResponse response) throws IOException{  
  18.         request.setCharacterEncoding("GBK");  
  19.         response.setContentType("text/html;charset=gbk");  
  20.         PrintWriter pw=response.getWriter();  
  21.             //创建数据库链接  
  22.              try {  
  23.                 Class.forName("com.mysql.jdbc.Driver");  
  24.              Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test01","root","1234");  
  25.              String sql="select * from user where id=? ";  
  26.              PreparedStatement ps=conn.prepareStatement(sql);  
  27.              ps.setString(1, request.getParameter("updateId"));  
  28.              ResultSet rs=ps.executeQuery();  
  29.              pw.println("<html><head>");  
  30.              pw.println("<meta http-equiv='content-type' content='text/html;charset=utf-8'></head>");  
  31.                
  32.              pw.println("<h1>Update User</h1>");  
  33.                
  34.              Integer id=Integer.parseInt(request.getParameter("updateId"));  
  35.              pw.println("<form action='update?updateId="+id+"' method='post'>"  
  36.                      + "<table>");  
  37.              while(rs.next()){  
  38.                  String name=rs.getString("name");  
  39.                  String salary=rs.getString("salary");  
  40.                  String age=rs.getString("age");  
  41.                  String sex=rs.getString("sex");  
  42.                  String tel=rs.getString("tel");  
  43.                  pw.println("<tr>");  
  44.                  pw.println("<td>name:</td>");  
  45.                  pw.println("<td><input type='text' name='name' value='"+name+"'/></td></tr>");  
  46.   
  47.                  pw.println("<tr>");  
  48.                  pw.println("<td>salary:</td>");  
  49.                  pw.println("<td><input type='text' name='salary' value='"+salary+"'/></td></tr>");  
  50.                    
  51.                  pw.println("<tr>");  
  52.                  pw.println("<td>age:</td>");  
  53.                  pw.println("<td><input type='text' name='age' value='"+age+"'/></td></tr>");  
  54.                    
  55.                  pw.println("<tr>");  
  56.                  pw.println("<td>sex:</td><td>");  
  57.                  if(sex.equals("M")){  
  58.                      pw.println("M:<input checked='checked' type='radio' name='sex' value='M'/>");  
  59.                      pw.println("W:<input type='radio' name='sex' value='W'/>");  
  60.                  }else{  
  61.                      pw.println("M:<input type='radio' name='sex' value='M'/>");  
  62.                      pw.println("W:<input checked='checked' type='radio' name='sex' value='W'/>");  
  63.                  }  
  64.                  pw.println("</td></tr>");  
  65.                    
  66.                  pw.println("<tr><td>tel:</td>");  
  67.                  pw.println("<td><input type='text' name='tel' value='"+tel+"'/></td></tr>");  
  68.                    
  69.                  pw.println("<tr><td><input type='submit' vlaue='submit'/></td></tr>");  
  70.                  pw.println("</table></form></html>");  
  71.              }  
  72.              conn.close();  
  73.              conn.close();  
  74.             } catch (ClassNotFoundException e) {  
  75.                 // TODO Auto-generated catch block  
  76.                 e.printStackTrace();  
  77.             } catch (SQLException e) {  
  78.                 // TODO Auto-generated catch block  
  79.                 e.printStackTrace();  
  80.             }  
  81.     }     
  82. }  
  83. </span>  

[java]  view plain  copy
  1. <span style="font-size:14px;">package com.user.servlet;  
  2.   
  3. import java.io.IOException;  
  4. import java.sql.Connection;  
  5. import java.sql.DriverManager;  
  6. import java.sql.PreparedStatement;  
  7. import java.sql.SQLException;  
  8.   
  9. import javax.servlet.http.HttpServlet;  
  10. import javax.servlet.http.HttpServletRequest;  
  11. import javax.servlet.http.HttpServletResponse;  
  12.   
  13. //将修改后的数据提交给这个表单的Servlet  
  14. @SuppressWarnings("serial")  
  15. public class Update extends HttpServlet{  
  16.     protected void service(HttpServletRequest request,HttpServletResponse response) throws IOException{  
  17.         request.setCharacterEncoding("GBK");  
  18.         response.setContentType("text/html;charset=gbk");  
  19.         try {  
  20.             Class.forName("com.mysql.jdbc.Driver");  
  21.             Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/test01","root","1234");  
  22.             String sql="update user set name=?,salary=?,age=?,sex=?,tel=?  where id=?";  
  23.             PreparedStatement ps=conn.prepareStatement(sql);  
  24.             Integer id=Integer.parseInt(request.getParameter("updateId"));  
  25.             String name=request.getParameter("name");  
  26.             String salary=request.getParameter("salary");  
  27.             String age=request.getParameter("age");  
  28.             String sex=request.getParameter("sex");  
  29.             String tel=request.getParameter("tel");  
  30.               
  31.             ps.setString(1,name);  
  32.             ps.setString(2,salary);  
  33.             ps.setString(3, age);  
  34.             ps.setString(4, sex);  
  35.             ps.setString(5, tel);  
  36.             ps.setInt(6,id);  
  37.               
  38.             ps.executeUpdate();  
  39.               
  40.             response.sendRedirect("list");  
  41.             conn.close();  
  42.             ps.close();  
  43.         } catch (SQLException e) {  
  44.             // TODO Auto-generated catch block  
  45.             e.printStackTrace();  
  46.         } catch (ClassNotFoundException e) {  
  47.             // TODO Auto-generated catch block  
  48.             e.printStackTrace();  
  49.         }  
  50.           
  51.     }  
  52. }  
  53. </span>  
6.xml映射文件
[html]  view plain  copy
  1. <span style="font-size:14px;"><?xml version="1.0" encoding="ISO-8859-1"?>  
  2. <web-app xmlns="http://java.sun.com/xml/ns/javaee"  
  3.    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"  
  5.    version="2.5">  
  6.    <servlet>  
  7.         <servlet-name>myView</servlet-name>  
  8.         <servlet-class>com.user.servlet.View</servlet-class>  
  9.    </servlet>  
  10.    <servlet>  
  11.         <servlet-name>myModify</servlet-name>  
  12.         <servlet-class>com.user.servlet.Modify</servlet-class>  
  13.    </servlet>  
  14.    <servlet>  
  15.         <servlet-name>myUpdate</servlet-name>  
  16.         <servlet-class>com.user.servlet.Update</servlet-class>  
  17.    </servlet>  
  18.     <servlet>  
  19.         <servlet-name>myDelete</servlet-name>  
  20.         <servlet-class>com.user.servlet.Delete</servlet-class>  
  21.     </servlet>  
  22.     <servlet>  
  23.         <servlet-name>myList</servlet-name>  
  24.         <servlet-class>com.user.servlet.List</servlet-class>  
  25.     </servlet>  
  26.     <servlet>  
  27.         <servlet-name>myAdd</servlet-name>  
  28.         <servlet-class>com.user.servlet.Add</servlet-class>  
  29.     </servlet>  
  30.     <servlet-mapping>  
  31.         <servlet-name>myAdd</servlet-name>  
  32.         <url-pattern>/add</url-pattern>  
  33.     </servlet-mapping>  
  34.     <servlet-mapping>  
  35.         <servlet-name>myList</servlet-name>  
  36.         <url-pattern>/list</url-pattern>  
  37.     </servlet-mapping>  
  38.     <servlet-mapping>  
  39.         <servlet-name>myDelete</servlet-name>  
  40.         <url-pattern>/delete</url-pattern>  
  41.     </servlet-mapping>  
  42.     <servlet-mapping>  
  43.         <servlet-name>myUpdate</servlet-name>  
  44.         <url-pattern>/update</url-pattern>  
  45.     </servlet-mapping>  
  46.     <servlet-mapping>  
  47.         <servlet-name>myModify</servlet-name>  
  48.         <url-pattern>/modify</url-pattern>  
  49.     </servlet-mapping>  
  50.     <servlet-mapping>  
  51.         <servlet-name>myView</servlet-name>  
  52.         <url-pattern>/view</url-pattern>  
  53.     </servlet-mapping>  
  54.  </web-app></span>  
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值