json與java對象的轉換,以及struts2對json的支持,實現ajax技術

這兩天學的東西有點多,今天抽個時間寫下來,以此做爲激勵,這兩天學了json,ajax,jQueryjavascript

1、使用第三方的工具java轉換爲json類型css

首先就是java類型轉換爲json對象,首先要導入第三方工具包:html

 準備導入第三方jar包:java

    》commons-beanutils-1.7.0.jarnode

    》commons-collections-3.1.jargit

    》commons-lang-2.5.jargithub

》commons-logging-1.1.1.jarweb

》ezmorph-1.0.3.jarajax

》json-lib-2.1-jdk15.jar       apache

 

轉換的方法以下:

(1)JavaBean----->JSON

             》JSONArray jsonArray = JSONArray.fromObject(city);

             》String jsonJAVA = jsonArray.toString();

   (2)List<JavaBean>----->JSON

        》JSONArray jsonArray = JSONArray.fromObject(cityList);

             》String jsonJAVA = jsonArray.toString();

   (3)List<String>----->JSON

        》JSONArray jsonArray = JSONArray.fromObject(stringList);

             》String jsonJAVA = jsonArray.toString();

   (4)Set<JavaBean>----->JSON

        》JSONArray jsonArray = JSONArray.fromObject(citySet);

             》String jsonJAVA = jsonArray.toString();

   (5)Map<String,Object>----->JSON

        》JSONArray jsonArray = JSONArray.fromObject(map);

             》String jsonJAVA = jsonArray.toString();

public static void javabean2Json()
    {
        City city = new City(1,"廣州");
        JSONArray jsonArray = JSONArray.fromObject(city);
        String jsonJAVA = jsonArray.toString();
        System.out.println(jsonJAVA);
        //[{"id":1,"name":"廣州"}]
    }
    
    public static void list2json()
    {
        List<City> cityList = new ArrayList<City>();
        cityList.add(new City(1,"廣州"));
        cityList.add(new City(2,"深圳"));
        
        Province province = new Province(1,"廣東",cityList);
        
        //[{"id":1,"cityList":[{"id":1,"name":"廣州"},{"id":2,"name":"深圳"}],"name":"廣東"}]
        JSONArray jsonArray = JSONArray.fromObject(province);
        String jsonJAVA = jsonArray.toString();
        System.out.println(jsonJAVA);
        //List集合[{"id":1,"name":"廣州"},{"id":2,"name":"深圳"}]
    }
    
    public static void set2json()
    {
        Set<City> citySet= new HashSet<City>();
        citySet.add(new City(1,"廣州"));
        citySet.add(new City(2,"深圳"));
        JSONArray jsonArray = JSONArray.fromObject(citySet);
        String jsonJAVA = jsonArray.toString();
        System.out.println(jsonJAVA);
        //[{"id":1,"name":"廣州"},{"id":2,"name":"深圳"}]
    }
    public static void map2json()
    {
        List<City> cityList = new ArrayList<City>();
        cityList.add(new City(1,"廣州"));
        cityList.add(new City(2,"深圳"));
        
        Map<String,Object> map = new HashMap<String,Object>();
        map.put("total", cityList.size());//表示集合的長度
        map.put("rows", cityList);//表示集合
        /**
         * [{"total":2,"rows":[{"id":1,"name":"廣州"},{"id":2,"name":"深圳"}]}]
         */
        
        JSONArray jsonArray = JSONArray.fromObject(map);
        String jsonJAVA = jsonArray.toString();
        jsonJAVA = jsonJAVA.substring(1,jsonJAVA.length()-1);
        System.out.println(jsonJAVA);
        //[{"id":1,"name":"廣州"},{"id":2,"name":"深圳"}]
    }
    
    public static void main(String[] args) {
        // TODO Auto-generated method stub
//        javabean2Json();
//        list2json();
//        set2json();
        map2json();
    }

注意的是這裏json全是java格式,必須轉換爲javascript所支持的json格式.

注意:JS能夠直接解析JSON格式的文本,前提是:該JSON必須採用JS格式書寫的才行,若是該JSON是採用Java格式寫的,必須使用eval()函數轉換後,方可被JS解析,該eval("")函數接收一個字符串格式的內容。

    二 、使用struts2自動將java對象轉換爲json

1)導入struts2的jar包,主要是一些核心包,

commons-fileupload-1.2.2.jar
commons-io-2.0.1.jar
commons-lang3-3.1.jar
freemarker-2.3.19.jar
javassist-3.11.0.GA.jar
ognl-3.0.5.jar
struts2-core-2.3.4.1.jar
xwork-core-2.3.4.1.jar

還有一個struts2對json支持的插件包:struts2-json-plugin-2.3.1.1.jar

2)配置web.xml

 <!-- 配置攔截器 -->
  <filter>
      <filter-name>struts2</filter-name>
      <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  
  <filter-mapping>
      <filter-name>struts2</filter-name>
      <url-pattern>/*</url-pattern>
  </filter-mapping> 

配置struts.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">

<struts>

    <!-- 配置struts2 -->
    <!--<package name="checknode" extends="struts-default" namespace="/user">
        <action name="check" class="cn.itcast.js_02.checkcode.CheckcodeAction" method="check">
        </action>
    </package>-->
    
    <package 
    name="province" 
    extends="json-default" 
    namespace="/">
    
    <!-- 配置全局結果 -->
    <global-results>
        <result  name="success" type="json"></result>
    </global-results>
        <action 
        name="findCityByProvince" 
        class="cn.itcast.js_02.provincecityarea.ProvinceCityArea"
         method="findCityByProvince">
        </action>
        
        <action 
        name="findAreaByCity" 
        class="cn.itcast.js_02.provincecityarea.ProvinceCityArea"
         method="findAreaByCity">
        </action>
    </package>
    
    
</struts>

3)javabean 代碼:

package cn.itcast.js_02.provincecityarea;

public class Bean {
    
    private String province;
    private String city;
    
    public Bean() {
        // TODO Auto-generated constructor stub
    }

    public String getProvince() {
        return province;
    }

    public void setProvince(String province) {
        this.province = province;
    }

    public String getCity() {
        return city;
    }

    public void setCity(String city) {
        this.city = city;
    }
}

Action代碼:

package cn.itcast.js_02.provincecityarea;

import java.util.ArrayList;
import java.util.List;

import com.opensymphony.xwork2.ActionSupport;

public class ProvinceCityArea extends ActionSupport {
    
    private Bean bean;
    public void setBean(Bean bean) {
        this.bean = bean;
    }
    public Bean getBean() {
        return bean;
    }

    public String findCityByProvince() throws Exception {
        // TODO Auto-generated method stub
        cityList = new ArrayList<String>();
        if("湖北".equals(bean.getProvince()))
        {
            cityList.add("武漢");
            cityList.add("孝感");
            cityList.add("黃岡");
        }else if("湖南".equals(bean.getProvince()))
        {
            cityList.add("長沙");
            cityList.add("株洲");
            cityList.add("岳陽");
            cityList.add("湖南");
        }else if("江西".equals(bean.getProvince()))
        {
            cityList.add("南昌");
            cityList.add("南昌");
            cityList.add("南昌");
            cityList.add("南昌");
        }
        
        //配置讓struts2自動將List/Set/Map<String>轉換爲JSON文本
        return this.SUCCESS;
    }
    
    /**
     * 經過城市查找區域
     * @return
     * @throws Exception
     */
    
    public String findAreaByCity() throws Exception {
        // TODO Auto-generated method stub
        areaList = new ArrayList<String>();
        if("武漢".equals(bean.getCity()))
        {
            areaList.add("AA");
            areaList.add("BB");
            areaList.add("CC");
        }else if("南昌".equals(bean.getCity()))
        {
            areaList.add("DD");
            areaList.add("EE");
            areaList.add("FF");
        }else if("長沙".equals(bean.getCity()))
        {
            areaList.add("GG");
            areaList.add("HH");
            areaList.add("II");
        }
        
        //配置讓struts2自動將List/Set/Map<String>轉換爲JSON文本
        return this.SUCCESS;
    }
    
    private List<String> cityList;
    private List<String> areaList;
    public List<String> getAreaList() {
        return areaList;
    }
    public List<String> getCityList()
    {
        return this.cityList;
    }
}

jsp代碼:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
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>struts2實現三級聯查詢</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>
  <select id="provinceID" style="width:111px">
      <option>請選擇省份</option>
      <option>湖北</option>
      <option>湖南</option>
      <option>江西</option>
  </select>
  
  <select id="cityID" style="width:111px">
      <option>請選擇城市</option>
  </select>
  
   <select id="areaID" style="width:111px">
      <option>請選擇區域</option>
  </select>
   <script type="text/javascript" src="js/ajax.js"></script>
   <script type="text/javascript">
   document.getElementById("provinceID").onchange = function()
   {
       var province = this[this.selectedIndex].innerHTML;
       //清除以前的樣式
       var cityElement = document.getElementById("cityID");
       cityElement.options.length = 1;
       //當省份發生變化時,區域也會發生變化
       var areaElement = document.getElementById("areaID");
       areaElement.options.length = 1;
       if("選擇省份"!=province)
       {
           //NO1)
           var ajax = createAjax();
           //NO2)
           var method = "POST";
           var url = "${pageContext.request.contextPath}/findCityByProvince?time="+new Date().getTime();
           ajax.open(method, url);
           //NO3)
           ajax.setRequestHeader("content-type", "application/x-www-form-urlencoded");
           //NO4)
           var content = "bean.province="+province;
           ajax.send(content);
           //------------------------->等待
           //NO5)
           ajax.onreadystatechange = function()
           {
               if(ajax.readyState == 4)
               {
                   if(ajax.status == 200)
                   {
                       //NO6)返回JAVA
                       var jsonJAVA = ajax.responseText;
                       var p = eval("("+jsonJAVA+")");
                       var array = p.cityList;
                       var size = array.length;
                       for(var i=0;i<size;i++)
                       {
                           var city=array[i];
                           var option = document.createElement("option");
                           option.innerHTML = city;
                           cityElement.appendChild(option);
                       }
                   }
               }
           }
       }
   }
   
   
   document.getElementById("cityID").onchange = function()
   {
       var city = this[this.selectedIndex].innerHTML;
       //清除以前的數據
       var areaElement = document.getElementById("areaID");
       areaElement.options.length = 1;
       if("請選擇城市"!=city)
       {
           //NO1)
           var ajax = createAjax();
           //MO2)    
           var method = "POST";
           var url = "${pageContext.request.contextPath}/findAreaByCity?time="+new Date().getTime();
           ajax.open(method,url);
           //NO3)
           ajax.setRequestHeader("content-type", "application/x-www-form-urlencoded");
           //NO4)
           var content = "bean.city="+city;
           ajax.send(content);
           
           //----------------------等待
           ajax.onreadystatechange = function()
           {
               //NO5)
               if(ajax.readyState == 4)
               {
                   if(ajax.status == 200)
                   {    
                       //NO6)
                       var jsonJAVA = ajax.responseText;
                       var jsonJS = eval("("+jsonJAVA+")");
                       var array = jsonJS.areaList;
                       var size = array.length;
                       for(var i=0;i<size;i++)
                       {
                           var area = array[i];
                           var option = document.createElement("option");
                           option.innerHTML = area;
                           areaElement.appendChild(option);
                       }
                   }
               }
           }
       }
       
   }
   </script>
  </body>
  <form action="" enctype="application/x-www-form-urlencoded"></form>
</html>在這中間出了一些問題,大部分是由於寫錯了方法名稱或屬性名例如:ajax.onreadystatechange最後再附上源碼地址:https://github.com/blench/js_day02.git
相關文章
相關標籤/搜索