MiniAPI中,Response的返回数据有三种格式,IResult,string,json:
ValueTask<string> - 这包括 string 和 Task<string>
T(任何其他类型,返回前端时转成json)- 这包括 Task<T> 和 ValueTask<T>
基于 IResult - 这包括 Task<IResult> 和 ValueTask<IResult>
1、字符串
返回字符串很简单,就是把结果转成字符串返回即可,如下:
app.MapGet("/hi", () => "Hellow Mini API");
返回结果
Content-Type类型
2、Json
json也不难,只要返回对象就可以
app.MapGet("/answers/{questionid}", (int questionId, ExamContext exam) => exam.Answers.Where(s => s.QuestionId == questionId));
结果
Content-Type
3、IResult
相对string,json,Result是就丰富的多,官方提供的如下:
这样就能适配很多场景了,比如认证的登录登出,文件下载,重定向(Redirect,LocalRedirect,RedirectToRoute),以及各种返回值状态,当然也包括返回Text,Json。
除了内置的,还可对结果进行扩展,看一个返回yaml类型的例子。
扩展类(这里引入了一个三方的对象序列化ymal字符串的库YamlDotNet)
static class ResultsExtensions { public static IResult Yaml(this IResultExtensions resultExtensions, object yamlObject) { ArgumentNullException.ThrowIfNull(resultExtensions, nameof(resultExtensions)); var serialzer = new YamlDotNet.Serialization.SerializerBuilder().Build(); return new YamlResult(serialzer.Serialize(yamlObject)); } } class YamlResult : IResult { private readonly string _yaml; public YamlResult(string yaml) { _yaml = yaml; } public Task ExecuteAsync(HttpContext httpContext) { httpContext.Response.ContentType = "yaml"; httpContext.Response.ContentLength = Encoding.UTF8.GetByteCount(_yaml); return httpContext.Response.WriteAsync(_yaml); } }
使用扩展类
app.MapGet("/yaml/questions/{id}", (int id, ExamContext exam) => Results.Extensions.Yaml(exam.Questions.Where(s => s.Id == id).Include("Answers").Select(s => new { s.Id, Question = s.Question1, s.Score, QuestionType = s.QuestionType.TypeName, SubjectType = s.SujectType.TypeName, Answers = s.Answers.Select(t => new { t.Id, Answer = t.Answer1 }) })) );
结果
content-type
想要更快更方便的了解相关知识,可以关注微信公众号