在用Asp.netCore 3.1 开发 WebApi 接口,若有时间类型的字段,会经常一个错误。
入参:
{
"schoolId": 111,
"beginTime": "2020-08-18 08:00:00",
"endTime": "2020-08-18 10:00:00",
}
然后就会报错:
The JSON value could not be converted to System.DateTime. Path: $.beginTime | LineNumber: 0 | BytePositionInLine: 48.
{
"code": 400,
"msg": "The JSON value could not be converted to System.DateTime. Path: $.beginTime | LineNumber: 0 | BytePositionInLine: 48."
}
为啥会有这个错误?时间格式明明没问题啊。
原因为程序无法正常解析该json, 主要是为了提升执行效率;System.Text.Json作为微软内置json处理,效率更高更快。
那么这个微软官方的json会认识什么格式的时间值呢?它只认下面的格式
2020-08-18T08:00
年月日和时分秒之间加一个T就OK了。
当然,还有一个解决方案,若你执意不想要这个T,我们可以将微软默认的Json解析换掉,换成NewtonsoftJson就可以了。
为Controllers添加NewtonsoftJson注册,在Startup.cs下
public void ConfigureServices(IServiceCollection services)
{
services.AddControllers() .AddNewtonsoftJson();
}
需要安装 Microsoft.AspNetCore.Mvc.NewtonsoftJson 包。