2015-11-10 47 views
1

我想实现一个搜索过滤器来获取我的控制器之一中的对象。 我有以下代码:FromUri似乎没有工作Web API

public class SearchFilter 
{ 
    public DateTime? BusinessDate; 
    public DateTime? BusinessDateFrom; 
    public DateTime? BusinessDateTo; 
    public bool? Status; 
} 

这是我的控制器:

public SearchFilter get([FromUri] SearchFilter SearchFilter) 
    { 
     var Results = db.MyTable.Where(t => t.Published == true); 
     if (SearchFilter.BusinessDate != null) 
     { 
      Results = Results.Where(t => t.BusinessDate == SearchFilter.BusinessDate); 
     } 
     else 
     { 
      if (SearchFilter.BusinessDateFrom != null && SearchFilter.BusinessDateTo != null) 
      { 
       Results = Results.Where(t => t.BusinessDate >= SearchFilter.BusinessDateFrom && t.BusinessDate <= SearchFilter.BusinessDateTo); 
      } 
     } 
     if (SearchFilter.Status != null) 
     { 
      Results = Results.Where(t => t.Approved == SearchFilter.Status); 
     } 

     return SearchFilter; 
    } 

我现在回到SearchFilter只是为了看看它是否工作,因为过滤不工作。

这是为什么:

请求:http://localhost:11513/api/MyController/?BusinessDateFrom=2015-09-10&BusinessDateTo=2015-09-12&BusinessDate=09/09/2015&Status=true 结果:

{ 
    "BusinessDate": null, 
    "BusinessDateFrom": null, 
    "BusinessDateTo": null, 
    "Status": null 
} 

谁能解释什么,我做错了,因为根据这个环节应该是非常直截了当:

http://www.asp.net/web-api/overview/formats-and-model-binding/parameter-binding-in-aspnet-web-api

回答

3

我意识到问题所在。

问题在于SearchFilter类,它缺少每个属性的getset

public class SearchFilter 
{ 
    public DateTime? BusinessDate { get; set; } 
    public DateTime? BusinessDateFrom { get; set; } 
    public DateTime? BusinessDateTo { get; set; } 
    public bool? Status { get; set; } 
} 

这使得它像魅力一样工作。

+0

我刚刚发现这个问题 - 不幸的是我没有拥有这个对象,所以我必须使用getters/setters创建一个DTO并使用automapper。 –