特殊参数
2024年6月13日小于 1 分钟
特殊参数
特殊参数是指不需要任何特性来修饰就能工作的一些参数类型。
CancellationToken 类型
每个接口都支持声明一个或多个 CancellationToken 类型的参数,用于取消请求操作。
public interface IUserApi
{
[HttpGet("api/users/{id}")]
Task<User> GetAsync(string id, CancellationToken token = default);
}
FileInfo 类型
做为 multipart/form-data 表单的一个文件项,实现文件上传功能。
public interface IUserApi
{
[HttpPost("api/users")]
Task<User> PostAsync([FormDataContent] User user, FileInfo headImage);
}
HttpContent 的子类型
public interface IUserApi
{
[HttpPost("api/users/{id}")]
Task PostAsync(StringContent text);
[HttpPost("api/users/{id}")]
Task PostAsync(StreamContent stream);
[HttpPost("api/users/{id}")]
Task PostAsync(ByteArrayContent bytes);
}
IApiParameter 的子类型
实现 IApiParameter 的类型,称为自解释参数类型,它可以弥补特性(Attribute)不能解决的一些复杂参数。
FormDataFile 类型
做为 multipart/form-data 表单的一个文件项,实现文件上传功能,等效于 FileInfo 类型。
public interface IUserApi
{
[HttpPost("api/users")]
Task<User> PostAsync([FormDataContent] User user, FormDataFile headImage);
}
JsonPatchDocument 类型
表示 JsonPatch 请求文档。
public interface IUserApi
{
[HttpPatch("api/users/{id}")]
Task<UserInfo> PatchAsync(string id, JsonPatchDocument<User> doc);
}
var doc = new JsonPatchDocument<User>();
doc.Replace(item => item.Account, "laojiu");
doc.Replace(item => item.Email, "laojiu@qq.com");