javaweb+mysql+c3p0ajax实现三级联动

1.首先要导入jar文件:

c3p0-0.9.5.1.jar
commons-beanutils-1.7.0.jar
commons-collections-3.2.jar
commons-dbutils-1.6.jar
commons-lang-2.4.jar
commons-logging-1.0.4.jar
ezmorph-1.0.3.jar
fastjson-1.1.40.jar
jackson-all-1.7.5.jar
json-lib-2.2.3-jdk15.jar
mchange-commons-java-0.2.10.jar
mysql-connector-java-5.1.30-bin.jar

2.c3p0配置文件

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <c3p0-config>
 3   <default-config>
 4 
 5     <property name="checkoutTimeout">30000</property>
 6     <property name="idleConnectionTestPeriod">30</property>
 7     <property name="initialPoolSize">10</property>
 8     <property name="maxIdleTime">30</property>
 9     <property name="maxPoolSize">100</property>
10     <property name="minPoolSize">10</property>
11     <property name="maxStatements">200</property>
12     
13     <!-- 驱动程序 -->
14     <property name="driverClass">com.mysql.jdbc.Driver</property>
15     <!-- 数据库连接url地址 -->
16     <property name="jdbcUrl">jdbc:mysql://localhost:3306/day02</property>
17     <!-- 用户名 -->
18     <property name="user">****</property>
19     <!-- 密码 -->
20     <property name="password">****</property>
21 
22  
23   </default-config>
24 </c3p0-config>
25 
26 <!-- <?xml version="1.0" encoding="UTF-8"?>
27 <c3p0-config>
28   <named-config > 
29     <property name="acquireIncrement">5</property>
30     <property name="initialPoolSize">3</property>
31     <property name="minPoolSize">1</property>
32     <property name="maxPoolSize">10</property>
33     <property name="maxStatements">0</property> 
34     <property name="user">root</property>
35     <property name="password">root</property>
36     ?useUnicode=true&characterEncoding=UTF-8
37     <property name="jdbcUrl">jdbc:mysql://localhost:3306/test</property>
38     <property name="driverClass">com.mysql.jdbc.Driver</property>
39   </named-config>
40 </c3p0-config> -->
41 
42 
43     

 

3..要建三张表,省市区分别一张

 

3.写对应的实体类

1 public class Province {
2 
3     private Integer provinceId;
4     private String provinceName;
5 
6       .....省略get和set代码      
7 }
1 public class City {
2 
3     private Integer cityId;
4     private String cityName;
5       
6    .....省略get和set方法  
7 }
1 public class Area {
2 
3     private Integer areaId;
4     private String areaName;
5     ...省略set和get方法
6 }

4.Util包下的DBManager

 1 public class DBManager {
 2 
 3         private static ComboPooledDataSource cpds=new ComboPooledDataSource();
 4         
 5         //获取数据库资源
 6         public static ComboPooledDataSource getDateResource(){
 7             return cpds;
 8         }
 9         
10         //返回连接对象
11         public static Connection getConn() throws SQLException{
12             return cpds.getConnection();
13         }
14         
15         //释放资源
16         public static void release(Connection conn){
17             DbUtils.closeQuietly(conn);
18         }
19         
20         
21 }

 

5.dao层

 

 1 public class BaseDao{
 2 
 3 private static final QueryRunner runner = new QueryRunner();
 4     
 5     public <T> List<T> getForList(String sql,Class<T> clazz,Object ...args) throws SQLException{
 6         
 7         List<T> list  = null;
 8         
 9         Connection conn = null;
10         
11         try {
12             conn = DBManager.getConn();
13             list = runner.query(conn, sql,new BeanListHandler<T>(clazz),args);
14         } catch (Exception e) {
15             throw new RuntimeException(e);
16         }finally{
17             DbUtils.close(conn);
18         }
19         
20         return list;
21         
22         
23     }

6.前台页面 index.jsp

<%
    response.sendRedirect("provinceServlet?method=listProvince");
    
%>

访问顺序是--->index.jsp----->provinceServlet?method=listProvince------>provice.jsp

 

7.provice.jsp(包含ajax代码)

  1 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
  2 <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
  3 
  4 
  5 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  6 <html>
  7   <head>
  8     
  9     
 10     <title>三级联动页面</title>
 11     
 12     <meta http-equiv="pragma" content="no-cache">
 13     <meta http-equiv="cache-control" content="no-cache">
 14     <meta http-equiv="expires" content="0">    
 15     <!-- 
 16         1.获取#province,添加change函数
 17         2.使#province只保留一个option子节点
 18         3.获取province下来菜单选择的值,若选择的值为“”(请选择省份),此时不需要发送ajax请求
 19         4.若值不为“”,说明的确是province发生了改变,发送ajax请求
 20         4.1  url:provinceServlet?method=
 21         4.2  args: 
 22         5.返回的是一个json数组
 23         6.遍历,创建<option value="provinceId">provinceName</option>
 24         并把新创建的option节点加为#city的子节点
 25      -->
 26     <script type="text/javascript" src="js/jquery-2.1.4.js"></script>
 27     <script type="text/javascript">
 28         $(function(){
 29         //第二级
 30              $("#province").change(function(){
 31             
 32                 $("#city option:not(:first)").remove();
 33                 var province = $(this).val();
 34                     //alert(province);
 35                 
 36                     var url = "provinceServlet?method=listCity";
 37                     var args = {"provinceId":province/* ,"time":new Date() */};
 38                     
 39                     $.getJSON(url, args, function(data){
 40                     //alert("11111");
 41                     
 42                         for(var i = 0;i < data.length; i++){
 43                     
 44                             var cityId = data[i].cityId;
 45                             var cityName = data[i].cityName;
 46                             
 47                             $("#city").append("<option value='"+ cityId  + "'>"+cityName+"</option>")
 48                             
 49                         }
 50                     
 51                     
 52                     
 53                     });
 54                         
 55                     
 56                     
 57                     
 58                 }
 59             );
 60          
 61          
 62          //第三极
 63          $("#city").change(function(){
 64             
 65                 $("#area option:not(:first)").remove();
 66                 var city = $(this).val();
 67                     //alert(province);
 68                 
 69                     var url = "provinceServlet?method=listArea";
 70                     var args = {"cityId":city,"time":new Date()}; //这里写一个时间戳 每次点击时,时间戳都不一样,浏览器就认为是新的图片,然后就发送请求了。
 71                     
 72                     $.getJSON(url, args, function(data){
 73                     //alert("11111");
 74                     
 75                         for(var i = 0;i < data.length; i++){
 76                     
 77                             var areaId = data[i].areaId;
 78                             var areaName = data[i].areaName;
 79                             
 80                             $("#area").append("<option value='"+ areaId  + "'>"+areaName+"</option>")
 81                             
 82                         }
 83                     
 84                     
 85                     
 86                     });
 87                         
 88                     
 89                     
 90                     
 91                 }
 92             );
 93         });
 94     
 95     </script>
 96 
 97   </head>
 98   
 99   <body>
100            省份:<select id="province">
101             <option>请选择省份</option>
102             <c:forEach items="${provinces}" var="province">
103                 <option value="${province.provinceId}">${province.provinceName}</option>
104             </c:forEach>
105                 
106             </select>
107             城市:<select id="city">
108                     <option>请选择城市</option>
109                 </select>
110             区域:<select id="area">
111                     <option>请选择区域</option>
112                 </select>
113   </body>
114 </html>

8.proviceServlet

 1 package three.controller;
 2 
 3 import java.io.IOException;
 4 import java.lang.reflect.Method;
 5 import java.sql.SQLException;
 6 import java.util.List;
 7 
 8 import javax.servlet.ServletException;
 9 import javax.servlet.http.HttpServlet;
10 import javax.servlet.http.HttpServletRequest;
11 import javax.servlet.http.HttpServletResponse;
12 
13 import org.codehaus.jackson.map.ObjectMapper;
14 
15 import three.dao.BaseDao;
16 import three.domain.Area;
17 import three.domain.City;
18 import three.domain.Province;
19 
20 public class provinceServlet extends HttpServlet {
21 
22     
23     public void doGet(HttpServletRequest request, HttpServletResponse response)
24             throws ServletException, IOException {
25         
26         request.setCharacterEncoding("UTF-8");
27         response.setContentType("text/html;charset=UTF-8");
28         
29         
30 
31         String methodName = request.getParameter("method");
32         
33         try {
34             Method method = getClass().getDeclaredMethod(methodName,HttpServletRequest.class,HttpServletResponse.class);
35             method.invoke(this, request,response);
36         } catch (Exception e) {
37             e.printStackTrace();
38         } 
39         
40     }
41 
42     private BaseDao  baseDao = new BaseDao();
43     public void listProvince(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, SQLException{
44         
45         String sql = "SELECT provinceid,provincename FROM province;";
46         List<Province> provinces = baseDao.getForList(sql, Province.class);
47         request.setAttribute("provinces", provinces);
48         
49         request.getRequestDispatcher("/province.jsp").forward(request, response);
50         
51     
52     }
53 
54 
55     public void listCity(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, SQLException{
56         
57         String provinceId = request.getParameter("provinceId");
58         String sql = "select cityid,cityname from city c where c.cityid = ?";
59         
60         List<City> cities = baseDao.getForList(sql, City.class, Integer.parseInt(provinceId));
61         
62         System.out.println(cities+"===========");
63         
64         ObjectMapper mapper = new ObjectMapper();
65         String result = mapper.writeValueAsString(cities);
66         System.out.println(result);
67         
68         response.setContentType("text/javascript");
69         response.getWriter().print(result);
70         
71         
72     }
73 
74 public void listArea(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, SQLException{
75     
76     String cityId = request.getParameter("cityId");
77     String sql = "select areaid,areaname from area a where a.areaid = ?";
78     
79     List<Area> areas = baseDao.getForList(sql, Area.class, Integer.parseInt(cityId));
80     
81     System.out.println(areas+"===========");
82     
83     ObjectMapper mapper = new ObjectMapper();
84     String result = mapper.writeValueAsString(areas);
85     System.out.println(result);
86     
87     response.setContentType("text/javascript");
88     response.getWriter().print(result);
89     
90     
91 }
92 
93     public void doPost(HttpServletRequest request, HttpServletResponse response)
94             throws ServletException, IOException {
95 
96         doGet(request,response);
97     }
98 
99 }

 

posted @ 2016-03-15 09:04  在路上的牛小牛  阅读(2256)  评论(0编辑  收藏  举报