ASP MVC3 - Ação HttpPost não encontrada após a publicação
Tenho um aplicativo ASP MVC3 que possui vários métodos HttpPost ActionResult. Durante uma sessão de depuração, os métodos funcionam bem. Mas quando publico e visualizo o aplicativo Web no navegador, apenas os métodos HttpPost falham. O Firebug mostra um "404 não encontrado". Outros métodos que não são HttpPost no mesmo controlador funcionam be
ATUALIZAR
1) O URL publicado para o aplicativo é localhost / psp. 2) Todas as ações GET retornam URLs dehttp: // localhost / psp / 'controlador' / 'ação'.
3) As ações POST estão retornando URLs dehttp: // localhost / 'controlador' / 'ação'.
Então isso parece ser um problema de roteamento. A única rota que tenho no meu arquivo Global.asax.cs é:
routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
Observe que o controlador Home NÃO contém nenhuma das ações HttpPost. Todos os métodos POST que falham estão em um controlador separado. Tentei ajustar esta rota para:psp/{controller}/{action}/{id}
mas, em seguida, recebe um erro 403.14 (FYI, estou usando o IIS 7.5
Estou perplexo com o porquê desses métodos HttpPost funcionarem durante a depuração, mas não em um aplicativo publicado. Aqui está um dos métodos que obtém o erro 404 após a publicação:
[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);
}
Aqui está a vista parcial:
@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>
E aqui está o javascript que chama o método HttpPost e, em seguida, carrega a exibição parcial retornada em uma div chamada "returnProjData":
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;
}