ASP.NET 复杂JSON字符串反序列化操作

简介: 在MIS系统开发中,有时需要在主页顶部显示天气信息,本篇经验将和大家介绍一下实现过程。1、一个可以获取各个城市天气预报情况的网站:http://wthrcdn.

在MIS系统开发中,有时需要在主页顶部显示天气信息,本篇经验将和大家介绍一下实现过程。


1、一个可以获取各个城市天气预报情况的网站:

http://wthrcdn.etouch.cn/weather_mini?city=合肥

参数city的值根据你所在的城市相应修改,获取到的气象信息如下图所示:


JSON字符串如下:

{
    "desc": "OK",
    "status": 1000,
    "data": {
        "wendu": "25",
        "ganmao": "各项气象条件适宜,无明显降温过程,发生感冒机率较低。",
        "forecast": [
            {
                "fengxiang": "南风",
                "fengli": "3-4级",
                "high": "高温 27℃",
                "type": "晴",
                "low": "低温 15℃",
                "date": "14日星期五"
            },
            {
                "fengxiang": "东风",
                "fengli": "微风级",
                "high": "高温 28℃",
                "type": "多云",
                "low": "低温 18℃",
                "date": "15日星期六"
            },
            {
                "fengxiang": "东南风",
                "fengli": "3-4级",
                "high": "高温 25℃",
                "type": "中雨",
                "low": "低温 16℃",
                "date": "16日星期天"
            },
            {
                "fengxiang": "西风",
                "fengli": "3-4级",
                "high": "高温 25℃",
                "type": "多云",
                "low": "低温 20℃",
                "date": "17日星期一"
            },
            {
                "fengxiang": "西北风",
                "fengli": "3-4级",
                "high": "高温 27℃",
                "type": "晴",
                "low": "低温 15℃",
                "date": "18日星期二"
            }
        ],
        "yesterday": {
            "fl": "3-4级",
            "fx": "南风",
            "high": "高温 24℃",
            "type": "晴",
            "low": "低温 13℃",
            "date": "13日星期四"
        },
        "aqi": "73",
        "city": "合肥"
    }
}

附一个可以用于验证JSON字符串正确性的网址:http://www.bejson.com/

2、打开json2csharp网站,网站网址为:http://json2csharp.com/,将以上JSON串复制到编辑框中,然后点击“Generate”按钮,生成实体类,如下图所示:



3、C#代码实现,核心代码如下:


using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace CommonClass
{
    public class Forecast
    {
        public string fengxiang { get; set; }
        public string fengli { get; set; }
        public string high { get; set; }
        public string type { get; set; }
        public string low { get; set; }
        public string date { get; set; }
    }

    public class Yesterday
    {
        public string fl { get; set; }
        public string fx { get; set; }
        public string high { get; set; }
        public string type { get; set; }
        public string low { get; set; }
        public string date { get; set; }
    }

    public class Data
    {
        public string wendu { get; set; }
        public string ganmao { get; set; }
        public List<Forecast> forecast { get; set; }
        public Yesterday yesterday { get; set; }
        public string aqi { get; set; }
        public string city { get; set; }
    }

    public class RootObject
    {
        public string desc { get; set; }
        public int status { get; set; }
        public Data data { get; set; }
    }
}


Json2Entities.cs代码如下:
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.Serialization.Json;
using System.Text;
using System.Web;

namespace CommonClass
{
    public class Json2Entities
    {
        /// <summary>  
        /// 将json字符串转化为方法实体类  
        /// </summary>  
        /// <typeparam name="T"></typeparam>  
        /// <param name="jsonString"></param>  
        /// <returns></returns>  
        public static T JsonToObject<T>(string jsonString)
        {
            DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T));
            MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonString));
            T jsonObject = (T)ser.ReadObject(ms);
            ms.Close();
            return jsonObject;
        }
    }
}


        //用UTF-8转码有汉字参数的url
        protected string UrlUtf_8(string url)
        {
            byte[] bs = Encoding.GetEncoding("UTF-8").GetBytes(url);
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < bs.Length; i++)
            {
                if (bs[i] < 128)
                    sb.Append((char)bs[i]);
                else
                {
                    sb.Append("%" + bs[i++].ToString("x").PadLeft(2, '0'));
                    sb.Append("%" + bs[i].ToString("x").PadLeft(2, '0'));
                }
            }
            return sb.ToString();
        }
        //用UrlGB2312转码有汉字参数的url
        protected string UrlGB2312(string url)
        {
            byte[] bs = Encoding.GetEncoding("GB2312").GetBytes(url);
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < bs.Length; i++)
            {
                if (bs[i] < 128)
                    sb.Append((char)bs[i]);
                else
                {
                    sb.Append("%" + bs[i++].ToString("x").PadLeft(2, '0'));
                    sb.Append("%" + bs[i].ToString("x").PadLeft(2, '0'));
                }
            }
            return sb.ToString();
        }

        /// <summary>
        /// 
        /// </summary>
        /// <param name="url"></param>
        /// <returns></returns>
        public string GetFunction(string url)
        {
            string serviceAddress = url;
            //HttpWebRequest类继承于WebRequest,并没有自己的构造函数,需通过WebRequest的Creat方法 建立,并进行强制的类型转换 
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
            request.ContentType = "text/html;charset=UTF-8";
            request.Method = "GET";
            //通过HttpWebRequest的GetResponse()方法建立HttpWebResponse,强制类型转换 
            HttpWebResponse response = (HttpWebResponse)request.GetResponse();
            //GetResponseStream()方法获取HTTP响应的数据流,并尝试取得URL中所指定的网页内容 
            Stream myResponseStream = response.GetResponseStream();
            //站点在响应的时候用gzip压缩过了,用using (var gStream = new GZipStream(myResponseStream, CompressionMode.Decompress)){}解压 
            using (var gStream = new GZipStream(myResponseStream, CompressionMode.Decompress))
            {
                //Encoding.GetEncoding("UTF-8")转码
                StreamReader myStreamReader = new StreamReader(gStream, Encoding.GetEncoding("UTF-8"));
                string retString = myStreamReader.ReadToEnd();
                myStreamReader.Close();
                response.Close();
                myResponseStream.Close();
                return retString;
            }
        }

string url = "http://wthrcdn.etouch.cn/weather_mini?city=合肥";
string info = GetFunction(url);
RootObject rootObj = new RootObject();
rootObj = Json2Entities.JsonToObject<RootObject>(info);
string weather = rootObj.data.city + " " + rootObj.data.forecast[0].type + " " + rootObj.data.forecast[0].low.Replace("低温", "") + " ~ " + rootObj.data.forecast[0].high.Replace("高温", "");

4、实现效果如下图所示:





相关文章
|
4天前
|
存储 JSON 安全
【C++ JSON库 json值的创建手段】深入探究C++中JSON对象定位与操作:从引用到回调函数
【C++ JSON库 json值的创建手段】深入探究C++中JSON对象定位与操作:从引用到回调函数
74 0
|
4天前
|
存储 JSON JavaScript
Python字典和JSON字符串相互转化方法
【2月更文挑战第18天】
67 3
|
2天前
|
JSON JavaScript 前端开发
js将json字符串还原为json对象
【5月更文挑战第14天】js将json字符串还原为json对象
13 1
|
2天前
|
JSON NoSQL MongoDB
实时计算 Flink版产品使用合集之要将收集到的 MongoDB 数据映射成 JSON 对象而非按字段分割,该怎么操作
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
28 1
|
4天前
|
XML 开发框架 .NET
C#/ASP.NET应用程序配置文件app.config/web.config的增、删、改操作
C#/ASP.NET应用程序配置文件app.config/web.config的增、删、改操作
15 1
|
4天前
|
XML 存储 JSON
c#XML、JSON的序列化和反序列化,看完你就懂了
c#XML、JSON的序列化和反序列化,看完你就懂了
28 0
|
4天前
|
JSON Java Linux
【探索Linux】P.30(序列化和反序列化 | JSON序列化库 [ C++ ] )
【探索Linux】P.30(序列化和反序列化 | JSON序列化库 [ C++ ] )
23 2
|
4天前
|
SQL DataWorks 关系型数据库
DataWorks操作报错合集之DataWorks在同步mysql时报错Code:[Framework-02],mysql里面有个json类型字段,是什么原因导致的
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
33 0
|
4天前
|
存储 JSON DataWorks
DataWorks产品使用合集之DataWorks将 MongoDB 中的数组类型写入到 DataWorks 的单个字段时,表示为字符串格式而非 JSON 格式如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
26 3
|
4天前
|
JSON 分布式计算 大数据
MaxCompute产品使用合集之大数据计算MaxCompute 要提取JSON字符串中的所有key-value对,我该怎么操作
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。

热门文章

最新文章