在EntitySetController中创建自定义操作

时间:2013-09-18 01:35:05

标签: asp.net-web-api odata

我在.Net 4.5中有一个oData应用程序。 oData端点工作正常,但我想在控制器上创建自定义操作,以便在给定电子邮件地址时在Customer记录上设置标志。

这是我的客户端代码(使用AngularJS):

    $http({
        method: 'POST',
        url: '/odata/Customers/SetAlertFlag',
        data: { 'email': 'test@test.com'}
    }).success(function (data, status, headers, config) {
        // ...
    }).error(function (data, status, headers, config) {
        // ...
    });

这是我的服务器代码:

public class CustomersController : EntitySetController<Customer, int>
{
    private DBEntities db = new DBEntities();

    // ... other generated methods here


    // my custom method
    [HttpPut]
    public Boolean SetAlertFlag([FromBody] string email)
    {
        return true;
    }
}

永远不会调用服务器方法。当我在浏览器http://localhost:60903/odata/Customers/SetAlertFlag中输入此URL时,我收到此错误:“检测到无效操作。”SetAlertFlag'不是可以绑定到'Collection([Skirts.Models.Customer Nullable = False])'的操作。 “

EntitySetController类可以没有自定义方法吗?我该怎么做呢?

2 个答案:

答案 0 :(得分:7)

OData中的操作使用特定格式,需要POST。你需要:

将操作添加到EDM:

ActionConfiguration action = modelBuilder.Entity<Customer>().Collection.Action("SetAlertFlag");
action.Parameter<string>("email");

声明这样的动作:

[HttpPost]
public int SetAlertFlag(ODataActionParameters parameters) 
{ 
    if (!ModelState.IsValid)
    {
        throw new HttpResponseException(HttpStatusCode.BadRequest);
    }

    string email = (string)parameters["email"];
}

调用类似这样的动作:

POST http://localhost/odata/Customers/SetAlertFlag
Content-Type: application/json

{"email":"foo"}

在此处阅读更多内容:http://www.asp.net/web-api/overview/odata-support-in-aspnet-web-api/odata-actions

(我只输入了这些代码段,因此可能会出现一些错误,但这就是想法。)

答案 1 :(得分:0)

您在AngularJS中使用POST,但在.NET方法上有[HttpPut]属性。您需要在两侧使用POST或PUT。