JackSon与AJAX的简单操作

 服务器序列化与反序列化

一,序列化

    /**
     * 序列化为json
     */
    public static String toJson(Object obj) {
        String result = null;
        try {
            //对象映射器
            ObjectMapper objectMapper = new ObjectMapper();
            //设置日期格式
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd HH:mm:ss");
            objectMapper.setDateFormat(sdf);

            result = objectMapper.writeValueAsString(obj);
        } catch (JsonProcessingException e) {
            e.printStackTrace();
        }
        return result;
    }

二,反序列化

/**
     * 反序列化成对象
     *
     * T:表示全部类型与objcet不同的是 泛型强类型 Object为弱类型
     * json:需要反序列化的字符串
     * valueType:反序列化的类型
     * */
    public static <T> T toObject(String json,Class<T> valueType) {
        //对象映射器
        ObjectMapper mapper=new ObjectMapper();
        T result=null;
        try {
            result=mapper.readValue(json,valueType);

        }catch (Exception e) {
            e.printStackTrace();
        }
        return result;
    }

三,序列化时时间的问题

  通过jackson序列化时时间是一个问题,它会把时间转换为1977年到现在这个时间的毫秒数,下面来解决这个问题

3.1,时间注解@JsonFormat: 

在需要指定序列化对象的时间字段前面插入时间注解,转变为自己想要的格式

    private String comid;
    private String comname;
    private String comprice;
    //设置日期格式
   /**
    *locale:国家
    *timezone:时区
    *pattern:时间格式
    */ @JsonFormat(locale="zh", timezone="GMT+8", pattern="yyyy-MM-dd HH:mm:ss") private String comtime; private String yn;

 

3.2,SimpleDateFormat: 

在序列化前设置好时间格式

            //对象映射器
            ObjectMapper objectMapper = new ObjectMapper();
            //设置日期格式
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd HH:mm:ss");
            objectMapper.setDateFormat(sdf);

            objectMapper.writeValueAsString(obj);

3.3,Spring MVC 返回时间到前端页面为时间戳

package com.chenjiahao.ssm.entity;


import com.fasterxml.jackson.annotation.JsonFormat;

import java.sql.Timestamp;

public class Register {

  private String id;
  private String mobilePhone;
  private String pwd;
  private String mailbox;
  private Timestamp datas;

  public Register() {
  }

  public Register(String id, String pwd) {
    this.id = id;
    this.pwd = pwd;
  }

  public Register(String id, String mobilePhone, String mailbox) {
    this.id = id;
    this.mobilePhone = mobilePhone;
    this.mailbox = mailbox;
  }

  public Register(String id, String mobilePhone, String pwd, String mailbox) {
    this.id = id;
    this.mobilePhone = mobilePhone;
    this.pwd = pwd;
    this.mailbox = mailbox;
  }

  public Register(String id, String mobilePhone, String pwd, String mailbox, Timestamp datas) {
    this.id = id;
    this.mobilePhone = mobilePhone;
    this.pwd = pwd;
    this.mailbox = mailbox;
    this.datas = datas;
  }

  public String getId() {
    return id;
  }

  public void setId(String id) {
    this.id = id;
  }


  public String getMobilePhone() {
    return mobilePhone;
  }

  public void setMobilePhone(String mobilePhone) {
    this.mobilePhone = mobilePhone;
  }


  public String getPwd() {
    return pwd;
  }

  public void setPwd(String pwd) {
    this.pwd = pwd;
  }


  public String getMailbox() {
    return mailbox;
  }

  public void setMailbox(String mailbox) {
    this.mailbox = mailbox;
  }

  @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "GMT+8",locale = "zh")
  public Timestamp getDatas() {
    return datas;
  }

  public void setDatas(Timestamp datas) {
    this.datas = datas;
  }

    @Override
    public String toString() {
        return "Register{" +
                "id='" + id + '\'' +
                ", mobilePhone='" + mobilePhone + '\'' +
                ", pwd='" + pwd + '\'' +
                ", mailbox='" + mailbox + '\'' +
                ", datas=" + datas +
                '}';
    }
}

 

Jackson工具包:

 https://files.cnblogs.com/files/NiuBiHH/jackson.zip

 

四,原生AJAX

获取XHR对象 

   /**
     * 获取XHR对象
     * */
    function getXHR() {
        //window.XMLHttpRequest 普通浏览器差不多都具备的对象
        if(window.XMLHttpRequest){
            return new XMLHttpRequest();
        }else  if(window.ActiveXObject){
            //ActiveXObject("Microsoft.XMLHTTP") 为Microsoft公司的 在IE6 IE5下获得的XHR对象
            return new ActiveXObject("Microsoft.XMLHTTP");
        }
        return null;
    }

状态发生改变时调用的函数

      /*
    *xhr.readyState等于4时 表示请求成功
    *xhr.status等于200时 表示服务器响应状态成功
    *xhr.responseText 取出服务器响应返回的值
    */
      XHR.onreadystatechange=function(){
            if(xhr.readyState==4){ 
                if(xhr.status==200){ 
                 xhr.responseText;
           } } }

open()  如果是本地的话可以用openReques()代替

/*
* method 请求的类型 如:get post
* url  请求是路径
* asycn 是否是异步请求 默认为true
*/

void
open( DOMString method, DOMString url, optional boolean async, );
xhr.open("GET","CommodityControl?action=time",true); 

 send() 请求的所有相关事件都必须在此方法之前

 xhr.send(null); 

 

事例:


/** * 获取XHR对象 * */ function getXHR() { //window.XMLHttpRequest 普通浏览器差不多都具备的对象 if(window.XMLHttpRequest){ return new XMLHttpRequest(); }else if(window.ActiveXObject){ //ActiveXObject("Microsoft.XMLHTTP") 为Microsoft公司的 在IE6 IE5下获得的XHR对象 return new ActiveXObject("Microsoft.XMLHTTP"); } return null; } function getTime_click(){ var xhr=getXHR(); //当状态变化时的事件 xhr.onreadystatechange=function(){ if(xhr.readyState==4){ //请求成功 if(xhr.status==200){ //服务器响应状态成功 //将从服务器获得的数据显示在页面上 alert(xhr.responseText); } } } //打开请求 xhr.open("GET","CommodityControl?action=time",true); //请求类型,路径,是否为异步请求 //发送请求 xhr.send(null); //参数 }

五,$.ajax(options)

$.ajax参数描述
属性 类型 描述
url 字符串 请求的URL
Type  字符串 请求的方法 如:GET() POST() 默认GET()
Data 对象 请求后台时带过去的参数
dataType 字符串 设置服务器返回数据的类型 如:XML HTTP JSON SCRIPT TEXT
timeout 数值 设置请求时间 如果超过改时间则中止请求 并调用错误函数
global 布尔值 启用或者禁用全集函数的触发
contentType 字符串 请求的内容类型
success 函数 请求成功时调用改函数,该函数第一个参数为服务器的响应值
error 函数 请求响应指示错误状态码,携带三个实参调用该函数:请求对象 ,   状态消息字符串  ,   异常对象
complete 函数 请求响应指示成功状态码,调用该函数, 如果指定了success或error回调函数,则在他们被调用之后在调用该函数
beforeSend 函数 发起请求前调用的函数
async 布尔值 指定是否为异步请求

 

事例:

 $.ajax({
                type: "get",        //请求类型
                url: "CommodityControl?action=allcom",                //路径
                beforeSend: function () {                                //请求前的事件
                    c.show();
                },
                success: function (data) {              //请求成功后的事件
                    $.each(data, function (index, obj) {
                        var tr = $("<tr/>");
                        var inptd = $("<td/>");
                        $("<input name='comCheck' class='comCheck' type='checkbox'/>").html(obj.comtime).appendTo(inptd).data("id", obj.comid);
                        inptd.appendTo(tr);
                        $("<td/>").html(obj.comid).appendTo(tr);
                        $("<td/>").html(obj.comname).appendTo(tr);
                        $("<td/>").html(obj.comprice).appendTo(tr);
                        $("<td/>").html(obj.comtime).appendTo(tr);
                        var inputtd = $("<td/>");
                        if (obj.yn == 'y') {
                            $("<input  name='yn' checked='' value='y' type='checkbox'/>").html(obj.comtime).appendTo(inputtd);
                        }
                        else {
                            $("<input  name='yn' type='checkbox'/>").html(obj.comtime).appendTo(inputtd);
                        }
                        inputtd.appendTo(tr);
                        var atd = $("<td/>");
                        $("<a href='#'class='aupdate'></a> ").html("详细    ").appendTo(atd).data("id", obj.comid);
                        $("<a href='#' class='adel'></a> ").html("   删除").appendTo(atd).data("id", obj.comid);
                        atd.appendTo(tr);
                        $("#com").append(tr);
                        c.close();
                    });
                },
                complete: function () {  //请求完成时的事件,不论成功或失败
                    $("#hint").html("请求完成...");

                },
                error: function (xhr, textStatus, errorThrown) {  //错误时
                    alert(xhr + textStatus + errorThrown);
                }

  

六,ajax一些帮助方法

6.1:定义页面的共用函数

      (只能是同一个页面 多个ajax共用的函数)

    $.ajaxSetup({...})

      如:

       $.ajaxSetup({
			beforeSend: function() {
				$("#msg")[0].innerHTML += "请求中...<br/>";
			},
			complete: function() {
				$("#msg")[0].innerHTML += "请求完成...<br/>";
			},
			error: function() {
				$("#msg")[0].innerHTML += "请求失败...<br/>";
			}.........
		});

 

6.2:全局函数

1,请求开始时触发的事件

        $("......").ajaxStart(function() { ....})

 2.请求出错时触发的事件
         $("....").ajaxError(function(event,xhr,options,exc) {
          event:事件对象
           xhr:
XMLHttpRequest对象
         options:在AJAX request中使用的参数
        })
  3.请求成功时触发的事件		
      $(".....").ajaxSuccess(function() {......})
 4.发送时触发的事件	
      $("......").ajaxSend(function(evt, request, settings) {
          event:事件对象
           xhr:
XMLHttpRequest对象
         options:在AJAX request中使用的参数
      })
 5.请求完成时触发的事件(不管请求有没有成功)
    
$("....").ajaxComplete(function( event, xhr, settings ) {.....}

6.3:辅助ajax使用的一些方法

 
辅助方法
  JSON.stringify(....) 序列化对象为json对象 如:({"name":"....","age":...})
  JSON.parse(.....) 将json对象反序列化为普通对象  如:({name:"...",age:...})
  $("...").serialize() 获取表单中的所有内容并参数化 如:uid=...&pwd=.....
  $("...").serializeArray() 将表单中的元素序列化为数组对象 如:[{"name":"uid","value":"...."},"name":"pwd","value":"...."}]
  $.param(....) 将对象参数化 如:uid=...&pwd=...
   
posted @ 2018-06-07 20:24  NiuBiHH  阅读(618)  评论(0编辑  收藏  举报
levels of contents