- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在制作一个带有 Web API 的网站,我试图将 JSON 发送到我的 Controller ,但这是我不断收到的错误。
Multiple actions were found that match the request:
Post on type AuctionWebsiteASP.Controllers.MovesController
readDatabase on type AuctionWebsiteASP.Controllers.MovesController
newItem on type AuctionWebsiteASP.Controllers.MovesController
首先,我尝试搜索修复程序,但此处的修复程序均无济于事。
我的 Controller
public class MovesController : ApiController
{
[AcceptVerbs("GET", "POST")]
public HttpResponseMessage Post([FromBody] Product product)
{
products.Add(product);
newItem();
return Request.CreateResponse(HttpStatusCode.OK, product);
}
}
我的JS
$.ajax({
type: "POST",
dataType: "json",
url: "/api/moves/",
data: source,
success: function (data) {
$("#nStart").val(null);
$("#nImg").val(null);
$("#nMaker").val(null);
$("#nModel").val(null);
$("#nSerial").val(null);
$("#nCpu").val(null);
$("#nRam").val(null);
$("#nGpu").val(null);
$("#nStorage").val(null);
$("#nBattery").val(null);
$("#nDrivers").val(null);
$("#nAccessories").val(null);
$("#nNotes").val(null);
console.log("Data has been sent!");
},
error: function (error) {
jsonValue = jQuery.parseJSON(error.responseText);
alert("ERROR!");
}
});
提前致谢!
最佳答案
你的路线大概是这样的
routes.MapHttpRoute(
name: "API Default",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional });
但是为了使用相同的 http 方法执行多个操作,您需要通过这样的路由向 webapi 提供更多信息:
routes.MapHttpRoute(
name: "API Default",
routeTemplate: "api/{controller}/{action}/{id}",
defaults: new { id = RouteParameter.Optional });
尝试使用 Route
属性来区分每个 Action ,例如
public class MovesController : ApiController
{
[Route("Product")]
public HttpResponseMessage Post([FromBody] Product product)
{
products.Add(product);
newItem();
return Request.CreateResponse(HttpStatusCode.OK, product);
}
}
$.ajax({
输入:“发布”,
数据类型:“json”,
网址:“/api/移动/产品”,
数据源,
成功:功能(数据){
$("#nStart").val(空);
$("#nImg").val(null);
$("#nMaker").val(null);
$("#nModel").val(空);
$("#nSerial").val(空);
$("#nCpu").val(空);
$("#nRam").val(空);
$("#nGpu").val(空);
$("#nStorage").val(null);
$("#nBattery").val(null);
$("#nDrivers").val(null);
$("#nAccessories").val(null);
$("#nNotes").val(null);
console.log("数据已发送!");
},
错误:函数(错误){
jsonValue = jQuery.parseJSON(error.responseText);
警报(“错误!”);
}
});
关于javascript - 如何将 JSON 发送到 Web API?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40758077/
我是一名优秀的程序员,十分优秀!