Razor Pages POST 处理程序在 IIS 上返回 404



我正在开发一个 ASP.NET Core 2.1应用程序。我需要通过 ajax 调用命名页面处理程序。

该方法在调试/发布中正常工作,但在发布到 IIS 后失败。

我试过什么

  • 我现在使用@page"{handler?}"而不是将处理程序指定为查询参数
  • 我已确保请求 url 正确,并且表单包含"__RequestVerificationToken">
  • 我已将 IIS 应用程序池 CLR 版本更改为"无托管代码">
  • 我已经修改了我的 web.config 看起来像这样:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<modules runAllManagedModulesForAllRequests="true" />
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath="dotnet" arguments=".MyApp.dll" stdoutLogEnabled="false" stdoutLogFile=".logsstdout" />
</system.webServer>
</location>
</configuration>

法典:

这是处理程序方法,在其他页面中也有类似的方法,ajax 请求找不到它们(但同样,这仅在部署到 IIS 后才会发生(:

[HttpPost]
public IActionResult OnPostExampleHandler([FromForm]ExampleHandlerModel model)
{
// ...
return new JsonResult(new { data, message });
}

这是在提交时调用的javascript代码:

function submitForm()
{
return $.ajax(
{
type: "POST",
url: "/relativeURL/ExampleHandler",
data: $('#ExampleHandlerForm').serialize(),
dataType: "json",
complete: function (res)
{
// do something on completion
}
});
}

最后这是Html/Razor代码,我正在使用"form"TagHelper,它确保在序列化表单时存在AntiForgeryToken:

<form method="post" asp-page-handler="ExampleHandler" id="ExampleHandlerForm">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">@Model.Details.Description</h5>
<button type="button" class="close" data-dismiss="modal">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body form-row">
@* Input Fields *@
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">@Lang.Operations.Close</button>
<button type="button" onclick="submitForm();" class="btn btn-primary">@Lang.Operations.Save</button>
</div>
</div>
</form>

错误信息

POST http://root:port/relativeURL/ExampleHandler 404 (Not Found)
send    @   jquery.min.js:2
ajax    @   jquery.min.js:2
submitForm  @   VM106:13
onclick @   5:1

为我工作。

  1. 将 [IgnoreAntiforgeryToken(Order = 1001(] 添加到 PageModel。即使您的项目中禁用了防伪令牌。
  2. 从 url 的开头删除"/",在这种情况下,浏览器将针对当前页面发出请求,因此您无需对整个路径进行硬编码。

例:

url: 'NameOfPageModel?handler=NameOfHandler'

不要忘记从处理程序名称中删除前缀 OnPost 和后缀 Async(如果存在(。

最新更新