Чтение данных JSON из внешнего API с помощью C # - PullRequest
0 голосов
/ 22 марта 2019

Я пытаюсь прочитать данные JSON, поступающие из API, и я просто хочу прочитать объекты из этих данных ..

 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"        
        }
      ]
}

Мне нужно только читать данные тега "msg" из json, используя C #. Я пробовал это:

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

Используя выше, я получаю данные из тега "history", но как я смогу получить текст из history [array] .msg, как мы это делаем с помощью javascript ajax.

Ответы [ 2 ]

1 голос
/ 22 марта 2019

Вы можете использовать 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();
0 голосов
/ 22 марта 2019
  //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();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...