一种可能的解决方法是确认路由参数名称是否唯一并确保路由模板与控制器方法签名的参数匹配。
例如,以下代码片段将导致路由参数名称重复而引发问题:
[HttpGet("{id}")]
public IActionResult Get(int id)
{
// code
}
[HttpPost("{id}")]
public IActionResult Post(int id)
{
// code
}
在此示例中,HttpGet 和 HttpPost 控制器方法都使用名称为 "id" 的路由参数。
要解决此问题,您可以更改路由参数名称以确保唯一。例如:
[HttpGet("{id}")]
public IActionResult Get(int id)
{
// code
}
[HttpPost("{newId}")]
public IActionResult Post(int newId)
{
// code
}
在此示例中,HttpPost 控制器方法更改参数名称以'newId”替换'id”,以确保唯一性。
如果路由参数名称是唯一的,则可能需要检查路由模板是否与控制器方法签名的参数匹配。如果不匹配,将无法正确解析路由并导致问题。在这种情况下,您应该确保路由模板与方法签名的参数匹配,并更改它们以匹配。
此外,您可以在 Startup.cs 文件中启用端点命名空间(Endpoint Routing 中间件),以避免路由参数名称重复导致的问题。要启用此选项,请添加以下代码:
services.AddControllersWithViews().AddRazorRuntimeCompilation().ConfigureApplicationPartManager(apm =>
{
// Enable endpoint routing namespace inclusion for api help pages
var assembly = typeof(Startup).Assembly;
apm.ApplicationParts.Add(new Microsoft.AspNetCore.Mvc.ApplicationParts.AssemblyPart(assembly));
apm.FeatureProviders.Add(new Microsoft.AspNetCore.Mvc.ApplicationParts.Controllers.ControllerFeatureProvider());
}).SetCompatibilityVersion(CompatibilityVersion.Version_3_0).AddJsonOptions(options => options.JsonSerializerOptions.WriteIndented = true);
此代码包括在 ConfigureApplicationPartManager 内部一个特定的 Microsoft.AspNetCore.Mvc.ApplicationParts.AssemblyPart 定义,它启用了命名空间包括器,通过 ApplicationPart 类管理。
另一种解决方法是添加一个别名,用于映射不同路由模板的控制器