我正在开发一个 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">×</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
为我工作。
- 将 [IgnoreAntiforgeryToken(Order = 1001(] 添加到 PageModel。即使您的项目中禁用了防伪令牌。
- 从 url 的开头删除"/",在这种情况下,浏览器将针对当前页面发出请求,因此您无需对整个路径进行硬编码。
例:
url: 'NameOfPageModel?handler=NameOfHandler'
不要忘记从处理程序名称中删除前缀 OnPost 和后缀 Async(如果存在(。