Web API ApiController PUT和POST方法间歇性地接收空参数

时间:2013-04-18 18:57:55

标签: .net asp.net-web-api

当我在调试器中运行测试时,我的ApiController方法有时会收到空参数。但是,如果我触摸控制器文件并重建它,它可以正常使用相同的测试。一切都是一样的,除了它重新编译Web Api项目的DLL。我打开了跟踪但除了参数是否为null之外它没有告诉我任何事情。怎么会发生这种情况?

我想它无法将JSON对象反序列化为参数类型,但我该如何解决这个问题?

编辑:已添加代码

此方法有时会收到value = null

public FilterItem Post(uint jobId, uint columnID, FilterItemDTO value)
    {
        // save a new FilterItem
    }

FilterItemDTO是我做的DTO类,因为FilterItem类有一堆不需要的继承字段,我不能在基类中注释它们:

public class FilterItemDTO
{
    public uint Id;
    public uint ColumnID { get; set; }
    public FilterItem.FilterType Type;
    public string Value;

    //Date/Time Stamps
    public DateTime? CreatedDate = null;
    public string CreatedBy = null;
    public DateTime? ModifiedDate;
    public string ModifiedBy = null;
    public int FilterLevel = 0;

    public FilterItemDTO(FilterItem f)
    {
        Id = f.ID;
        ColumnID = f.ColumnID;
        Type = f.Type;
        Value = f.Value;
        FilterLevel = f.FilterLevel;
        CreatedDate = f.CreatedDate;
        CreatedBy = f.CreatedBy;
        ModifiedDate = f.ModifiedDate;
        ModifiedBy = f.ModifiedBy;
    }

    internal static FilterItem ToFilterItem(FilterItemDTO value)
    {
        FilterItem f = new FilterItem(value.Type, value.Value, value.FilterLevel);
        f.ID = value.Id;
        f.ColumnID = value.ColumnID;
        f.CreatedDate = value.CreatedDate;
        f.CreatedBy = value.CreatedBy;
        f.ModifiedDate = value.ModifiedDate;
        f.ModifiedBy = value.ModifiedBy;

        return f;
    }

    public FilterItem ToFilterItem()
    {
        return FilterItemDTO.ToFilterItem(this);
    }
}

这是我发送的请求(从Fiddler便笺簿复制)

POST http://localhost:56875/api/job/4513/column/21213/filter HTTP/1.1
Host: localhost:56875
Connection: keep-alive
Content-Length: 28
Accept: application/json, text/javascript, */*; q=0.01
Origin: http://localhost:56875
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.31 (KHTML, like Gecko) Chrome/26.0.1410.64 Safari/537.31
Content-Type: application/json
Referer: http://localhost:56875/Content/test.htm
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-GB,en-US;q=0.8,en;q=0.6
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3

{"type":"Equal","value":"1"}

这是我的格式化程序配置。类型:“Equal”值应使用StringEnumConverter自动转换。

 public class FormatterConfig
{
    public static void RegisterGlobalFormatters(MediaTypeFormatterCollection formatters)
    {
        var jsonSerializerSettings = formatters.JsonFormatter.SerializerSettings;
        jsonSerializerSettings.Converters.Add(new IsoDateTimeConverter());

        // serialize every enum as a string
        jsonSerializerSettings.Converters.Add(new Newtonsoft.Json.Converters.StringEnumConverter());

        // include null value fields
        jsonSerializerSettings.NullValueHandling = NullValueHandling.Ignore;

        // use camel case
        jsonSerializerSettings.ContractResolver = new CamelCasePropertyNamesContractResolver();

        // indented formatting
        formatters.JsonFormatter.Indent = true;

        formatters.Remove(formatters.XmlFormatter);
    }
}

1 个答案:

答案 0 :(得分:1)

我会先尝试隔离问题:

  • 在一个控制器中注释掉除一个方法之外的所有方法,看它是否仍然受到影响

  • 对每个孤立的方法做同样的事情

  • 如果他们处于孤立状态,那么这意味着方法可能没有明确分开,有时WebApi会选择错误的方法(因为缺少属性或其他东西)

  • 如果它们仍然失败,并且失败仍然是随机的,我会检查传入的任何狡猾的对象 - 尝试使用fiddler多次重播请求并检查它们之间的失败(params,cookies,接受/内容类型标题等。)

  • 从app_start调试,如果需要,可以多次调试 - 你可能很清楚你的故障模式,只需继续调试,看看请求之间发生了什么变化

  • 检查是否有任何方法/测试未以任何其他方式覆盖应用程序的任何配置/更改状态

  • 尝试从对象中删除复杂属性,只留下原始类型,看看是否有帮助(如果有,则意味着类型序列化可能存在问题(例如继承相关))

  • 更改序列化程序

如果没有任何帮助,请发布一些代码。