我正在尝试在.net core 2.0应用程序中反序列化后显示json数据。 Feed提供商每1-3秒通过POST请求将JSON文件发送到我的服务器(他将数据推送到我的服务器)
这就是我在做什么:
我处理POST请求发送的gzip文件,并解压缩其中的json文件,然后将其下载到我的服务器上(完成)
现在,我正在尝试读取此json文件并将其显示在第一页“ index.cshtml”上。我们将为供稿提供者发送的每个POST请求创建一个新行->实时显示行(NOT DONE YET)
INDEX.XSHTML视图示例
1- FIRST LINE =“ info”:{“ id”:84844481,“ name”:“五个岛屿 vs Pigotts Bullets FC”,“体育”:“足球”,“联赛”:“安提瓜和巴布达 总理 部门”,“开始时间”:“ 22:11”,“开始日期”:“ 15.12.2019”,“开始时间”:1576444268,“期间”:“第二 Half“,” minute“:” 73“,” secunds“:” 72:54“,” score“:” 0:0“,” points“:”“,” pitch“:”“,” ball_pos“:” “,” add_time“:”“,”玩家“:”“,”州“:” 21012“}
2-第二行=“信息”:{“ id”:84844482,“名称”:“ xxxx vs xxxx FC”,“运动”:“足球”,“联赛”:“ SERIE” A“,” start_time“:” 22:30“,” start_date“:” 15.12.2019“,” start_ts“:1576444268,” period“:” 2nd Half“,” minute“:” 18“,” secunds“:” 18:54“,” score“:” 0:0“,” points“:”“,” pitch“:”“,” ball_pos“:” 0.71, 0.48“,” add_time“:”“,” player“:” hoffman“,” state“:” 21000“} 3- ETC. ....
PS:这里我只是按原样复制了信息标签=>确保我需要格式正确的信息,例如:1- FIRST LINE:id = xxxxx,name =“”,....
这是JSON feed的示例:https://filebin.net/k5enw2wn4f5bc89m/inplay-soccer.json?t=84y0df94
这是我到目前为止的代码:
ValuesController
using System;
using System.Collections.Generic;
using System.IO;
using System.IO.Compression;
using System.Linq;
using System.Net;
using System.Text;
using System.Threading.Tasks;
using HelloWorld.Models;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Newtonsoft.Json;
// For more information on enabling Web API for empty projects, visit https://go.microsoft.com/fwlink/?LinkID=397860
namespace HelloWorld.Controllers
{
[Route("")]
public class ValuesController : Controller
{
// POST api/<controller>
[HttpPost]
[Consumes("application/gzip")]
public async Task<IActionResult> PostAsync(IFormFile file)
{
WebClient Client = new WebClient();
Client.DownloadFile("http://inplay.goalserve.com/inplay-soccer.gz", "C:\\temp\\inplay-soccer.gz");
using (var inputFileStream = new FileStream("c:\\temp\\inplay-soccer.gz", FileMode.Open))
using (var gzipStream = new GZipStream(inputFileStream, CompressionMode.Decompress))
using (var outputFileStream = new FileStream("c:\\temp\\inplay-soccer.json", FileMode.Create))
{
await gzipStream.CopyToAsync(outputFileStream);
}
using (StreamReader r = new StreamReader("c:\\temp\\inplay-soccer.json"))
{
string json = r.ReadToEnd();
var objects = JsonConvert.DeserializeObject<Goalserve>(json);
return View(objects);
}
return Ok();
}
}
}
Goalserve模型(我是用https://app.quicktype.io/生成的)->也许这里有些问题!
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Linq;
using System.Threading.Tasks;
namespace HelloWorld.Models
{
public partial class Goalserve
{
[JsonProperty("updated")]
public string Updated { get; set; }
[JsonProperty("updated_ts")]
public long UpdatedTs { get; set; }
[JsonProperty("events")]
public Events Events { get; set; }
}
public partial class Events
{
[JsonProperty("84586848")]
public The84586848 The84586848 { get; set; }
}
public partial class The84586848
{
[JsonProperty("core")]
public Core Core { get; set; }
[JsonProperty("info")]
public InfoClass Info { get; set; }
[JsonProperty("stats")]
public Dictionary<string, Stat> Stats { get; set; }
[JsonProperty("odds")]
public Dictionary<string, Odd> Odds { get; set; }
}
public partial class Core
{
[JsonProperty("safe")]
public long Safe { get; set; }
[JsonProperty("stopped")]
public long Stopped { get; set; }
[JsonProperty("blocked")]
public long Blocked { get; set; }
[JsonProperty("finished")]
public long Finished { get; set; }
[JsonProperty("updated")]
public DateTimeOffset Updated { get; set; }
[JsonProperty("updated_ts")]
public long UpdatedTs { get; set; }
}
public partial class InfoClass
{
[JsonProperty("id")]
public long Id { get; set; }
[JsonProperty("name")]
public string Name { get; set; }
[JsonProperty("sport")]
public string Sport { get; set; }
[JsonProperty("league")]
public string League { get; set; }
[JsonProperty("start_time")]
public string StartTime { get; set; }
[JsonProperty("start_date")]
public string StartDate { get; set; }
[JsonProperty("start_ts")]
public long StartTs { get; set; }
[JsonProperty("period")]
public string Period { get; set; }
[JsonProperty("minute")]
[JsonConverter(typeof(ParseStringConverter))]
public long Minute { get; set; }
[JsonProperty("secunds")]
public string Secunds { get; set; }
[JsonProperty("score")]
public string Score { get; set; }
[JsonProperty("points")]
public string Points { get; set; }
[JsonProperty("pitch")]
public string Pitch { get; set; }
[JsonProperty("ball_pos")]
public string BallPos { get; set; }
[JsonProperty("add_time")]
public string AddTime { get; set; }
[JsonProperty("player")]
public string Player { get; set; }
[JsonProperty("state")]
[JsonConverter(typeof(ParseStringConverter))]
public long State { get; set; }
}
public partial class Odd
{
[JsonProperty("id")]
public long Id { get; set; }
[JsonProperty("name")]
public string Name { get; set; }
[JsonProperty("short_name")]
public string ShortName { get; set; }
[JsonProperty("suspend")]
public long Suspend { get; set; }
[JsonProperty("order")]
public long Order { get; set; }
[JsonProperty("info")]
public InfoEnum Info { get; set; }
[JsonProperty("participants")]
public Dictionary<string, Participant> Participants { get; set; }
}
public partial class Participant
{
[JsonProperty("id")]
public long Id { get; set; }
[JsonProperty("order")]
public long Order { get; set; }
[JsonProperty("name")]
public string Name { get; set; }
[JsonProperty("short_name")]
public string ShortName { get; set; }
[JsonProperty("value_eu")]
public string ValueEu { get; set; }
[JsonProperty("value_na")]
public string ValueNa { get; set; }
[JsonProperty("value_us")]
public string ValueUs { get; set; }
[JsonProperty("handicap")]
public string Handicap { get; set; }
[JsonProperty("suspend")]
public long Suspend { get; set; }
}
public partial class Stat
{
[JsonProperty("name")]
public string Name { get; set; }
[JsonProperty("home")]
public string Home { get; set; }
[JsonProperty("away")]
public string Away { get; set; }
}
public enum InfoEnum { Count070007959, CurrentCorners11, Empty };
internal static class Converter
{
public static readonly JsonSerializerSettings Settings = new JsonSerializerSettings
{
MetadataPropertyHandling = MetadataPropertyHandling.Ignore,
DateParseHandling = DateParseHandling.None,
Converters =
{
InfoEnumConverter.Singleton,
new IsoDateTimeConverter { DateTimeStyles = DateTimeStyles.AssumeUniversal }
},
};
}
internal class ParseStringConverter : JsonConverter
{
public override bool CanConvert(Type t) => t == typeof(long) || t == typeof(long?);
public override object ReadJson(JsonReader reader, Type t, object existingValue, JsonSerializer serializer)
{
if (reader.TokenType == JsonToken.Null) return null;
var value = serializer.Deserialize<string>(reader);
long l;
if (Int64.TryParse(value, out l))
{
return l;
}
throw new Exception("Cannot unmarshal type long");
}
public override void WriteJson(JsonWriter writer, object untypedValue, JsonSerializer serializer)
{
if (untypedValue == null)
{
serializer.Serialize(writer, null);
return;
}
var value = (long)untypedValue;
serializer.Serialize(writer, value.ToString());
return;
}
public static readonly ParseStringConverter Singleton = new ParseStringConverter();
}
internal class InfoEnumConverter : JsonConverter
{
public override bool CanConvert(Type t) => t == typeof(InfoEnum) || t == typeof(InfoEnum?);
public override object ReadJson(JsonReader reader, Type t, object existingValue, JsonSerializer serializer)
{
if (reader.TokenType == JsonToken.Null) return null;
var value = serializer.Deserialize<string>(reader);
switch (value)
{
case "":
return InfoEnum.Empty;
case "Count : 0 (70:00 - 79:59)":
return InfoEnum.Count070007959;
case "Current Corners : 11":
return InfoEnum.CurrentCorners11;
}
throw new Exception("Cannot unmarshal type InfoEnum");
}
public override void WriteJson(JsonWriter writer, object untypedValue, JsonSerializer serializer)
{
if (untypedValue == null)
{
serializer.Serialize(writer, null);
return;
}
var value = (InfoEnum)untypedValue;
switch (value)
{
case InfoEnum.Empty:
serializer.Serialize(writer, "");
return;
case InfoEnum.Count070007959:
serializer.Serialize(writer, "Count : 0 (70:00 - 79:59)");
return;
case InfoEnum.CurrentCorners11:
serializer.Serialize(writer, "Current Corners : 11");
return;
}
throw new Exception("Cannot marshal type InfoEnum");
}
public static readonly InfoEnumConverter Singleton = new InfoEnumConverter();
}
}
Index.xshtml
@page
@model HelloWorld.Models.Goalserve
@{
var objects = Model;
}
<table>
<tr>
test
<td>@objects.ToString()</td>
</tr>
</table>
有人可以帮助我实施此.net应用吗?
我肯定有一些我不熟悉的概念/模型,如果有人可以帮助我实现此代码,我将不胜感激。
非常感谢您的帮助!
答案 0 :(得分:1)
您可以使用LINQ查询JSON文件。请参阅:SelectToken
var jobject = JObject.Parse(json);
var results = jobject.SelectTokens("$..info");