【发布时间】:2012-02-20 05:32:29
【问题描述】:
我有一个 ASP MVC3 应用程序,它有几个 HttpPost ActionResult 方法。在调试会话期间,这些方法工作正常。但是当我在浏览器中发布和查看 Web 应用程序时,只有 HttpPost 方法失败。 Firebug 显示“404 未找到”。同一控制器中的其他非 HttpPost 方法工作正常。
更新:
1) 应用发布的 url 是 localhost/psp。
2) 所有的 GET 动作都返回 http://localhost/psp/'controller'/'action' 的 URL。
3)POST动作返回http://localhost/'controller'/'action'的URL。
所以这似乎是一个路由问题。我在 Global.asax.cs 文件中的唯一路径是:
routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
请注意,Home 控制器不包含任何 HttpPost 操作。所有失败的 POST 方法都在单独的控制器中。我尝试将此路由调整为:psp/{controller}/{action}/{id},但随后收到 403.14 错误(仅供参考,我使用的是 IIS 7.5)。
我对为什么这些 HttpPost 方法在调试期间有效但在已发布的应用程序中无效感到困惑。以下是发布后出现404错误的方法之一:
[HttpPost]
public ActionResult GetAreaSelTexResult(JSON_MapSelPars pars)
{
AreaSelTextResult myResult = new AreaSelTextResult();
using (var ctx = new prismEntities())
{
var q = from p in ctx.pPSPMapSummary_Sel(pars.areaType, pars.areaName, null, null,pars.goalCDL) select p;
// There should only be one record returned, so loop will iterate only once.
foreach (var k in q)
{
//Move procedure results to object
myResult.TopProjectName1 = k.TopProjectName1;
myResult.TopProjectName2 = k.TopProjectName2;
myResult.TopProjectName3 = k.TopProjectName3;
myResult.TopProjectSnapshotLink1 = k.TopProjectSnapshotLink1;
myResult.TopProjectSnapshotLink2 = k.TopProjectSnapshotLink2;
myResult.TopProjectSnapshotLink3 = k.TopProjectSnapshotLink3;
myResult.TotalProjectAmt = string.Format("{0:C}", k.TotalProjectAmt);
myResult.TotalProjectCount = k.TotalProjectCount;
}
}
// send object to partial view
return PartialView("GetAreaSelTexResult", myResult);
}
这是部分视图:
@model PAA.Models.AreaSelTextResult
<p>@Model.TotalProjectCount projects</p>
<p>@Model.TotalProjectAmt total</p>
<p>
<a href="@Model.TopProjectSnapshotLink1">@Model.TopProjectName1</a></p>
<p>
<a href="@Model.TopProjectSnapshotLink2">@Model.TopProjectName2</a></p>
<p>
<a href="@Model.TopProjectSnapshotLink3">@Model.TopProjectName3</a></p>
这里是调用 HttpPost 方法然后将返回的局部视图加载到名为“returnedProjData”的 div 中的 javascript:
function retrieveSelectionSummary(selectionName, selectionType) {
$('#goalList input:checked').each(function () {
goals += $(this).attr('value') + ",";
});
var attr = { areaName: selectionName,
areaType: selectionType,
yearCDL: null,
goalCDL: null,
statusCDL: status
};
var json = JSON.stringify(attr);
$.ajax({
url: '/summary/GetAreaSelTexResult',
type: 'POST',
dataType: 'html',
data: json,
contentType: 'application/json; charset=utf-8',
success: function (result) {
$('#returnedProjData').html(result);
},
error: function () {
alert("Error.");
}
});
return attr;
}
【问题讨论】:
-
你能发布呈现表单的视图代码吗? POST 返回 404 后,浏览器中的 URL 是什么?你是通过 AJAX 调用这个吗?
-
我同意,这听起来更像是一个路由问题,而不是一个从未调用过的操作方法的问题。
-
@MartinNH - 是的,这似乎是您建议的路由问题。请查看帖子顶部附近的更新。 Post 操作的 URL 缺少应用程序目录。感谢您的帮助。