首页 > 解决方案 > 当从 Html 表单调用带有 HttpPost 的 ASP.NET CORE 3.1 操作时,服务器返回 405 错误

问题描述

我有一个网站开发,一个用HtmlFormASP.NET CORE 3.1装饰并被调用的动作[HttpPost][ValidateAntiForgeryToken]我的本地主机上一切正常,但是当我将其发布到服务器时,只有这种方法会出现 405 错误。(联系表格的另一种方法HttpPost是可以的)

我在 fidller 中的请求标头:

服务器上的 405 错误

我不知道为什么安全标头Allow: GET在我的请求标头中,我的操作方法用 [HttpPost] 装饰,而在我的 HTML 表单中,方法设置为 POST。在 stackoverflow 和网络上的其他资源中进行了大量搜索后,我已经完成了这些解决方案,但没有一个对我有用。

这是我的行动方法

[HttpPost]
[ValidateAntiForgeryToken]
[EnableCors("MyPolicy")]
public async Task<IActionResult> Order(OrderSingleProductViewModel model) {
            
   if(!ModelState.IsValid) {
                var product = await _productService.GetResultByIdAsync(model.ProductId);
                return RedirectToAction("Detail", "Post", new {
                    postType = PostType.PRODUCT,
                    slug = product.Slug
                });
            }

            var data = model.Adapt<OrderSingleProductDto>();
            //var basket = await _orderProductService.OrderProductAsync(data);
            var invoice = await _orderProductService.CreateInvoiceAsync(data);
            var result = invoice.Adapt<CustomerInvoiceViewModel>();
            result.CurrencyTitle = WebsiteInfo.CurrencyInfo.DefaultCurrencyTitle;
            var contactInfo = await _websiteOptionService.GetContactInfoAsync();
            result.InvoiceInfo.Address = contactInfo.Address1;
            result.InvoiceInfo.Email = contactInfo.Email;
            result.InvoiceInfo.Phones = contactInfo.Phones;

            var optionLogo = await _websiteOptionService
                .GetOptionAsync("website.logo");
            var optionCompany = await _websiteOptionService
                .GetOptionAsync("company.name");

            if (optionLogo != null)
                result.InvoiceInfo.Logo = optionLogo.Value;

            if (optionCompany != null)
                result.InvoiceInfo.Company = optionCompany.Value;

            return View(result);
        }

    

启用 CORS

public void ConfigureServices(IServiceCollection services) {
            services.AddCors(o => o.AddPolicy("MyPolicy", builder => {
                builder.AllowAnyOrigin()
                       .AllowAnyMethod()
                       .AllowAnyHeader();
            }));
}

在 Startup 类的 Configure 方法中:

app.UseCors("MyPolicy");

连我的动作方法都装饰着[EnableCors("MyPolicy")]

我的 Web.config 文件:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <location path="." inheritInChildApplications="false">
    <system.webServer>
    <modules runAllManagedModulesForAllRequests="false">
        <remove name="WebDAVModule" />
      </modules>
      <handlers>
        <remove name="aspNetCore" />
        <remove name="WebDAV" />
        <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
      </handlers>
      <aspNetCore processPath=".\Felan.Web.exe" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" hostingModel="inprocess" />
    </system.webServer>
  </location>
</configuration>

而且我的网站托管在共享主机提供商中,因此我无法访问 IIS 或任何其他服务器的配置。

标签: c#asp.net-corecorsweb-config

解决方案


最后,我发现问题出在数据库中具有 NULL 值的字段之一,并且我期待NUllable must have a value应用程序的开发人员异常页面中出现异常,但我一直收到HTTP 405错误消息。

在我的问题中,我写了我尝试过的所有解决方案。它看起来像 HTTP 405 错误意味着您必须使用代码检查所有内容,尤其是数据库错误和值。希望它对功能中的某人有所帮助。


推荐阅读