澳门至尊网站-首页

您的位置:澳门至尊网站 > 免费资源 > 输出到前面三个JSON的三种办法

输出到前面三个JSON的三种办法

2019-10-19 23:12

先是种:利用MODEL拼成要出口JSON的靶子。再用JSON.NET转成JSON输出到前端(这种常用,就不比如了。)

  本文意在介绍假若经过C#将赢获得的XML文书档案转变到对应的JSON格式字符串,然后将其出口到页这段时间端,以供JavaScript代码分析接纳。只怕你能够间接利用JavaScript代码通过Ajax的艺术来读取XML,然后直接对内部的内容举行剖析,这样或然更加直白一些。但本文中付出的代码目的在于认证什么通过原生的C#代码来产生那日新月异调换。除此而外,你还是能够借用一些第三方类库可能更加高端部分的.NET库对象来实践调换。大家来探视这里介绍的局地较为轻巧的艺术,但前提是你必需具备可支撑的类库和目的以备使用。

第两种:利用table拼成JSON数据格式,再用JSON.NET转成JSON输出到前面一个:

  • 使用Json.NET类库

          

  前提是急需首先下载和设置Json.NET类库,在那处能够找到

  dt = new DataTable();

            dt.Columns.Add(new DataColumn("列头",typeof(string)));
            dt.Columns.Add(new DataColumn("object", typeof(object)));

            DataRow dr = dt.NewRow();
            dr[0] = "abc";

            DataTable dt2 = dt.Clone();
            dt2.Columns.Add("defaultdata", typeof(string));
            DataRow dr2 = dt2.NewRow();
            dr2[0] = "defgijk";
            dr2["defaultdata"] = "cccc";
            dt2.Rows.Add(dr2);

            dr[1] = dt2;

            dt.Rows.Add(dr);

            GridView1.DataSource = dt.Rows[0][1];
            GridView1.DataBind();

            Label1.Text = JsonConvert.SerializeObject(dt);

  上面是三个例子:

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using Newtonsoft.Json;

namespace JSonConverter
{
    class Program
    {
        static void Main(string[] args)
        {
            string xml = "<Test><Name>Test class</Name><X>100</X><Y>200</Y></Test>";

            XmlDocument doc = new XmlDocument();
            doc.LoadXml(xml);
            string json = Newtonsoft.Json.JsonConvert.SerializeXmlNode(doc);

            Console.WriteLine("XML -> JSON: {0}", json);
            Console.ReadLine();

        }
    }
}

其二种:用JSON.net自带的JOBJECT,拼成JSON格式,转成JSON在前端输出:

  • 使用.NET Framework中的JavaScriptSerializer.aspx)类

    

  首先供给保险您的工程或服务器辅助.NET 4.0或上述版本的Framework,不然无法找到此类。

JObject obj = new JObject();
    obj.Add(new JProperty("Status", "S"));
    obj.Add(new JProperty("TotalCount", totalCount));
    JArray array = new JArray();
    if (result != null)
    {
    foreach (var item in result)
    {    
    array.Add(
    new JObject(
    new JProperty("X", item.X)
    , new JProperty(" XX", item.XX)
    , new JProperty("XXX", item.XXX)
    , new JProperty("Xxxxx", item.XXXX)
    , new JProperty("xxxxxxx", item.XXXXX)
    , new JProperty("xxxxxxxxx", item.XXXXXX)
    , new JProperty("xxxxxxxxxxx", item.XXXXXXX)
    , new JProperty("xxxxxxxxxxxxx", item.XXXXXXXX)
    , new JProperty("xxxxxxxxxxxxxxxxx", item.XXXXXXXXX)
    , new JProperty("xxxxxxxxxxxxxxxxxxxx", item.XXXXXXXXXX)
    , new JProperty("xxxxxxxxxxxxxxxxxxxxxxx", item.XXXXXXXXXXX)));
    }
    obj.Add(new JProperty("WorkOrderManagerList", array));
    Response.Write(JsonConvert.SerializeObject(obj));

  下边是二个例子:

 

using System;
using System.Linq;
using System.Web.Script.Serialization;
using System.Xml.Linq;

class Program
{
    static void Main()
    {
        var xml = 
        @"<Columns>
          <Column Name=""key1"" DataType=""Boolean"">True</Column>
          <Column Name=""key2"" DataType=""String"">Hello World</Column>
          <Column Name=""key3"" DataType=""Integer"">999</Column>
        </Columns>";
        var dic = XDocument
            .Parse(xml)
            .Descendants("Column")
            .ToDictionary(
                c => c.Attribute("Name").Value, 
                c => c.Value
            );
        var json = new JavaScriptSerializer().Serialize(dic);
        Console.WriteLine(json);
    }
}

 第各样:利用array数组和hashtable拼成JSON格式,转成JSON在前端输出:

  其出口结果为:{"key1":"True","key2":"Hello World","key3":"999"}

    

  也许还也会有越来越多的不二等秘书技,这里不豆蔻梢头一列出了。那么怎样运用原生的C#代码将XML转变到JSON格式字符串呢?大概说该C#代码在非常低版本的.NET Framework中也得以运转吧?来探问上边的牵线吧。

 ArrayList eventList = new ArrayList();

     Hashtable hx = new Hashtable();
     hx.Add("eventid", 1);
          hx.Add("eventname", "圣诞节");
       hx.Add("eventdate", "2018-08-25");
       hx.Add("eventlocation", "公司会议中心");

       for (int i = 0; i < 3; i++)
      {
      Hashtable ht = new Hashtable();
      ht.Add("eventid", i + 1);
      ht.Add("eventname", "圣诞节");
      ht.Add("eventdate", hx);
      ht.Add("eventlocation", "公司会议中心");
      eventList.Add(ht);
     }
    JavaScriptSerializer ser = new JavaScriptSerializer();
    String jsonStr = ser.Serialize(eventList);
    Response.Write(jsonStr);

Introduction

 

  JSON是三个轻量级的数据交流格式,它能够非常轻巧地被页面包车型地铁JavaScript编码为对象的样式,进而方便数据操作。

  基于AJAX的页面使用XmlHttpRequest指标从服务端接收数据来响应客户的呼吁,当重临的数码是XML格式时,它能够被转移为JSON格式的字符串进而通过JavaScript特别轻便地对数码举行拍卖。

  多数应用程序都将数据存款和储蓄为XML的格式,何况会将数据以JSON的格式发送到客户端以做越发管理。要落到实处那一点,它们必需将XML格式转变为JSON格式。上面的ASP.NET C#代码实现了那后生可畏进程。

Code Description

  代码中提供了贰个方式XmlToJSON,能够用来将XmlDocument目的调换为JSON字符串。代码通过迭代每一个XML节点、属性以至子节点,来创设对应的JSON对象。

  • 代码不会变卦数字和布尔类型的值
  • Xml DocumentElement对象始终会被转移为JSON对象的member:object,它遵守上边那几个法规。
  • 节点的习性会被对应地改造为JSON对象的分子"attr_name":"attr_value"。如:

    XML JSON
    <xx yy='nn'></xx> { "xx" : { "yy" : "nn" } }
    <xx yy=''></xx> { "xx" : { "yy" : "" } }
  • 不曾参节点、属性和剧情的节点被转移为成员"child_name":null

    XML JSON
    <xx/> { "xx" : null }
  • 从未有过子节点和总体性,不过有内容的节点被转移为成员"child_name":"child_text"

    XML JSON
    <xx>yyy</xx> { "xx" : "yyy" }
  • 其他节点和属性会被正好地转移为"child_name":对象或然"child_name":[elements]对象数组,节点的值会被退换为目的成员的"value",如:

    XML JSON
    <xx yy='nn'><mm>zzz</mm></xx> { "xx" : { "yy" : "nn", "mm" : "zzz" } }
    <xx yy='nn'><mm>zzz</mm><mm>aaa</mm></xx> { "xx" : { "yy" : "nn", "mm" : [ "zzz", "aaa" ] } }
    <xx><mm>zzz</mm>some text</xx> { "xx" : { "mm" : "zzz", "value" : "some text" } }
    <xx value='yyy'>some text<mm>zzz</mm>more text</xx> { "xx" : { "mm" : "zzz", "value" : [ "yyy", "some text", "more text" ] } }
  • 字符会被平安地转变为JSON字符串。注意该调换不会保险你的JavaScript代码不会惨被任何注入攻击,假如中间的剧情来自于风姿洒脱段不安全的XML数据源的话。上面那些例子演示了字符的转义:

    XML JSON
    <aa>/z'z''zyyy</aa> { "aa" : "/zu0027z''z\yyy" }

   在好几特殊的情状下,例如下面包车型地铁代码,恐怕需求您本身对反斜线进行转义。

string JSON = XmlToJSON(doc);
JSON = JSON.Replace(@"", @"\");

  注意,在页面上应用任何未经济检察查的XML数据时都会存在安全祸患。

Example

XML输入:

<space name="Cake Collage">
<frame>
  <photo img="cakecollage1.jpg" />
  <text string="Browse my cake space" />
  <rule type="F" img="cakecollage9.jpg" x="150" y="0" w="300" h="250" />
  <rule type="F" img="cakecollage2.jpg" x="0" y="0" w="150" h="220" />
</frame>
<frame>
  <photo img="cakecollage2.jpg" />
  <rule type="B" img="cakecollage1.jpg" />
  <rule type="L" img="cakecollage3.jpg" />
</frame>
</space>

JSON输出(对代码实行了格式化):

{ "space":
  { "name": "Cake Collage",
    "frame": [ {"photo": { "img": "cakecollage1.jpg" },
                "rule": [ { "type": "F",
                            "img": "cakecollage9.jpg",
                            "x": "150",
                            "y": "0",
                            "w": "300",
                            "h": "250"
                          }, 
                          { "type": "F",
                            "img": "cakecollage2.jpg",
                            "x": "0",  
                            "y": "0",  
                            "w": "150",  
                            "h": "220" 
                          }
                        ],
                "text": { "string": "Browse my cake space" }
               },
               {"photo": { "img": "cakecollage2.jpg" },
                "rule": [ { "type": "B", "img": "cakecollage1.jpg" },
                          { "type": "L",  "img": "cakecollage3.jpg" }
                        ]
               }
             ]
  }
}

  黄金年代旦JSON字符串被定义为二个JavaScript对象,如space_DOM,大家便得以在JavaScript代码中动用上边这个指标和质量:

  • space_DOM.space.name
  • space_DOM.space.frame.length
  • space_DOM.space.frame[0].text.string
  • space_DOM.space.frame[0].rule[0].type

  你的JavaScript代码应该能够非常灵活地应对种种情形,如成员空头支票、成员只包蕴value、或成员是三个数组。上边这些函数能够将装有的分子转变到贰个数组,进而回答各种区别的情形。

function ObjectToArray( obj)
{
    if( !obj) return new Array();
    if( !obj.length) return new Array(obj);
    return obj;
}

space_DOM.space.frame = ObjectToArray(space_DOM.space.frame);

XmlToJSON C# code

  上面给出对应的C#源代码,通过传播的XmlDocument对象将其改换为对应的JSON格式字符串。

private static string XmlToJSON(XmlDocument xmlDoc)
{
    StringBuilder sbJSON = new StringBuilder();
    sbJSON.Append("{ ");
    XmlToJSONnode(sbJSON, xmlDoc.DocumentElement, true);
    sbJSON.Append("}");
    return sbJSON.ToString();
}

//  XmlToJSONnode:  Output an XmlElement, possibly as part of a higher array
private static void XmlToJSONnode(StringBuilder sbJSON, XmlElement node, bool showNodeName)
{
    if (showNodeName)
        sbJSON.Append(""" + SafeJSON(node.Name) + "": ");
    sbJSON.Append("{");
    // Build a sorted list of key-value pairs
    //  where   key is case-sensitive nodeName
    //          value is an ArrayList of string or XmlElement
    //  so that we know whether the nodeName is an array or not.
    SortedList childNodeNames = new SortedList();

    //  Add in all node attributes
    if( node.Attributes!=null)
        foreach (XmlAttribute attr in node.Attributes)
            StoreChildNode(childNodeNames,attr.Name,attr.InnerText);

    //  Add in all nodes
    foreach (XmlNode cnode in node.ChildNodes)
    {
        if (cnode is XmlText)
            StoreChildNode(childNodeNames, "value", cnode.InnerText);
        else if (cnode is XmlElement)
            StoreChildNode(childNodeNames, cnode.Name, cnode);
    }

    // Now output all stored info
    foreach (string childname in childNodeNames.Keys)
    {
        ArrayList alChild = (ArrayList)childNodeNames[childname];
        if (alChild.Count == 1)
            OutputNode(childname, alChild[0], sbJSON, true);
        else
        {
            sbJSON.Append(" "" + SafeJSON(childname) + "": [ ");
            foreach (object Child in alChild)
                OutputNode(childname, Child, sbJSON, false);
            sbJSON.Remove(sbJSON.Length - 2, 2);
            sbJSON.Append(" ], ");
        }
    }
    sbJSON.Remove(sbJSON.Length - 2, 2);
    sbJSON.Append(" }");
}

//  StoreChildNode: Store data associated with each nodeName
//                  so that we know whether the nodeName is an array or not.
private static void StoreChildNode(SortedList childNodeNames, string nodeName, object nodeValue)
{
    // Pre-process contraction of XmlElement-s
    if (nodeValue is XmlElement)
    {
        // Convert  <aa></aa> into "aa":null
        //          <aa>xx</aa> into "aa":"xx"
        XmlNode cnode = (XmlNode)nodeValue;
        if( cnode.Attributes.Count == 0)
        {
            XmlNodeList children = cnode.ChildNodes;
            if( children.Count==0)
                nodeValue = null;
            else if (children.Count == 1 && (children[0] is XmlText))
                nodeValue = ((XmlText)(children[0])).InnerText;
        }
    }
    // Add nodeValue to ArrayList associated with each nodeName
    // If nodeName doesn't exist then add it
    object oValuesAL = childNodeNames[nodeName];
    ArrayList ValuesAL;
    if (oValuesAL == null)
    {
        ValuesAL = new ArrayList();
        childNodeNames[nodeName] = ValuesAL;
    }
    else
        ValuesAL = (ArrayList)oValuesAL;
    ValuesAL.Add(nodeValue);
}

private static void OutputNode(string childname, object alChild, StringBuilder sbJSON, bool showNodeName)
{
    if (alChild == null)
    {
        if (showNodeName)
            sbJSON.Append(""" + SafeJSON(childname) + "": ");
        sbJSON.Append("null");
    }
    else if (alChild is string)
    {
        if (showNodeName)
            sbJSON.Append(""" + SafeJSON(childname) + "": ");
        string sChild = (string)alChild;
        sChild = sChild.Trim();
        sbJSON.Append(""" + SafeJSON(sChild) + """);
    }
    else
        XmlToJSONnode(sbJSON, (XmlElement)alChild, showNodeName);
    sbJSON.Append(", ");
}

// Make a string safe for JSON
private static string SafeJSON(string sIn)
{
    StringBuilder sbOut = new StringBuilder(sIn.Length);
    foreach (char ch in sIn)
    {
        if (Char.IsControl(ch) || ch == ''')
        {
            int ich = (int)ch;
            sbOut.Append(@"u" + ich.ToString("x4"));
            continue;
        }
        else if (ch == '"' || ch == '\' || ch == '/')
        {
            sbOut.Append('\');
        }
        sbOut.Append(ch);
    }
    return sbOut.ToString();
}

Using XmlToJSON

  上面包车型地铁代码演示了如何在ASP.NET 2的页面中利用XmlToJSON()办法。页面上使用了ClientScriptManager对象来作为JavaScript代码的容器。当然,你一丝一毫能够利用另外任何方法将所改造的JSON字符串放到前端页面上。通过上边包车型客车代码,程序在前端页面上调用二个名称为space_processJSON的JavaScript函数,并将JSON字符串作为参数字传送递给它。

protected void Page_Load(object sender, EventArgs e)
{
    XmlDocument doc = new XmlDocument();
    try
    {
        string path = Server.MapPath(".");
        doc.Load(path+"whatever.xml");
    }
    catch (Exception ex)
    {
        lblError.Text = ex.ToString();
        return;
    }

    // Convert XML to a JSON string
    string JSON = XmlToJSON(doc);

    // Replace  with \ because string is being decoded twice
    JSON = JSON.Replace(@"", @"\");

    // Insert code to process JSON at end of page
    ClientScriptManager cs = Page.ClientScript;
    cs.RegisterStartupScript(GetType(), "SpaceJSON", "space_processJSON('" + JSON + "');", true);
}

  来探视前端页面上定义的这一个JavaScript函数的具体内容。

<script src="space/json.js" type="text/javascript"></script>

<script type="text/javascript">
function space_processJSON( JSON)
{
    space_DOM = JSON.parseJSON();
    if( !space_DOM)
    {
        alert("JSON decode error");
        return;
    }
    space_DOM.space.frame = ObjectToArray(space_DOM.space.frame);
    space_frameCount = space_DOM.space.frame.length;
    //.. or whatever
}
</script>

  原来的书文出处:《How to convert XML to JSON in ASP.NET C#》

本文由澳门至尊网站发布于免费资源,转载请注明出处:输出到前面三个JSON的三种办法

关键词:

  • 上一篇:没有了
  • 下一篇:没有了