【问题标题】:Reading json data from external api using C#使用 C# 从外部 api 读取 json 数据
【发布时间】:2019-03-22 04:04:51
【问题描述】:

我正在尝试读取来自 api 的 json 数据,我只想从这些数据中读取对象..

 string id_url = "http://abc/some_id";

 WebRequest requst = WebRequest.Create(id_url);
 requst.Method = "GET";
 requst.Headers["Authorization"] = "Basic " + Convert.ToBase64String(Encoding.Default.GetBytes("user:password"));

 HttpWebResponse response = requst.GetResponse() as HttpWebResponse;

 var encod = ASCIIEncoding.ASCII;

 using (var readchat = new System.IO.StreamReader(response.GetResponseStream(), encod))
 {
     string chatresult = readchat.ReadToEnd();

     var json = JObject.Parse(chatresult);
 }

我得到json

{
      "comment": null,
      "triggered_response": true,
      "rating": null,
      "visitor": {
        "phone": "",
        "name": "abc"
      },

      "history": [
        {
          "name": "Visitor 7949",
          "department_name": null,
          "type": "chat.memberjoin",
          "department_id": null
        },
        {
          "name": "fdef",
          "sender_type": "Trigger",
          "msg": "Welcome back! How may I help you today?",
          "type": "chat.msg"        
        },
        {
          "name": "use",
          "sender_type": "Trigger",
          "msg": "good morning",
          "type": "chat.msg"        
        }
      ]
}

我必须使用 C# 仅从 json 读取“msg”标签数据。我试过这个:

string data = json["history"].ToString();

通过上面的使用,我从“历史”标签中获取数据,但是如何能够像我们使用 javascript ajax 一样从历史 [array].msg 中获取文本。

【问题讨论】:

标签: c# asp.net-mvc asp.net-mvc-4 asp.net-web-api c#-4.0


【解决方案1】:

您可以将JsonConvert 与动态对象JsonConvert.DeserializeObject<dynamic>(data) 一起使用

示例代码:

string data = " {\"comment\": null,   \"triggered_response\": true,   \"rating\": null,   \"visitor\": {    \"phone\": \"\",    \"name\": \"abc\"   },   \"history\": [    {     \"name\": \"Visitor 7949\",     \"department_name\": null,     \"type\": \"chat.memberjoin\",     \"department_id\": null    },    {     \"name\": \"fdef\",     \"sender_type\": \"Trigger\",     \"msg\": \"Welcome back! How may I help you today?\",     \"type\": \"chat.msg\"        },{     \"name\": \"use\",     \"sender_type\": \"Trigger\",     \"msg\": \"good morning\",     \"type\": \"chat.msg\"        }   ]  }";

var dynamicobject = JsonConvert.DeserializeObject<dynamic>(data);

var historyname = dynamicobject.history[0].name.ToString();

【讨论】:

    【解决方案2】:
      //data structure for mapping
    public class History {
      public string name { get; set; }
      public string sender_type { get; set; }
      public string msg { get; set; }
      public string type { get; set; }
    }
    
    public class Visitor {
      public string Phone { get; set; }
      public string Name { get; set; }
    }
    
    
    public class ObjectThatContainsHistory {
      public string Comment { get; set; }
      public bool Triggered_Response { get; set; }
      public string Rating { get; set; }
      public Visitor Visitor { get; set; }
    
      public List<History> History { get; set; }
    }
    
      var jsonString =
        @"{
            ""comment"": null,
            ""triggered_response"": true,
            ""rating"": null,
            ""visitor"": {
              ""phone"": """",
              ""name"": ""abc""
            },
    
            ""history"": [
              {
                ""name"": ""Visitor 7949"",
                ""department_name"": null,
                ""type"": ""chat.memberjoin"",
                ""department_id"": null
              },
              {
                ""name"": ""fdef"",
                ""sender_type"": ""Trigger"",
                ""msg"": ""Welcome back! How may I help you today?"",
                ""type"": ""chat.msg""        
              },
              {
                ""name"": ""use"",
                ""sender_type"": ""Trigger"",
                ""msg"": ""good morning"",
                ""type"": ""chat.msg""        
              }
            ]
        }";
    
      ObjectThatContainsHistory objectThatContainsHistory = JsonConvert.DeserializeObject<ObjectThatContainsHistory>(jsonString);
    
      var messages = objectThatContainsHistory.History
        .Select(x => x.msg)
        .ToList();
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-08-15
      • 2019-08-09
      • 2017-07-06
      相关资源
      最近更新 更多