BUG记录 -- json无法正常解析DateTime格式(.NetCore3.1 )

项目场景:

项目使用.NetCore 3.1框架,WebAPI 定义一个 Post 一个接口。


参数:Model实体类(包含 DateTime类型 字段),代码如下。
[Route("api/[controller]")]
[ApiController]
public class DateTimeTController : ControllerBase
{
    /// <summary>
    /// Post 接口,参数为DateTime类型
    /// </summary>
    /// <param name="value"></param>
    [HttpPost]
    public bool Post([FromBody] UserModel value)
    {
        if (value.ID < 0)
        {
            return false;
        }
        // ...业务处理

        return true;
    }
}
public class UserModel
{
    public int ID { get; set; }
    public string Name { get; set; }
    public DateTime CreateTime { get; set; }
}

问题描述:

【问题描述】:调试接口,向接口传以下参数,返回400 “The JSON value could not be converted to System.DateTime”

{
  "id": 0,
  "name": "TestName",
  "createTime": "2020-01-01 06:53:10"
}

截图

原因分析:

【分析】:json无法正常解析 DateTime 格式。可是 “2020-01-01 06:53:10” 格式明明是正确的,为什么无法解析呢?

  原来是微软为了提高执行效率,将 System.Text.Json 作为内置 json 处理,但只识别 "2020-01-01T06:53:10" 这种格式 的时间值。


解决方案:

两种解决方案:
  a. 时间类型传参格式 :日期与时间中间添加 T 字符,举例:“2020-01-01T06:53:10”。
  b. 修改程序配置(微软不推荐
  在 startup.cs 配置文件中修改配置。提示:需要安装Microsoft.AspNetCore.Mvc.NewtonsoftJson。

public void ConfigureServices(IServiceCollection services)
{
    services.AddControllers().AddNewtonsoftJson();
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值