蛋疼的路由规则约定
在上一篇文章中
我们成功通过AJAX获取到了服务器的数据,
而且服务器根据请求的类型,格式化数据之后再传给客户端。
然而
在上一篇的实例中,
我们为controller程序增加一个GetProducts方法
让这个方法与GetAllProducts方法逻辑一致
再运行程序,
发现前端AJAX已经无法正常获取数据了
对于AJAX请求
服务端返回如下内容
Multiple actions were found that match the request:
System.Collections.Generic.IEnumerable`1[HelloWebAPI.Models.Product] GetAllProducts() on type HelloWebAPI.Controllers.ProductsController\r\nSystem.Collections.Generic.IEnumerable`1[HelloWebAPI.Models.Product] GetProducts() on type HelloWebAPI.Controllers.ProductsController
也就是说
有两个同样的action满足这个请求( $.getJSON("api/products/",………..)
如果你尝试把Action名字加在请求的路径当中
比如$.getJSON("api/products/GetProducts/"….
那么就会得到这样的反馈:
"The parameters dictionary contains a null entry for parameter 'id' of non-nullable type 'System.Int32' for method 'HelloWebAPI.Models.Product GetProductById(Int32)' in 'HelloWebAPI.Controllers.ProductsController'. An optional parameter must be a reference type, a nullable type, or be declared as an optional parameter."
也就是说这个请求与
GetProductById(int id)
这个Action冲突了!
查阅微软说明得知:
在Web API的controller当中
只要方法名以“Get”开头
就会匹配所有的Get请求
同理以Post开头的方法
将匹配所有的Post请求
(目前我个人认为这是一个非常蛋疼的约定!!!)
(小尾鱼也这么认为)
插播一句
VS2012中注释与取消注释的快捷图标改成这样
也是非常蛋疼的改变!还以为是要插入个tip框!
接收POST请求
我们为实例中的controller增加一个方法
这个方法接收一个Product实体
这个实体是POST来的数据自动序列化得来的
这个工作是由WEB API完成的
在客户端POST数据的js代码如下:
前端传递的JSON对象,在ACTION中被序列化为实体类型。
如下图:
好吧,假设我们没有一个类型与传递的json对象相对应
该如何是好呢?
我首先想到的是把参数改成string类型的
但string类型的参数并不能接收到任何内容
如下图所示
看来我的想法是错误的
我想总会有办法解决这个问题
就此搁笔
希望喜欢的朋友推荐,并留言!