zoukankan      html  css  js  c++  java
  • 程序猿Web面试之JSON

    

    JSON是什么?

    JSON(JavaScript对象表示法), 是在网络通信下。经常使用的一种数据表达格式,它有助于我们于一个自描写叙述的,独立的和轻的方式呈现并交换数据。

    这些数据能够易于和转换为JavaScript对象。

     

    JSON格式的最大长处: 它能够被非常easy得被转换为一个javascript对象。比如,以下的代码片段中看到的,我们有一个JSON格式的数据里面有“姓名”,“街道”,“年龄”和“手机”。

    <script type="text/javascript"> var JSONObject= {
    "name":"John Johnson",
    "street":"Oslo West 555", 
    "age":33,
    "phone":"555 1234567"};
    alert(JSONObject.name); 
    </script>

    如今,这个数据能够直接使用,如我们可获得JSONObject的对象。并不是常方便的调用其“name”属性。

    是否用SOAP能够做JSON相同的事情呢?

    有2点不同:

    首先,SOAP是用XML标签表达,比較重。

    JSON比較轻。纯数据。

    其次,最重要的是。JSON可直接转换为javascript对象。相同的要转换SOAP XML为javascript对象是较繁琐的任务。

    untitled

    是否全部的技术都支持JSON?

    是的,差点儿全部的数据交换都支持JSON。

    例如以下所看到的:

    WCF服务:假设你想你的WCF服务应该发送JSON消息,而不是SOAP,能够设置“ResponseFormat”作为你的操作协定“WebMessageFormat.Json”。

    [OperationContract]
    [WebInvoke(Method="GET", UriTemplate="/GetData", RequestFormat=WebMessageFormat.Json,
               ResponseFormat=WebMessageFormat.Json)]
    string GetData();

    MVC:假设你希望MVC返回JSON数据;通过调用Json,可返回JSON格式的Customer对象。

    public JsonResult  CustomerJson()
    {
         List<Customer> obj1 = new List<Customer>();
         Thread.Sleep(5000);
                Customer obj = new Customer();
                obj.CustomerCode = "1001";
                obj1.Add(obj);
                return Json(obj1,JsonRequestBehavior.AllowGet);
    }

    ASP.net: 假设你想使用ASP.NET返回JSON。我们须要使用“DataContractJsonSerializer”类。

    DataContractJsonSerializer serializer = new DataContractJsonSerializer(myPerson.GetType());
    MemoryStream ms = new MemoryStream();
    serializer.WriteObject(ms, myPerson);
    string json = System.Text.Encoding.UTF8.GetString(ms.ToArray());
    Response.Clear();
    Response.ContentType = "application/json;charset=utf-8";
    Response.Write(json);
    Response.End();

    使用jQuery怎样进行一个JSON调用?

    如在一个MVC中,可通过“getEmployee”函数返回employ的JSON对象。

    public JsonResult  getEmployee()
    {
    Emp obj = new Emp();
    obj.empcode = "1001";
    return Json(obj,JsonRequestBehavior.AllowGet);
    }

    我们用jQuery的getJson函数。来调用上述MVC函数返回的JSON对象就可以。

    $.getJSON("/Employee/getEmployee", null, getData);
    function getData(data)
    {
    alert(data.empcode);
    }

    jQuery的getJson函数有三个參数:

    • 第一个參数,获取JSON数据的URL地址。
    • 第二个參数,能够将数据传递到URL的MVC操作。眼下,我们仅仅是做一个get操作,故第二个參数为NULL。

    • 第三个參数,在JavaScript中,用回调函数对返回的Employee对象进行处理。

    由于输出是JSON,它会自己主动将JSON数据转换为JavaScript对象。你可直接使用“getData”函数显示了“data.empcode”属性,非常便捷。

    能否够将JSON对象Post到server?

    能够。

    能够使用jQuery的“post”方法将数据发送到server。

    以下是怎样post方法调用的样例,相同的。post有3个參数:

    • 第一个參数,接受JSON数据的URL地址
    • 第二个參数,是我们要发送的Json对象
    • 第三个參数,是回调函数,我们收到回应的数据进行处理。
    var mydata ={name:"Shiv",city:"Mumbai"};
    $.post("/Send/Request", // URL
    mydata , // Data to be sent
    function(data,status){alert(data + &ldquo; &ldquo; + status);}); // Call back function

    怎样把一个完整的HTML表单以JSON格式Post到server上?

    首先,我们须要调用jQuery的”serialize“,把须要post的表单序列化为JSON对象。

    然后,採用上面相似的办法进行post就可以。

    完整代码例如以下:

    var Mydata = $("#form1").serialize();
    $.post("/Customer/getCustomer",JSON. stringify (MyData), DisplayData);

    在后台(server),可通过inputStream进行捕获JSON数据流。

    System.IO.Stream body = Request.InputStream;
    System.IO.StreamReader reader = new System.IO.StreamReader(body);
    string s =   reader.ReadToEnd() ;

    我们怎样才干把JSON字符串转换为C#对象?

    要转换一个JSON字符串到C#对象,我们须要使用“JavaScriptSerializer”类。并使用“反序列化”。我们将字符串转换为C#对象。

    var jsonser = new JavaScriptSerializer()
    var obj = jsonser.Deserialize<dynamic>(JsonString);
    foreach (var x in obj)
    {
        String strvalue = x[&ldquo;value&rdquo;];
    }
  • 相关阅读:
    Silverlight实用窍门系列:68.Silverlight的资源字典ResourceDictionary
    在HyperlinkButton的URL地址里附加多个参数(以http get的方式)
    SilverLight CheckBox 控件 DataContext属性与DataContextChanged事件
    关于事件在意料之外触发的问题
    关于Telerik RadGridView 数据列拖动后异常的一种情况
    silverlight使用小计(先做记录后续整理)
    Redis_简介和安装
    Python并行系统工具_multiprocessing模块
    Python并行系统工具_程序退出和进程间通信
    Python并行系统工具_进程分支
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/6884855.html
Copyright © 2011-2022 走看看