У меня есть метод POST .NET Core API, который принимает экземпляр модели.Я тестирую свой API через Postman, и когда я отправляю объект в формате json на свой API, я вижу в журналах ссылки на привязку модели.Я думаю, что привязка модели не работает должным образом.Вот вывод от почтальона:
System.Text.Json.JsonException: The JSON value could not be converted to System.Boolean. Path: $.damaged | LineNumber: 0 | BytePositionInLine: 41.
at System.Text.Json.ThrowHelper.ThowJsonException(String message, Utf8JsonReader& reader, String path)
at System.Text.Json.ThrowHelper.ThrowJsonException_DeserializeUnableToConvertValue(Type propertyType, Utf8JsonReader& reader, String path)
at System.Text.Json.Serialization.JsonPropertyInfoNotNullable`3.Read(JsonTokenType tokenType, ReadStack& state, Utf8JsonReader& reader)
at System.Text.Json.Serialization.JsonSerializer.HandleValue(JsonTokenType tokenType, JsonSerializerOptions options, Utf8JsonReader& reader, ReadStack& state)
at System.Text.Json.Serialization.JsonSerializer.ReadCore(JsonSerializerOptions options, Utf8JsonReader& reader, ReadStack& readStack)
at System.Text.Json.Serialization.JsonSerializer.ReadCore(JsonReaderState& readerState, Boolean isFinalBlock, Span`1 buffer, JsonSerializerOptions options, ReadStack& readStack)
at System.Text.Json.Serialization.JsonSerializer.ReadAsync[TValue](Stream utf8Json, Type returnType, JsonSerializerOptions options, CancellationToken cancellationToken)
at System.Threading.Tasks.ValueTask`1.get_Result()
at Microsoft.AspNetCore.Mvc.Formatters.SystemTextJsonInputFormatter.ReadRequestBodyAsync(InputFormatterContext context, Encoding encoding)
at Microsoft.AspNetCore.Mvc.ModelBinding.Binders.BodyModelBinder.BindModelAsync(ModelBindingContext bindingContext)
at Microsoft.AspNetCore.Mvc.ModelBinding.ParameterBinder.BindModelAsync(ActionContext actionContext, IModelBinder modelBinder, IValueProvider valueProvider, ParameterDescriptor parameter, ModelMetadata metadata, Object value)
at Microsoft.AspNetCore.Mvc.Controllers.ControllerBinderDelegateProvider.<>c__DisplayClass0_0.<<CreateBinderDelegate>g__Bind|0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.<InvokeInnerFilterAsync>g__Awaited|13_0(ControllerActionInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.<InvokeNextResourceFilter>g__Awaited|24_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Rethrow(ResourceExecutedContextSealed context)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeFilterPipelineAsync()
--- End of stack trace from previous location where exception was thrown ---
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.<InvokeAsync>g__Logged|17_1(ResourceInvoker invoker)
at Microsoft.AspNetCore.Builder.RouterMiddleware.Invoke(HttpContext httpContext)
at IdentityServer4.Hosting.IdentityServerMiddleware.Invoke(HttpContext context, IEndpointRouter router, IUserSession session, IEventService events)
at IdentityServer4.Hosting.MutualTlsTokenEndpointMiddleware.Invoke(HttpContext context, IAuthenticationSchemeProvider schemes)
at Microsoft.AspNetCore.Authentication.AuthenticationMiddleware.Invoke(HttpContext context)
at IdentityServer4.Hosting.BaseUrlMiddleware.Invoke(HttpContext context)
at Microsoft.AspNetCore.Authentication.AuthenticationMiddleware.Invoke(HttpContext context)
at Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore.MigrationsEndPointMiddleware.Invoke(HttpContext context)
at Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore.DatabaseErrorPageMiddleware.Invoke(HttpContext httpContext)
at Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore.DatabaseErrorPageMiddleware.Invoke(HttpContext httpContext)
at Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)
HEADERS
=======
Cache-Control: no-cache
Connection: keep-alive
Content-Type: application/json
Accept: application/json
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.9
Authorization: Bearer eyJhbGciOiJ...
Cookie: _ga=GA1.1.968351695.1527270246; __utma=111872281.968351695.1527270246.1529431622.1530048579.3
Host: localhost:5001
User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36
Origin: chrome-extension://coohjcphdfgbiolnekdpbcijmhambjff
Content-Length: 194
В Почтальоне я отправляю свой json следующим образом:
{ "puDate": "0001-01-01", "damaged": "No", "boxed": "No", "pieceCount": 0, "address1": "123", "address2": "", "address3": "", "zip": "12345", "city": "SomeCity", "state": "AB", "po": 534560349, "createDate": "2019-06-06", "createdBy": "Me" }
Мое действие WebAPI (скаффолд по умолчанию)
// POST: api/ReturnShipmentQueues
[HttpPost]
public async Task<ActionResult<ReturnShipmentQueue>> PostReturnShipmentQueue(ReturnShipmentQueue returnShipmentQueue)
{
_context.ReturnShipmentQueue.Add(returnShipmentQueue);
try
{
await _context.SaveChangesAsync();
}
catch (DbUpdateException)
{
if (ReturnShipmentQueueExists(returnShipmentQueue.FkPonumber))
{
return Conflict();
}
else
{
throw;
}
}
return CreatedAtAction("GetReturnShipmentQueue", new { id = returnShipmentQueue.FkPonumber }, returnShipmentQueue);
}
И, конечно, модель:
using System;
using System.ComponentModel.DataAnnotations;
namespace WebApplication12.Models
{
public partial class ReturnShipmentQueue
{
[Key]
public long FkPonumber { get; set; }
public DateTime PickupDate { get; set; }
public bool Damaged { get; set; }
public bool Boxed { get; set; }
public int Pieces { get; set; }
public string Puaddress1 { get; set; }
public string Puaddress2 { get; set; }
public string Puaddress3 { get; set; }
public string Pucity { get; set; }
public string Pustate { get; set; }
public string Puzip { get; set; }
public DateTime CreateDate { get; set; }
public string CreatedBy { get; set; }
}
}
Я немного новичок в разработке API, но должен ли я указать некоторые параметры конфигурации для этого, или мне нужно что-то еще?