Vra*_*ela 3 c# .net-core asp.net-core-routing
所以我在 Startup.cs 中设置了以下默认模式:
app.UseEndpoints(endpoints =>
{
endpoints.MapControllerRoute(
name: "default",
pattern: "{controller}/{action}/{id?}");
});
Run Code Online (Sandbox Code Playgroud)
这是我的控制器:
[ApiController]
[Route("[controller]")]
public class WeatherForecastController : ControllerBase
{
private static readonly string[] Summaries = new[]
{
"Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"
};
private readonly ILogger<WeatherForecastController> _logger;
public WeatherForecastController(ILogger<WeatherForecastController> logger)
{
_logger = logger;
}
[HttpGet]
[Route("[action]")]
public IEnumerable<WeatherForecast> Get()
{
var rng = new Random();
return Enumerable.Range(1, 5).Select(index => new WeatherForecast
{
Date = DateTime.Now.AddDays(index),
TemperatureC = rng.Next(-20, 0),
Summary = Summaries[rng.Next(Summaries.Length)]
})
.ToArray();
}
[HttpGet]
[Route("[action]")]
public IEnumerable<WeatherForecast> Grab()
{
var rng = new Random();
return Enumerable.Range(1, 5).Select(index => new WeatherForecast
{
Date = DateTime.Now.AddDays(index),
TemperatureC = rng.Next(1, 55),
Summary = Summaries[rng.Next(Summaries.Length)]
})
.ToArray();
}
[Route("[action]")]
[HttpGet("{i:int}")]
public IEnumerable<WeatherForecast> Snatch(int i)
{
var rng = new Random();
return Enumerable.Range(i, 5).Select(index => new WeatherForecast
{
Date = DateTime.Now.AddDays(index),
TemperatureC = rng.Next(55, 100),
Summary = Summaries[rng.Next(Summaries.Length)]
})
.ToArray();
}
}
Run Code Online (Sandbox Code Playgroud)
现在当我打电话https://localhost:44388/weatherforecast/grab或https://localhost:44388/weatherforecast/get然后它工作得很好,但如果我打电话https://localhost:44388/weatherforecast/Snatch/1然后我进入Error: Cannot match any routes.我的浏览器。
我已经将最后一个方法 Snatch 设置为它需要一个 int 的参数,那么我做错了什么?
You need to use one route template to get the desired behavior
//GET weatherforecast/Snatch/1
[Route("[action]/{i:int}")]
[HttpGet]
public IEnumerable<WeatherForecast> Snatch(int i) {
//...
}
Run Code Online (Sandbox Code Playgroud)
Now as this is an ApiController, it would be enough to use only Http{Verb} for all the actions
When building a REST API, it's rare that you will want to use
[Route(...)]on an action method as the action will accept all HTTP methods. It's better to use the more specificHttp*Verb*Attributesto be precise about what your API supports. Clients of REST APIs are expected to know what paths and HTTP verbs map to specific logical operations.
//GET weatherforecast/Snatch/1
[HttpGet("[action]/{i:int}")]
public IEnumerable<WeatherForecast> Snatch(int i) {
//...
}
Run Code Online (Sandbox Code Playgroud)
And this can be simplified even further by aggregating the template
[ApiController]
[Route("[controller]/[action]")] //<-- NOTE THIS
public class WeatherForecastController : ControllerBase {
//...
//GET weatherforecast/get
[HttpGet]
public IEnumerable<WeatherForecast> Get() {
//...
}
//GET weatherforecast/grab
[HttpGet]
public IEnumerable<WeatherForecast> Grab() {
//...
}
//GET weatherforecast/Snatch/1
[HttpGet("{i:int}")]
public IEnumerable<WeatherForecast> Snatch(int i) {
//...
}
}
Run Code Online (Sandbox Code Playgroud)
Reference Routing to controller actions in ASP.NET Core
Reference Routing in ASP.NET Core
| 归档时间: |
|
| 查看次数: |
465 次 |
| 最近记录: |