c#实现http请求并解析返回之json

 

        作为一个新手,在实习的时候接触了web service,当时感觉十分新奇,就在网上搜索了一些web service,做了一些个比如天气查询之类的东西,但是网上提供的大部分的接口是通过http请求来实现的,所以就萌发了想要用C#发出http请求来实现天气查询的想法。

 

         C#是通过HttpWebRequest类和HttpWebResponseL类来实现http请求的发出和http响应的接收的,由于本人刚用这两个类,不是太熟悉,所以属性和方法就不在这里给大家讲解了。

       代码如下:

      

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net;
using System.Xml;
using System.Web;
using System.IO;
using System.Runtime.Serialization.Json;
using System.Runtime.Serialization;

namespace httpTest
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("请输入您要查询的地区!");
            string region = Console.ReadLine();
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://api.36wu.com/Weather/GetWeather?district="+region);
            request.Method = "GET";
            HttpWebResponse response = request.GetResponse() as HttpWebResponse;
            StreamReader stream = new StreamReader(response.GetResponseStream(), Encoding.UTF8);
            string jsonstr = stream.ReadLine();
            var ser = new DataContractJsonSerializer(typeof(weater));
            var ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonstr));
            weater sn = (weater)ser.ReadObject(ms);
            Console.WriteLine("{0}的当前气温是{1}",region,sn.data.temp);
            Console.ReadKey();
        }
    }
    [DataContract]
    class weater
    {
        [DataMember]
        public int status { get; set; }
        [DataMember]
        public string message { get; set; }
        [DataMember]
        public data data { get; set; }
    }
    [DataContract]
    class data
    {
        [DataMember]
        public string dateTime { get; set; }
        [DataMember]
        public string city { get; set; }
        [DataMember]
        public string temp { get; set; }
        [DataMember]
        public string minTemp { get; set; }
        [DataMember]
        public string maxTemp { get; set; }
        [DataMember]
        public string weathe { get; set; }
        [DataMember]
        public string windDirection { get; set; }
        [DataMember]
        public string windForce { get; set; }
        [DataMember]
        public string humidity { get; set; }
        [DataMember]
        public string img_1 { get; set; }
        [DataMember]
        public string img_2 { get; set; }
        [DataMember]
        public string refreshTime { get; set; }
    }
}


     这里我用的是控制台程序,其中比较简单,我就不一一解释了,其中需要注意的一点是得到的json是

 

    

{
    "status": 200, 
    "message": "OK", 
    "data": {
        "dateTime": "2014年3月23日", 
        "city": "北京", 
        "temp": "17℃", 
        "minTemp": "7℃", 
        "maxTemp": "20℃", 
        "weather": "晴转阴", 
        "windDirection": "南风", 
        "windForce": "2级", 
        "humidity": "26%", 
        "img_1": "0", 
        "img_2": "2", 
        "refreshTime": "13:18"
    }
}


    所以在写类的时候要注意,同时 [DataContract] [DataMember]  不能够少,不然无法解析json字符串。

 

 

 

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是使用C#实现HTTP POST请求,设置Header并获取JSON数据并保存到MySQL数据库的示例代码: ```csharp using System; using System.Net; using System.IO; using System.Text; using MySql.Data.MySqlClient; using Newtonsoft.Json; namespace HttpPostExample { class Program { static void Main(string[] args) { // 设置POST请求的URL地址 string url = "https://example.com/api/data"; // 设置POST请求的Header WebRequest request = WebRequest.Create(url); request.Method = "POST"; request.ContentType = "application/json"; request.Headers["Authorization"] = "Bearer your_access_token_here"; // 构造POST请求的JSON数据 string postData = JsonConvert.SerializeObject(new { name = "John", age = 30 }); // 将JSON数据写入请求流中 byte[] byteArray = Encoding.UTF8.GetBytes(postData); request.ContentLength = byteArray.Length; Stream dataStream = request.GetRequestStream(); dataStream.Write(byteArray, 0, byteArray.Length); dataStream.Close(); // 发送POST请求并获取响应 WebResponse response = request.GetResponse(); dataStream = response.GetResponseStream(); StreamReader reader = new StreamReader(dataStream); string responseFromServer = reader.ReadToEnd(); // 关闭流 reader.Close(); dataStream.Close(); response.Close(); // 解析JSON数据并保存到MySQL数据库 dynamic data = JsonConvert.DeserializeObject(responseFromServer); string connectionString = "server=localhost;database=mydatabase;uid=myusername;password=mypassword;"; using (MySqlConnection connection = new MySqlConnection(connectionString)) { connection.Open(); MySqlCommand command = connection.CreateCommand(); command.CommandText = "INSERT INTO mytable (name, age) VALUES (@name, @age)"; command.Parameters.AddWithValue("@name", data.name); command.Parameters.AddWithValue("@age", data.age); command.ExecuteNonQuery(); connection.Close(); } Console.WriteLine("Data saved to database successfully."); } } } ``` 在上面的示例代码中,我们首先设置POST请求的URL地址和Header,然后构造POST请求的JSON数据并将其写入请求流中。接下来,我们发送POST请求并获取响应,并将响应的JSON数据解析并保存到MySQL数据库中。最后,我们输出一条消息表示数据已成功保存到数据库中。 请注意,示例代码中使用了Json.NET库来处理JSON数据。如果您没有安装此库,请使用NuGet包管理器安装它。您还需要将MySQL.Data.dll添加到您的项目引用中。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值