zoukankan      html  css  js  c++  java
  • 作业:联系人管理

    数据库表:

    1.联系人表 contacts

     1 -- Create table
     2 create table CONTACTS
     3 (
     4   id      NUMBER not null,
     5   name    VARCHAR2(20) not null,
     6   tel     NVARCHAR2(20) not null,
     7   groupid NUMBER not null
     8 )
     9 tablespace TEST
    10   pctfree 10
    11   initrans 1
    12   maxtrans 255
    13   storage
    14   (
    15     initial 64K
    16     next 1M
    17     minextents 1
    18     maxextents unlimited
    19   );
    20 -- Create/Recreate primary, unique and foreign key constraints 
    21 alter table CONTACTS
    22   add constraint PK_CONTACTS primary key (ID)
    23   using index 
    24   tablespace TEST
    25   pctfree 10
    26   initrans 2
    27   maxtrans 255
    28   storage
    29   (
    30     initial 64K
    31     next 1M
    32     minextents 1
    33     maxextents unlimited
    34   );

    2.分组信息表 groups

     1 -- Create table
     2 create table GROUPS
     3 (
     4   id   NUMBER not null,
     5   name VARCHAR2(20) not null
     6 )
     7 tablespace TEST
     8   pctfree 10
     9   initrans 1
    10   maxtrans 255
    11   storage
    12   (
    13     initial 64K
    14     next 1M
    15     minextents 1
    16     maxextents unlimited
    17   );
    18 -- Create/Recreate primary, unique and foreign key constraints 
    19 alter table GROUPS
    20   add constraint PK_GROUPS primary key (ID)
    21   using index 
    22   tablespace TEST
    23   pctfree 10
    24   initrans 2
    25   maxtrans 255
    26   storage
    27   (
    28     initial 64K
    29     next 1M
    30     minextents 1
    31     maxextents unlimited
    32   );

    3,联系人id列自增长序列 SQ_CONTACTS_ID

    1 -- Create sequence 
    2 create sequence SQ_CONTACTS_ID
    3 minvalue 1
    4 maxvalue 9999999999999999999999999999
    5 start with 21
    6 increment by 1
    7 cache 20;

    javaee工程:lxr

    工具类放在com.haq.comm包中,包括:

    1,数据库连接工具类 DBHelper.java

     1 package com.haq.comm;
     2 
     3 import java.sql.*;
     4 
     5 //数据库连接工具类
     6 public class DBHelper {
     7     
     8     public static Connection getConnection() throws Exception
     9     {
    10         Connection conn = null;
    11         
    12         Class.forName("oracle.jdbc.driver.OracleDriver");
    13         
    14         String url = "jdbc:oracle:thin:@localhost:1521:orcl";
    15         
    16         conn = DriverManager.getConnection(url,"test","test");
    17         
    18         return conn;
    19     }
    20 
    21 }

    2,中文编码过滤器 ZhongWen.java

     1 package com.haq.comm;
     2 
     3 import java.io.IOException;
     4 import javax.servlet.Filter;
     5 import javax.servlet.FilterChain;
     6 import javax.servlet.FilterConfig;
     7 import javax.servlet.ServletException;
     8 import javax.servlet.ServletRequest;
     9 import javax.servlet.ServletResponse;
    10 import javax.servlet.annotation.WebFilter;
    11 
    12 /**
    13  * Servlet Filter implementation class ZhongWen
    14  */
    15 @WebFilter("/*")
    16 public class ZhongWen implements Filter {
    17 
    18     /**
    19      * Default constructor. 
    20      */
    21     public ZhongWen() {
    22         // TODO Auto-generated constructor stub
    23     }
    24 
    25     /**
    26      * @see Filter#destroy()
    27      */
    28     public void destroy() {
    29         // TODO Auto-generated method stub
    30     }
    31 
    32     /**
    33      * @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain)
    34      */
    35     public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
    36         // TODO Auto-generated method stub
    37         // place your code here
    38         
    39         //处理中文乱码的过滤器
    40         
    41         request.setCharacterEncoding("UTF-8");
    42         response.setCharacterEncoding("UTF-8");
    43         response.setContentType("text/html; charset=UTF-8");
    44 
    45         // pass the request along the filter chain
    46         chain.doFilter(request, response);
    47     }
    48 
    49     /**
    50      * @see Filter#init(FilterConfig)
    51      */
    52     public void init(FilterConfig fConfig) throws ServletException {
    53         // TODO Auto-generated method stub
    54     }
    55 
    56 }

    模型层类:放在com.hanq.dao包中,包括:

    1,封装联系人信息的实体类 Contacts.java

     1 package com.haq.dao;
     2 
     3 //实体类封装联系人信息
     4 public class Contacts {
     5     
     6     private int id;
     7     private String name;
     8     private String tel;
     9     private int groupid;
    10     
    11     public int getId() {
    12         return id;
    13     }
    14     public void setId(int id) {
    15         this.id = id;
    16     }
    17     public String getName() {
    18         return name;
    19     }
    20     public void setName(String name) {
    21         this.name = name;
    22     }
    23     public String getTel() {
    24         return tel;
    25     }
    26     public void setTel(String tel) {
    27         this.tel = tel;
    28     }
    29     public int getGroupid() {
    30         return groupid;
    31     }
    32     public void setGroupid(int groupid) {
    33         this.groupid = groupid;
    34     }
    35     
    36     
    37 
    38 }

    2,封装联系人表数据库操作的类 ContDal.java

      1 package com.haq.dao;
      2 
      3 import java.util.*;
      4 import java.sql.*;
      5 
      6 import com.haq.comm.DBHelper;
      7 
      8 //数据库操作类
      9 public class ContDal {
     10 
     11     //插入数据
     12     public int insertCont(Contacts c  ) throws Exception
     13     {
     14         //初始化返回值行数
     15         int row = -1;
     16         //获取数据库连接
     17         Connection conn = DBHelper.getConnection();
     18         //如果获取成功
     19         if(conn != null)
     20         {
     21             //声明PreparedStatement对象
     22             PreparedStatement ps = null;
     23             
     24             try
     25             {
     26                 //组织sql插入语句    
     27                 String sql = "insert into contacts(id,name,tel,groupid) values(sq_contacts_id.nextval,?,?,?)";
     28                 //获取PreparedStatement对象;
     29                 ps = conn.prepareStatement(sql);
     30                 //对sql语句中的参数赋值
     31                 ps.setString(1, c.getName());
     32                 ps.setString(2, c.getTel());
     33                 ps.setInt(3, c.getGroupid());
     34                 //执行插入操作,返回影响行数
     35                 row = ps.executeUpdate();
     36             }
     37             catch(Exception e)
     38             {
     39                 throw e;
     40             }
     41             finally
     42             {
     43                 try
     44                 {
     45                     //释放资源
     46                     ps.close();
     47                     conn.close();
     48                 }
     49                 catch(Exception e)
     50                 {
     51                     //确保ps关闭失败时,数据库连接可正常关闭
     52                     conn.close();
     53                 }
     54             }
     55             
     56         }
     57         //返回插入行数
     58         return row;
     59         
     60     }
     61     
     62     //查询方法
     63     public ArrayList<Contacts> selectContList() throws Exception
     64     {
     65         ArrayList<Contacts> arr = null;
     66         
     67         //获取数据库连接
     68         Connection conn = DBHelper.getConnection();
     69         
     70         if(conn != null)
     71         {
     72             Statement st = null;
     73             ResultSet rs = null;
     74             
     75             try
     76             {
     77                 //组织sql查询语句
     78                 String sql ="select * from contacts";
     79                 //获取Statement
     80                 st = conn.createStatement();
     81                 //执行sql语句,获取ResultSet
     82                 rs = st.executeQuery(sql);
     83                 //实例化ArrayList对象
     84                 arr = new ArrayList<Contacts>();
     85                 if(rs != null)
     86                 {
     87                     //遍历rs
     88                     while(rs.next())
     89                     {
     90                         //实例化实体类Contacts
     91                         Contacts c = new Contacts();
     92                         
     93                         c.setId(rs.getInt("id"));
     94                         c.setName(rs.getString("name"));
     95                         c.setTel(rs.getString("tel"));
     96                         c.setGroupid(rs.getInt("groupid"));
     97                         
     98                         arr.add(c);
     99                     }
    100                 }
    101             }
    102             catch(Exception e)
    103             {
    104                 throw e;
    105             }
    106             finally
    107             {
    108                 try
    109                 {
    110                     st.close();
    111                     rs.close();
    112                     conn.close();
    113                 }
    114                 catch(Exception e)
    115                 {
    116                     conn.close();
    117                 }
    118             }
    119         }
    120         
    121         
    122         return arr;
    123     }
    124     
    125     //删除方法
    126     public int deleteCont(int id ) throws Exception
    127     {
    128         //初始化返回值行数
    129         int row = -1;
    130         //获取数据库连接
    131         Connection conn = DBHelper.getConnection();
    132         //如果获取成功
    133         if(conn != null)
    134         {
    135             //声明PreparedStatement对象
    136             PreparedStatement ps = null;
    137             
    138             try
    139             {
    140                 //组织sql插入语句    
    141                 String sql = "delete from contacts where id = ?";
    142                 //获取PreparedStatement对象;
    143                 ps = conn.prepareStatement(sql);
    144                 //对sql语句中的参数赋值
    145                 ps.setInt(1, id);
    146                 //执行插入操作,返回影响行数
    147                 row = ps.executeUpdate();
    148             }
    149             catch(Exception e)
    150             {
    151                 throw e;
    152             }
    153             finally
    154             {
    155                 try
    156                 {
    157                     //释放资源
    158                     ps.close();
    159                     conn.close();
    160                 }
    161                 catch(Exception e)
    162                 {
    163                     //确保ps关闭失败时,数据库连接可正常关闭
    164                     conn.close();
    165                 }
    166             }
    167             
    168         }
    169         //返回插入行数
    170         return row;
    171         
    172     }
    173     
    174     //修改方法
    175     public int updateCont(Contacts c, int id ) throws Exception
    176     {
    177         //初始化返回值行数
    178         int row = -1;
    179         //获取数据库连接
    180         Connection conn = DBHelper.getConnection();
    181         //如果获取成功
    182         if(conn != null)
    183         {
    184             //声明PreparedStatement对象
    185             PreparedStatement ps = null;
    186             
    187             try
    188             {
    189                 //组织sql插入语句    
    190                 String sql = "update contacts set name=?,tel=?,groupid=? where id=?";
    191                 //获取PreparedStatement对象;
    192                 ps = conn.prepareStatement(sql);
    193                 //对sql语句中的参数赋值
    194                 ps.setString(1, c.getName());
    195                 ps.setString(2, c.getTel());
    196                 ps.setInt(3, c.getGroupid());
    197                 ps.setInt(4, id);
    198                 //执行插入操作,返回影响行数
    199                 row = ps.executeUpdate();
    200             }
    201             catch(Exception e)
    202             {
    203                 throw e;
    204             }
    205             finally
    206             {
    207                 try
    208                 {
    209                     //释放资源
    210                     ps.close();
    211                     conn.close();
    212                 }
    213                 catch(Exception e)
    214                 {
    215                     //确保ps关闭失败时,数据库连接可正常关闭
    216                     conn.close();
    217                 }
    218             }
    219             
    220         }
    221         //返回插入行数
    222         return row;
    223         
    224     }
    225     
    226     //单条查询
    227     public Contacts seleteCont(int id) throws Exception
    228     {
    229         //声明返回值
    230         Contacts c = null;
    231         
    232         //获得连接
    233         Connection conn = DBHelper.getConnection();
    234         
    235         //如果获取到连接
    236         if(conn != null)
    237         {
    238             PreparedStatement ps = null;
    239             
    240             ResultSet rs = null;
    241             
    242             try
    243             {
    244                 //组织数据库查询的sql语句
    245                 String sql ="select * from contacts where id = ?";
    246                 //获取PreparedStatement对象
    247                 ps = conn.prepareStatement(sql);
    248                 //添加sql语句参数
    249                 ps.setInt(1, id);
    250                 //执行sql语句,获取ResultSet对象
    251                 rs = ps.executeQuery();
    252                 //如果ResultSet获取到
    253                 if(rs != null && rs.next())
    254                 {
    255                     c = new Contacts();
    256                     
    257                     c.setId(rs.getInt("id"));
    258                     c.setName(rs.getString("name"));
    259                     c.setTel(rs.getString("tel"));
    260                     c.setGroupid(rs.getInt("groupid"));
    261                 }
    262 
    263             }
    264             catch(Exception e)
    265             {
    266                 
    267                 throw e;
    268                 
    269             }
    270             finally
    271             {
    272                 //释放资源
    273                 try
    274                 {
    275                     
    276                     ps.close();
    277                     rs.close();
    278                     conn.close();
    279                 }
    280                 catch(Exception e)
    281                 {
    282                     conn.close();
    283                 }
    284             }
    285             
    286         }
    287         
    288         //返回Groups对象
    289         return c;
    290     }
    291     
    292 }

    3,封装分组信息数据的实体类 Groups.java

     1 package com.haq.dao;
     2 
     3 //分组实体类
     4 public class Groups {
     5 
     6     //列作为属性,设为私有
     7     private int id;
     8     private String name;
     9     //对外开放get,set方法
    10     public int getId() {
    11         return id;
    12     }
    13     public void setId(int id) {
    14         this.id = id;
    15     }
    16     public String getName() {
    17         return name;
    18     }
    19     public void setName(String name) {
    20         this.name = name;
    21     }
    22 }

    4,封装分组表数据库操作的类 GroupDal.java

      1 package com.haq.dao;
      2 
      3 import java.sql.*;
      4 import java.util.ArrayList;
      5 
      6 import com.haq.comm.DBHelper;
      7 
      8 //分组表数据库操作类
      9 public class GroupDal {
     10     
     11     //查询全表信息
     12     public ArrayList<Groups> seleteGroupsList() throws Exception
     13     {
     14         //声明返回值
     15         ArrayList<Groups> arr = null;
     16         
     17         //获得连接
     18         Connection conn = DBHelper.getConnection();
     19         
     20         //如果获取到连接
     21         if(conn != null)
     22         {
     23             Statement st = null;
     24             
     25             ResultSet rs = null;
     26             
     27             try
     28             {
     29                 //组织数据库查询的sql语句
     30                 String sql ="select * from groups";
     31                 //获取Statement对象
     32                 st = conn.createStatement();
     33                 //执行sql语句,获取ResultSet对象
     34                 rs = st.executeQuery(sql);
     35                 //如果ResultSet获取到
     36                 if(rs != null)
     37                 {
     38                     //实例化ArrayList<Groups>
     39                     arr = new ArrayList<Groups>();
     40                     
     41                     //遍历rs,将数据添加到Groups实体类的对象中
     42                     while(rs.next())
     43                     {
     44                         //实例化Groups
     45                         Groups g = new Groups();
     46                         g.setId(rs.getInt("id"));
     47                         g.setName(rs.getString("name"));
     48                         //向集合中添加数据
     49                         arr.add(g);
     50                     }
     51                     
     52                 }
     53             }
     54             catch(Exception e)
     55             {
     56                 
     57                 throw e;
     58                 
     59             }
     60             finally
     61             {
     62                 //释放资源
     63                 try
     64                 {
     65                     
     66                     st.close();
     67                     rs.close();
     68                     conn.close();
     69                 }
     70                 catch(Exception e)
     71                 {
     72                     conn.close();
     73                 }
     74             }
     75             
     76         }
     77         
     78         //返回Groups对象
     79         return arr;
     80     }
     81     
     82     //查询单条记录方法
     83     public Groups seleteGroups(int id) throws Exception
     84     {
     85         //声明返回值
     86         Groups g = null;
     87         
     88         //获得连接
     89         Connection conn = DBHelper.getConnection();
     90         
     91         //如果获取到连接
     92         if(conn != null)
     93         {
     94             PreparedStatement ps = null;
     95             
     96             ResultSet rs = null;
     97             
     98             try
     99             {
    100                 //组织数据库查询的sql语句
    101                 String sql ="select * from groups where id = ?";
    102                 //获取PreparedStatement对象
    103                 ps = conn.prepareStatement(sql);
    104                 //添加sql语句参数
    105                 ps.setInt(1, id);
    106                 //执行sql语句,获取ResultSet对象
    107                 rs = ps.executeQuery();
    108                 //如果ResultSet获取到
    109                 if(rs != null && rs.next())
    110                 {
    111                     g = new Groups();
    112                     
    113                     g.setId(rs.getInt("id"));
    114                     g.setName(rs.getString("name"));
    115                 }
    116 
    117             }
    118             catch(Exception e)
    119             {
    120                 
    121                 throw e;
    122                 
    123             }
    124             finally
    125             {
    126                 //释放资源
    127                 try
    128                 {
    129                     
    130                     ps.close();
    131                     rs.close();
    132                     conn.close();
    133                 }
    134                 catch(Exception e)
    135                 {
    136                     conn.close();
    137                 }
    138             }
    139             
    140         }
    141         
    142         //返回Groups对象
    143         return g;
    144     }
    145 
    146 }

    控制层Servlet:放于com.hanq包中,包括:

    1,插入联系人 InsertCont.java

     1 package com.haq;
     2 
     3 import java.io.IOException;
     4 import javax.servlet.ServletException;
     5 import javax.servlet.annotation.WebServlet;
     6 import javax.servlet.http.HttpServlet;
     7 import javax.servlet.http.HttpServletRequest;
     8 import javax.servlet.http.HttpServletResponse;
     9 
    10 import com.haq.dao.ContDal;
    11 import com.haq.dao.Contacts;
    12 
    13 /**
    14  * Servlet implementation class InsertCont
    15  */
    16 @WebServlet("/InsertCont")
    17 public class InsertCont extends HttpServlet {
    18     private static final long serialVersionUID = 1L;
    19        
    20     /**
    21      * @see HttpServlet#HttpServlet()
    22      */
    23     public InsertCont() {
    24         super();
    25         // TODO Auto-generated constructor stub
    26     }
    27 
    28     /**
    29      * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
    30      */
    31     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    32         // TODO Auto-generated method stub
    33         //接收表单数据
    34         String name = request.getParameter("name");
    35         String tel = request.getParameter("tel");
    36         String groupid = request.getParameter("groupid");
    37         //验证数据是否正确传递
    38         if(name == null || name.trim().length() ==0)
    39         {
    40             response.getWriter().append("姓名不能为空");
    41         }
    42         else if(tel == null || tel.trim().length() ==0)
    43         {
    44             response.getWriter().append("电话不能为空");
    45         }
    46         else if(groupid == null || groupid.trim().length() ==0)
    47         {
    48             response.getWriter().append("分组不能为空");
    49         }
    50         else
    51         {
    52             //实例化联系人实体类
    53             Contacts c = new Contacts();
    54             //将接收到的数据添加到对象中
    55             c.setName(name);
    56             c.setTel(tel);
    57             c.setGroupid(Integer.parseInt(groupid));
    58             
    59             //实例化数据库操作类
    60             ContDal cd = new ContDal();
    61             //调用添加方法添加
    62             try {
    63                 
    64                 int row = cd.insertCont(c);
    65                 response.getWriter().append("成功添加" + row + "条数据");
    66                 
    67             } catch (Exception e) {
    68                 
    69                 response.getWriter().append("添加失败;错误信息:" + e.getMessage());
    70             }
    71             
    72             
    73         }
    74         
    75         //跳转回主页面
    76         response.setHeader("refresh", "1;URL=ContMana.jsp");
    77         //response.getWriter().append("Served at: ").append(request.getContextPath());
    78     }
    79 
    80     /**
    81      * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
    82      */
    83     protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    84         // TODO Auto-generated method stub
    85         doGet(request, response);
    86     }
    87 
    88 }

    2,删除联系人 DeleteCont.java

     1 package com.haq;
     2 
     3 import java.io.IOException;
     4 import javax.servlet.ServletException;
     5 import javax.servlet.annotation.WebServlet;
     6 import javax.servlet.http.HttpServlet;
     7 import javax.servlet.http.HttpServletRequest;
     8 import javax.servlet.http.HttpServletResponse;
     9 
    10 import com.haq.dao.*;
    11 
    12 /**
    13  * Servlet implementation class DeleteCont
    14  */
    15 @WebServlet("/DeleteCont")
    16 public class DeleteCont extends HttpServlet {
    17     private static final long serialVersionUID = 1L;
    18        
    19     /**
    20      * @see HttpServlet#HttpServlet()
    21      */
    22     public DeleteCont() {
    23         super();
    24         // TODO Auto-generated constructor stub
    25     }
    26 
    27     /**
    28      * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
    29      */
    30     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    31         // TODO Auto-generated method stub
    32         
    33         //接收参数
    34         String id = request.getParameter("id");
    35         
    36         if(id == null || id.trim().length() == 0)
    37         {
    38             response.getWriter().append("id不能为空");
    39         }
    40         else
    41         {
    42             //实例化数据库操作类
    43             ContDal cd = new ContDal();
    44             
    45             try {
    46                 int row = cd.deleteCont(Integer.parseInt(id));
    47                 response.getWriter().append("成功删除" + row + "条数据");
    48             } catch (Exception e) {
    49                 // TODO Auto-generated catch block
    50                 response.getWriter().append(e.getMessage());
    51             }
    52             
    53         }
    54         
    55         //跳转回主页面
    56         response.setHeader("refresh", "1;URL=ContMana.jsp");
    57         //response.getWriter().append("Served at: ").append(request.getContextPath());
    58     }
    59 
    60     /**
    61      * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
    62      */
    63     protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    64         // TODO Auto-generated method stub
    65         doGet(request, response);
    66     }
    67 
    68 }

    3,修改联系人 UpdateCont.java

     1 package com.haq;
     2 
     3 import java.io.IOException;
     4 import javax.servlet.ServletException;
     5 import javax.servlet.annotation.WebServlet;
     6 import javax.servlet.http.HttpServlet;
     7 import javax.servlet.http.HttpServletRequest;
     8 import javax.servlet.http.HttpServletResponse;
     9 
    10 import com.haq.dao.ContDal;
    11 import com.haq.dao.Contacts;
    12 
    13 /**
    14  * Servlet implementation class UpdateCont
    15  */
    16 @WebServlet("/UpdateCont")
    17 public class UpdateCont extends HttpServlet {
    18     private static final long serialVersionUID = 1L;
    19        
    20     /**
    21      * @see HttpServlet#HttpServlet()
    22      */
    23     public UpdateCont() {
    24         super();
    25         // TODO Auto-generated constructor stub
    26     }
    27 
    28     /**
    29      * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
    30      */
    31     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    32         // TODO Auto-generated method stub
    33         
    34                 //接收表单数据
    35                 String name = request.getParameter("name");
    36                 String tel = request.getParameter("tel");
    37                 String groupid = request.getParameter("groupid");
    38                 String id = request.getParameter("id");
    39                 //验证数据是否正确传递
    40                 if(name == null || name.trim().length() ==0)
    41                 {
    42                     response.getWriter().append("姓名不能为空");
    43                 }
    44                 else if(tel == null || tel.trim().length() ==0)
    45                 {
    46                     response.getWriter().append("电话不能为空");
    47                 }
    48                 else if(groupid == null || groupid.trim().length() ==0)
    49                 {
    50                     response.getWriter().append("分组不能为空");
    51                 }
    52                 else if(id == null || id.trim().length() ==0)
    53                 {
    54                     response.getWriter().append("id不能为空");
    55                 }
    56                 else
    57                 {
    58                     //实例化联系人实体类
    59                     Contacts c = new Contacts();
    60                     //将接收到的数据添加到对象中
    61                     c.setName(name);
    62                     c.setTel(tel);
    63                     c.setGroupid(Integer.parseInt(groupid));
    64                     
    65                     //实例化数据库操作类
    66                     ContDal cd = new ContDal();
    67                     //调用添加方法添加
    68                     try {
    69                         
    70                         int row = cd.updateCont(c,Integer.parseInt(id));
    71                         response.getWriter().append("成功修改" + row + "条数据");
    72                         
    73                     } catch (Exception e) {
    74                         
    75                         response.getWriter().append("添加失败;错误信息:" + e.getMessage());
    76                     }
    77                     
    78                     
    79                 }
    80                 
    81                 //跳转回主页面
    82                 response.setHeader("refresh", "2;URL=ContMana.jsp");
    83         
    84         //response.getWriter().append("Served at: ").append(request.getContextPath());
    85     }
    86 
    87     /**
    88      * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
    89      */
    90     protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    91         // TODO Auto-generated method stub
    92         doGet(request, response);
    93     }
    94 
    95 }

    表现层jsp页面,包括:

    1,显示联系人列表及添加 ContMana.jsp

      1 <%@ page language="java" contentType="text/html; charset=UTF-8"
      2     pageEncoding="UTF-8"%>
      3 <%@ page import="com.haq.*" %>
      4 <%@ page import="com.haq.dao.*" %>
      5 <%@ page import="com.haq.comm.*" %>
      6 <%@ page import="java.util.*" %>     
      7     
      8 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
      9 <html>
     10 <head>
     11 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
     12 <title>联系人管理</title>
     13 
     14 <script type="text/javascript" src="jquery-1.5.2.min.js"></script>
     15 
     16 <script type="text/javascript">
     17 
     18 //验证表单数据函数
     19 function checkform()
     20 {
     21     var name = form1.name.value;
     22     var tel = form1.tel.value;
     23     var group = form1.groupid.value;
     24     
     25     var zhz = /d{11}/;
     26     
     27     if(name == "" || $.trim(name) == "")
     28     {
     29         alert("姓名不能为空");
     30         return false;    
     31     }
     32     else if(tel == "" || $.trim(tel) == "")
     33     {
     34         alert("电话不能为空");
     35         return false;    
     36     }
     37     else if(!zhz.test(tel))
     38     {
     39         alert("电话格式错误");
     40         return false;    
     41     }
     42     else if(group == "" || $.trim(group) == "")
     43     {
     44         alert("分组不能为空");
     45         return false;    
     46     }
     47     else
     48     {
     49         return true;    
     50     }
     51     
     52 }
     53 
     54 //验证删除
     55 function deletecheck()
     56 {
     57     return(confirm("确定删除联系人吗?"))    
     58 }
     59 
     60 //修改联系人
     61 
     62 //显示添加表单
     63 
     64     $(document).ready(function(e) {
     65         $("#show").click(function()
     66         {
     67             $("#add").toggle();
     68         }
     69         );
     70     });    
     71     
     72 
     73 
     74 </script>
     75 
     76 </head>
     77 
     78 
     79 <body>
     80 <!--显示联系人表格-->
     81 <table border="1" width="300">
     82     <tr>
     83         <td></td>
     84         <td>姓名</td>
     85         <td>电话</td>
     86         <td>分组</td>
     87     </tr>
     88     <%
     89     //查询联系人信息
     90     //实例化集合
     91     ArrayList<Contacts> arr1 = new ArrayList<Contacts>();
     92     //实例化数据库操作类
     93     ContDal cd = new ContDal();
     94     
     95     arr1 = cd.selectContList();
     96     
     97     if(arr1 != null)
     98     {
     99         for(Contacts c : arr1)
    100         {
    101     %>
    102         <tr>
    103             <td>
    104                 <a href="updateCont.jsp?id=<%=c.getId() %>" >编辑</a>
    105                 <a href="DeleteCont?id=<%=c.getId() %>" onclick="return deletecheck()">删除</a>
    106             </td>
    107             <td><%=c.getName() %></td>
    108             <td><%=c.getTel() %></td>
    109             
    110             <td>
    111             <%
    112             int gid = c.getGroupid(); 
    113             //实例化数据操作类
    114             GroupDal gd1 = new GroupDal();
    115             
    116             Groups g1 = gd1.seleteGroups(gid);
    117             
    118             out.print(g1.getName());
    119             %>
    120             </td>
    121         
    122         </tr>
    123     
    124     <%
    125     
    126         }
    127     }
    128     
    129     %>
    130 
    131 </table>
    132 <br>
    133 <input type="button" id="show" name="show" value="添加联系人">
    134 
    135 <!--添加联系人表单-->
    136 <div id="add" style="display:none">
    137 
    138 <form action="InsertCont" id="form1" name="form1" onsubmit="return checkform()" method="post">
    139 
    140     姓名:<input type="text" id="name" name="name"/><br>
    141     电话:<input type="text" name="tel" id="tel" maxlength="11" /><br>
    142     分组:<select id="groupid" name="groupid">
    143     <%
    144     
    145     //查询分组信息
    146     
    147     GroupDal gd = new GroupDal();
    148     
    149     ArrayList<Groups> arr = gd.seleteGroupsList();
    150     
    151     //遍历输出
    152     if(arr != null)
    153     {
    154         for(Groups g : arr )
    155         {
    156     %>
    157     <option value="<%=g.getId()%>"><%=g.getName() %></option>
    158     
    159     <%        
    160         }
    161     }
    162     
    163     %>
    164     </select><br>
    165     
    166     <input type="submit" value="添加"/>
    167 
    168 </form>
    169 
    170 </div>
    171 
    172 </body>
    173 </html>

    2,修改联系人 updateCont.jsp

      1 <%@ page language="java" contentType="text/html; charset=UTF-8"
      2     pageEncoding="UTF-8"%>
      3     
      4 <%@ page import="com.haq.*" %>
      5 <%@ page import="com.haq.dao.*" %>
      6 <%@ page import="com.haq.comm.*" %>
      7 <%@ page import="java.util.*" %>   
      8 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
      9 <html>
     10 <head>
     11 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
     12 <title>修改联系人</title>
     13 
     14 <script type="text/javascript" src="jquery-1.5.2.min.js"></script>
     15 
     16 <script type="text/javascript">
     17 
     18 //验证表单数据函数
     19 function checkform()
     20 {
     21     var name = form1.name.value;
     22     var tel = form1.tel.value;
     23     var group = form1.groupid.value;
     24     
     25     var zhz = /d{11}/;
     26     
     27     if(name == "" || $.trim(name) == "")
     28     {
     29         alert("姓名不能为空");
     30         return false;    
     31     }
     32     else if(tel == "" || $.trim(tel) == "")
     33     {
     34         alert("电话不能为空");
     35         return false;    
     36     }
     37     else if(!zhz.test(tel))
     38     {
     39         alert("电话格式错误");
     40         return false;    
     41     }
     42     else if(group == "" || $.trim(group) == "")
     43     {
     44         alert("分组不能为空");
     45         return false;    
     46     }
     47     else
     48     {
     49         return true;    
     50     }
     51     
     52 }
     53 
     54 
     55 </script>
     56 </head>
     57 <body>
     58 
     59 <!--修改联系人表单-->
     60 
     61 
     62 
     63 
     64 <%
     65     //接收参数id
     66     String id = request.getParameter("id");
     67 
     68     if(id == null || id.trim().length() == 0)
     69     {
     70         out.print("参数错误");
     71         response.setHeader("refresh","1;url=ContMana.jsp");
     72     }
     73     else
     74     {
     75     //查询联系人信息
     76     //实例化Contacts
     77     Contacts c = new Contacts();
     78     //实例化数据库操作类
     79     ContDal cd = new ContDal();
     80     
     81     c = cd.seleteCont(Integer.parseInt(id));
     82     
     83     %>
     84 
     85 <form action="UpdateCont?id=<%=c.getId() %>" id="form1" name="form1" onsubmit="return checkform()" method="post">
     86 
     87     姓名:<input type="text" id="name" name="name" value="<%=c.getName() %>"><br>
     88     电话:<input type="text" name="tel" id="tel" maxlength="11" value="<%=c.getTel() %>"><br>
     89     分组:<select id="groupid" name="groupid">
     90     
     91     <% 
     92     //查询分组信息
     93     GroupDal gd = new GroupDal();
     94     
     95     ArrayList<Groups> arr = gd.seleteGroupsList();
     96     
     97     //遍历输出
     98     if(arr != null)
     99     {
    100         for(Groups g : arr )
    101         {
    102     %>
    103     <option value="<%=g.getId()%>" <%= ((c.getGroupid()==g.getId())? "selected" : "" ) %>><%=g.getName() %></option>
    104     
    105     <%        
    106         }
    107     }
    108     
    109     %>
    110     </select><br>
    111     
    112     <input type="submit" value="修改"/>
    113     <%
    114     }
    115     %>
    116 </form>
    117 </body>
    118 
    119 </html>
  • 相关阅读:
    关于宇宙大爆炸的理论模型
    算法系列2《RSA》
    Codeforces Round #248 (Div. 1)——Nanami&#39;s Digital Board
    Cocos2d-x场景变化相关功能介绍
    NYOJ 745 蚂蚁问题(两)
    quick-cocos2d-x endToLua 退出会卡住
    编程算法
    linux基础知识1
    URAL 1553. Caves and Tunnels 树链拆分
    2014/11/13_ 随想
  • 原文地址:https://www.cnblogs.com/dirgo/p/5071542.html
Copyright © 2011-2022 走看看