在ASP.net Core 2.1中,我想返回一个Json响应以及状态代码415,而不是默认返回415。
为此,我使用资源过滤器:
public class MediaTypeResouceFilter : Attribute, IResourceFilter
{
public void OnResourceExecuting(ResourceExecutingContext context)
{
}
public void OnResourceExecuted(ResourceExecutedContext context)
{
if (context.HttpContext.Response.StatusCode == 415)
{
context.Result = new ContentResult() { StatusCode = 415, Content = JsonConvert.SerializeObject(myResponse), ContentType = "application/json" };
}
}
}
在调试中,我看到context.Result被成功覆盖但邮递员只获得415而没有Json响应。
如果我把:
context.Result = new ContentResult() { StatusCode = 415, Content = JsonConvert.SerializeObject(myResponse), ContentType = "application/json" };
在OnResourceExecuting而不是OnResourceExecuted中,它可以按照我的意愿工作,但事实是我在执行资源之前无法检查状态代码。
有关为什么会发生这种情况的任何想法?
你能试试吗?
public class MediaTypeResouceFilter : Attribute, IResourceFilter
{
public void OnResourceExecuting(ResourceExecutingContext context)
{
}
public void OnResourceExecuted(ResourceExecutedContext context)
{
if (context.HttpContext.Response.StatusCode == 415)
{
var jsonString = JsonConvert.SerializeObject(new { data = "this is custom message" });
byte[] data = Encoding.UTF8.GetBytes(jsonString);
context.HttpContext.Response.Body.WriteAsync(data, 0, data.Length);
}
}
}
然后你可以得到415状态代码和身体数据是:{"data":"this is custom message"}
实际上OnResourceExecuted
发射太晚但你可以修改你的自定义消息的正文
我认为使用中间件组件是一个很好的选择。这是中间件的Invoke方法:
public async Task Invoke(HttpContext context) {
Exception exception = null;
try {
await _next(context);
}
catch (Exception e) {
exception = e;
//try handling exception stuff...
}
//try handling 415 code stuff...
if(context.Response.StatusCode==415){
var yourJsonObj = new { Blah = "blah..." };
string result = JsonConvert.SerializeObject(yourJsonObj);
//context.Response.StatusCode = 200; //You can change the StatusCode here
context.Response.ContentType = "application/json";
await context.Response.WriteAsync(result);
}
}
请参阅Microsoft的工作流程:
IResourceFilter::OnResourceExecuted(ResourceExecutedContext context)
的方法在Result执行后运行。由于结果执行已经完成,因此您无需更改结果。