参考
.NET WebAPI 基础 FromRoute、FromQuery、FromBody 用法 - 知乎 (zhihu.com)
使用
环境搭建
创建实体类 Parameter
data:image/s3,"s3://crabby-images/abe5f/abe5f339fa5dd3e49cda0efbfd64b46d49a8dced" alt=""
url 传参
使用 【 & 】
请求格式: https://localhost:7290/api/Param?Method=Get&Value=Query `
以 参数 接收
data:image/s3,"s3://crabby-images/d236a/d236a69ad3e2db2dd7a26af7e26b672db5784f66" alt=""
大小写都可以
data:image/s3,"s3://crabby-images/72ef4/72ef48451197a9ddf699d68850d5e0eab0f3a357" alt=""
以 实体类 接收
在接受的实体类前添加 [FromQuery]
data:image/s3,"s3://crabby-images/5035c/5035c175b2c37fd127ddb4409b72dda2360d0e2f" alt=""
以 【 Rest风格 】
以 参数 接受
注意:
若传入参数与接收参数不一致,可使用[FromRoute(Name = "xxx")]
绑定
参考: .net 请求参数与调用参数不一致 - 掘金 (juejin.cn)
data:image/s3,"s3://crabby-images/8f0e6/8f0e666f84a15e86b7adf3a9ed4e0b4e391ea274" alt=""
csharp
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
namespace Parameter.Controllers
{
[Route("api/[controller]")]
[ApiController]
public class Param : ControllerBase
{
[HttpGet("{Method}/{Value}")]
public async Task<Parameter> GetRouteAsync([FromRoute(Name = "Method")] string method, [FromRoute(Name = "Value")] string value)
{
Parameter parameter = new Parameter
{
Method = method,
Value = value
};
return await Task.FromResult(parameter);
}
}
}
以 实体类 接收
注意 :
- {xxx} 中的字母
大小
写要与实体类中属性一致
- 在实体类前添加
[FromRoute]
即可
data:image/s3,"s3://crabby-images/2851e/2851ed22ab5b75e540362ea2cd7b3dc32b57182f" alt=""
data:image/s3,"s3://crabby-images/869c1/869c1aba8c30d09f9dca2d5458c113117910f0b1" alt=""
请求体 传参
注: 若以参数接受,请求参数将会暴露在请求url上
data:image/s3,"s3://crabby-images/a1363/a13636401213a56f5a4b4403b6a41d12f8de55a0" alt=""
以 实体类 接受
data:image/s3,"s3://crabby-images/f27e7/f27e7d76fa5a3020a8b5f530ff7a374fedf73a30" alt=""
在接收的实体类前加[FromBody]
csharp
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
namespace Parameter.Controllers
{
[Route("api/[controller]")]
[ApiController]
public class Param : ControllerBase
{
[HttpPost]
public async Task<Parameter> PostAsync([FromBody] Parameter body)
{
return await Task.FromResult(body);
}
}
}