Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Asp.net Core Post parameter is always null [closed]

I'm sending POST from fiddler:

POST http://localhost:55924/api/Product HTTP/1.1
User-Agent: Fiddler
Host: localhost:55924
Content-Type: application/json; charset=utf-8
Content-Length: 84

{"Ean″:”1122u88991″,”Name″:”Post test″,"Description":"Post test desc"}

But Post method always gets null.

// POST api/Product
[HttpPost]
public IActionResult PostProduct([FromBody]Product product)
{
    if (!ModelState.IsValid)
    {
        return BadRequest(ModelState);
    }

    _repo.Add(product);

    return CreatedAtRoute("GetToode",product);
}

When I use [FormBody] product is always null, when not using it product is valued but with all fields being null. Product class is simple.

public class Product
{
    public int ProductID { get; set; }
    public string EAN { get; set; }
    public string Name { get; set; }
    public string Description { get; set; }
    public int? CategoryID { get; set; }
}

i tried adding NullValueHandling to ConfigureServices as proposed in post but no use.

services.AddMvc()
    .AddJsonOptions(jsonOptions =>
    {
        jsonOptions.SerializerSettings.NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore;
    });
like image 492
martinv Avatar asked Sep 28 '16 12:09

martinv


2 Answers

I experience a similar problem but I had no check for the validity of the ModelState as the OP. When this happens, inspecting it in debug mode will likely point you to what's wrong with the model:

QuickWatch window

In this example I was using an invalid string 'A' as test value for a Guid property, so the model was always null.

like image 158
jcespinoza Avatar answered Oct 23 '22 13:10

jcespinoza


I just had to correct the double quotes in your POST request and it worked. Try this:

{"Ean":"1122u88991","Name":"Post test","Description":"Post test desc"}

See screenshot below.

Screenshot

like image 38
Ignas Avatar answered Oct 23 '22 14:10

Ignas