C# 使用 System.Web.Script.Serialization 解析 JSON

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介:

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯。这些特性使JSON成为理想的数据交换语言。

JSON建构于两种结构

    1、“名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表 (hash table),有键列表(keyed list),或者关联数组 (associative array)。
     示例:{"UserID":11, "Name":"Froog"}; 

    2、值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。
如:
    示例:var Users=[{"userID":"1","Name":"Froog","friends":["Jack","Zack","Justin"]},
             {"userID":"2","Name":"Zack","friends":["Jack","Zack","Justin"]},
             {"userID":"3","Name":"Justin","friends":["Jack","Zack","Justin"]}

这些都是常见的数据结构。事实上大部分现代计算机语言都以某种形式支持它们。这使得一种数据格式在同样基于这些结构的编程语言之间交号)分隔。 

JSON具有以下这些形式
     对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“,”(逗号)分隔。 
     数组是 值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用“,”(逗号)分隔值(value)可以是双引号括 起来的字符串(string)、数值(number)、true、false、 null、对象(object)或者数组(array)。这些结构可以嵌套。 
     字符串(string)是由双引号包围的任意数量Unicode字符的集合,使用反斜线转义。一个字符(character)即一个单独的字符串(character string)。
NET中通过JavaScriptSerializer类操作JSON对象
示例代码:

  1. JavaScriptSerializer json = new JavaScriptSerializer();
  2. // 反序列化JSON字符串到对象
  3. User user = json.Deserialize<User>(jsonString);
  4. // 序列化对象为JSON字符串
  5. string jsonString = json.Serialize(user);

JavaScriptSerializer 成员信息:http://msdn.microsoft.com/zh-cn/library /system.web.script.serialization.javascriptserializer_members.aspx



AJAX 中使用JSON

 



示例代码:

  1. function getResult()
  2.           {
  3.                  $.ajax({
  4.            type: "POST",
  5.            url: "?Json=true",
  6.            data:"UserInfo="+obj.toJSONString(),
  7.            success: function(msg){
  8.                                 var obj = msg.parseJSON();
  9.                                  alert( "Name: " + obj.Name +",User:"+obj.User );
  10.                                   }
  11.          });


完整示例代码


Default.aspx

 

  1. <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs"Inherits="JsonWeb._Default" %>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" >
  4. <head runat="server">
  5.     <title>Untitled Page</title>
  6.     <script src="http://www.json.org/json.js" type="text/javascript"></script>
  7.     <script src="http://code.jquery.com/jquery.js" type="text/javascript"></script>
  8. <script type="text/javascript">
  9.          // "名称/值"对的集合
  10.          var User={"userID":"1","Name":"Froog","friends":["Jack","Zack","Justin"]}
  11.                  alert(User.Name);alert(User.friends[0]);
  12.         
  13.          // 值的有序列表
  14.          var Users=[{"userID":"1","Name":"Froog","friends":["Jack","Zack","Justin"]},
  15.          {"userID":"2","Name":"Zack","friends":["Jack","Zack","Justin"]},
  16.          {"userID":"3","Name":"Justin","friends":["Jack","Zack","Justin"]}
  17.                      ]
  18.          alert(Users[2].Name);alert(Users[2].friends.length);
  19.          alert(escape());
  20.         
  21.          // 转换JSON字符到Object
  22.          var JsonString = '{"userID":"2","Name":"Froog","friends":["Jack","Zack","Justin"]}';   
  23.          var User2 = eval('(' + JsonString + ')');
  24.          alert(User2.Name);alert(User2.friends[0]);
  25.         
  26.          //引用 json.js 实现JSON字符与Object相互转换。
  27.          var obj = JsonString.parseJSON();   
  28.          alert(obj.toJSONString());  
  29.         
  30.           //AJAX 中使用JSON   
  31.           function getResult()
  32.           {
  33.                  $.ajax({
  34.            type: "POST",
  35.            url: "?Json=true",
  36.            data:"UserInfo="+obj.toJSONString(),
  37.            success: function(msg){
  38.                                  var obj = msg.parseJSON();
  39.                                  alert( "Name: " + obj.Name +",User:"+obj.User );
  40.                                   }
  41.          });
  42.      //   requestHeaders: {Accept: 'application/json'} /**/,
  43.                       }
  44. </script>
  45. </head>
  46. <body>
  47.     <form id="form1" runat="server">
  48.     <div>
  49.     <input type="button" value="AJAX" onclick="getResult()" />
  50.     </div>
  51.     </form>
  52. </body>
  53. </html>

 

Default.aspx.cs

 

  1. using System;
  2. using System.Collections;
  3. using System.Configuration;
  4. using System.Data;
  5. using System.Linq;
  6. using System.Web;
  7. using System.Web.Security;
  8. using System.Web.UI;
  9. using System.Web.UI.HtmlControls;
  10. using System.Web.UI.WebControls;
  11. using System.Web.UI.WebControls.WebParts;
  12. using System.Xml.Linq;
  13. using System.Web.Script.Serialization;
  14. namespace JsonWeb
  15. {
  16.     public partial class _Default : System.Web.UI.Page
  17.      {
  18.         protected void Page_Load(object sender, EventArgs e)
  19.          {
  20.             if (Request.QueryString["Json"] != null)
  21.              {
  22.                 // AJAX 异步调用处理程序
  23.                 string UserInfo = Request.Form["UserInfo"] ?? string.Empty;
  24.                  JavaScriptSerializer json = new JavaScriptSerializer();
  25.                  Product product = new Product() { Name = "Computer " };
  26.                 if (!string.IsNullOrEmpty(UserInfo))
  27.                  {
  28.                     // 反序列化
  29.                      User user = json.Deserialize<User>(UserInfo);
  30.                      product.User = user.Name;
  31.                  }
  32.                 else
  33.                  {
  34.                      product.User = "Unknow";
  35.                  }
  36.                 // 序列化
  37.                 string jsonString = json.Serialize(product);
  38.                 // 输出异步处理结果
  39.                  Response.ContentType = "application/json";
  40.                  Response.Write(jsonString);
  41.                  Response.End();
  42.              }
  43.          }
  44.      }
  45.      [Serializable]
  46.     public class Product
  47.      {
  48.         public string Name;
  49.         public string User;
  50.      }
  51.     public class User
  52.      {
  53.         public string Name { getset; }
  54.      }
  55. }
分类:  ASP.NET

本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/p/3317424.html ,如需转载请自行联系原作者
相关文章
|
22天前
|
存储 JSON API
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
——在成长的路上,我们都是同行者。这篇关于商品详情API接口的文章,希望能帮助到您。期待与您继续分享更多API接口的知识,请记得关注Anzexi58哦! 淘宝API接口(如淘宝开放平台提供的API)允许开发者获取淘宝商品的各种信息,包括商品详情。然而,需要注意的是,直接访问淘宝的商品数据API通常需要商家身份或开发者权限,并且需要遵循淘宝的API使用协议。
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
|
7天前
|
JSON 前端开发 JavaScript
解析JSON文件
解析JSON文件
28 9
|
24天前
|
前端开发 JavaScript C#
C#开发者的新天地:Blazor如何颠覆传统Web开发,打造下一代交互式UI?
【8月更文挑战第28天】Blazor 是 .NET 生态中的革命性框架,允许使用 C# 和 .NET 构建交互式 Web UI,替代传统 JavaScript。本文通过问答形式深入探讨 Blazor 的基本概念、优势及应用场景,并指导如何开始使用 Blazor。Blazor 支持代码共享、强类型检查和丰富的生态系统,简化 Web 开发流程。通过简单的命令即可创建 Blazor 应用,并利用其组件化和数据绑定特性快速搭建界面。无论对于 .NET 还是 Web 开发者,Blazor 都是一个值得尝试的新选择。
42 1
|
13天前
|
存储 JSON API
Python编程:解析HTTP请求返回的JSON数据
使用Python处理HTTP请求和解析JSON数据既直接又高效。`requests`库的简洁性和强大功能使得发送请求、接收和解析响应变得异常简单。以上步骤和示例提供了一个基础的框架,可以根据你的具体需求进行调整和扩展。通过合适的异常处理,你的代码将更加健壮和可靠,为用户提供更加流畅的体验。
39 0
|
21天前
|
Java Spring 容器
彻底改变你的编程人生!揭秘 Spring 框架依赖注入的神奇魔力,让你的代码瞬间焕然一新!
【8月更文挑战第31天】本文介绍 Spring 框架中的依赖注入(DI),一种降低代码耦合度的设计模式。通过 Spring 的 DI 容器,开发者可专注业务逻辑而非依赖管理。文中详细解释了 DI 的基本概念及其实现方式,如构造器注入、字段注入与 setter 方法注入,并提供示例说明如何在实际项目中应用这些技术。通过 Spring 的 @Configuration 和 @Bean 注解,可轻松定义与管理应用中的组件及其依赖关系,实现更简洁、易维护的代码结构。
26 0
|
21天前
|
前端开发 开发者 C#
深度解析 Uno Platform 中的 MVVM 模式:从理论到实践的全方位指南,助你轻松掌握通过 C# 与 XAML 构建高效可维护的跨平台应用秘籍
【8月更文挑战第31天】本文详细介绍如何在优秀的跨平台 UI 框架 Uno Platform 中实施 MVVM(Model-View-ViewModel)模式,通过一个简单的待办事项列表应用演示其实现过程。MVVM 模式有助于分离视图层与业务逻辑层,提升代码组织性、易测性和可维护性。Uno Platform 的数据绑定机制使视图与模型间的同步变得高效简便。文章通过构造 `TodoListViewModel` 类及其相关视图,展示了如何解耦视图与模型,实现动态数据绑定及命令处理,从而提高代码质量和开发效率。通过这一模式,开发者能更轻松地构建复杂的跨平台应用。
26 0
|
25天前
|
JSON API 数据格式
基于服务器响应的实时天气数据进行JSON解析的详细代码及其框架
【8月更文挑战第25天】这段资料介绍了一个使用Python从服务器获取实时天气数据并解析JSON格式数据的基本框架。主要分为三个部分:一是安装必要的`requests`库以发起HTTP请求获取数据,同时利用Python内置的`json`库处理JSON数据;二是提供了具体的代码实现,包括获取天气数据的`get_weather_data`函数和解析数据的`parse_weather_data`函数;三是对代码逻辑进行了详细说明,包括如何通过API获取数据以及如何解析这些数据来获取温度和天气描述等信息。用户需要根据实际使用的天气API调整代码中的API地址、参数和字段名称。
|
22天前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
1月前
|
存储 NoSQL Redis
redis 6源码解析之 object
redis 6源码解析之 object
55 6
|
7天前
|
存储 缓存 Java
什么是线程池?从底层源码入手,深度解析线程池的工作原理
本文从底层源码入手,深度解析ThreadPoolExecutor底层源码,包括其核心字段、内部类和重要方法,另外对Executors工具类下的四种自带线程池源码进行解释。 阅读本文后,可以对线程池的工作原理、七大参数、生命周期、拒绝策略等内容拥有更深入的认识。
什么是线程池?从底层源码入手,深度解析线程池的工作原理

推荐镜像

更多