REST服务返回自定义的HttpResponseMessage
WebApi框架中对资源的操作,都是通过其Controller提供的各种方法(GET,POST,PUT,DELET等)来实现,而这些方法的返回信息有以下几种形式:
| 方法返回类型 | HttpResponseMessage |
| void | StateCode:204(No Content) |
| HttpResponseMessage | 直接返回HttpResponseMessage |
| IHttpActionResult | 调用ExecuteAsync方法去创建一个HttpResponseMessage 对象,让后将这个对象转换成Http响应消息 |
| 其他类型(如int,string等) | 将序列化的值写到响应消息的内容中,返回StateCode:200(OK) |
1:返回void的情况不多做介绍,返回给浏览器的responseMessage如下:
HTTP/ No Content Server: Microsoft-IIS/8.0 Date: Mon, Jan :: GMT
2:返回HttpResponseMessage
我们自定义的HttpResponseMessage主要可以通过这种返回类型来实现,例如,自定义response的Header:
public HttpResponseMessage Get()
{
HttpResponseMessage response = Request.CreateResponse(HttpStatusCode.OK, "value");
response.Content = new StringContent("hello", Encoding.Unicode);
response.Headers.CacheControl = new CacheControlHeaderValue()
{
MaxAge = TimeSpan.FromMinutes()
};
return response;
}
又例如,对方法的不同执行结果返回不同的HttpResponseMessage:
[HttpGet]
public HttpResponseMessage GetTopic(int id)
{
TopicModel topic;
using (var connection = new OracleConnection(Setting.ConnectionStr))
{
var sql = string.Format("select * from {0} where topicid=:TopicId", Setting.TopicModelTable);
var condition = new
{
TopicId = id
};
connection.Open();
topic = connection.QueryList<TopicModel>(sql,condition, null,null).FirstOrDefault();
connection.Close();
}
HttpResponseMessage resp;
if (topic == null)
{
resp = new HttpResponseMessage(HttpStatusCode.NoContent)
{
ReasonPhrase = "no resource found"
};
}
else
{
resp = Request.CreateResponse(HttpStatusCode.OK, topic);
}
return resp;
}
在上例中,自定义HttpResponseMessage有两种方法,一种是通过构造函数,new HttpResponseMessage,同时用JSON序列化后的实体对象创建HttpResponseMessage中的Content(通过new StringContent):
new HttpResponseMessage(HttpStatusCode.OK)
{
Content = new StringContent(JsonConvert.SerializeObject(topic))
};
另外一种是直接通过实体,自己JSON序列化后形成HttpResponseMessage:
Request.CreateResponse(HttpStatusCode.OK, topic); //topic为实体对象
这两种创建响应信息的方式,返回给浏览器的响应略有不同,前者返回给浏览器Header如下:
HTTP/ OK Content-Length: Content-Type: text/plain; charset=utf- Server: Microsoft-HTTPAPI/2.0 Date: Tue, Jul :: GMT
后者返回给浏览器Header如下:
HTTP/ OK Content-Length: Content-Type: text/json; charset=utf- Server: Microsoft-HTTPAPI/2.0 Date: Tue, Jul :: GMT
区别就在于Content-Type,因此,在某些对Content-Type有特殊要求的场合需要区分。
3:没怎么用过,对HttpResponseMessage提供一定的封装。
4:直接返回自定义对象,则默认序列化为JSON对象,加上StateCode:200(OK),形成新的HttpResponseMessage返回给浏览器:
HTTP/ OK Content-Length: Content-Type: text/xml; charset=utf- Server: Microsoft-HTTPAPI/2.0 Date: Tue, Jul :: GMT
其实HttpResponseMessage对象中的Header中的Content-Type是可以通过设置HttpRequestMessage的Header中的Accept来指定的,即内容协商机制,如下的HttpRequestMessage:
GET http://192.168.22.6:7777/api/topic/3 HTTP/1.1 User-Agent: Fiddler Accept: text/xml Content-Type: text/json Host: Content-Length:
即协商指定接收Content-Type为text/xml,以下是服务返回的HttpResponseMessage的Header:
HTTP/ OK Content-Length: Content-Type: text/xml; charset=utf- Server: Microsoft-HTTPAPI/2.0 Date: Tue, Jul :: GMT
由此可见,虽然服务返回的Content-Type是JSON,但最终返回给浏览器的Content-Type被协商为了XML格式。
REST服务返回自定义的HttpResponseMessage的更多相关文章
- angular(3)服务 --注入---自定义模块--单页面应用
ng内部,一旦发生值改变操作,如$scope.m=x,就会自动轮询$digest队列,触发指定的$watch,调用其回调函数,然后修改dom树. 干货:https://github.com/xufei ...
- Nginx挂载维护页或返回自定义响应信息
在服务停机升级或者服务暂不可用时,往往希望能够返回给用户更为明确和友好的响应信息.可以通过修改nginx配置文件,达到返回自定义信息的效果.有如下几种配置方式: (1)Nginx接收到的所有请求,都返 ...
- AngularJS内建服务以及自定义服务的用法
在AngularJS中, 服务是一个比较重要的部分,它是一个对象或者是函数,可以在你的AngularJS的应用中使用.接下来介绍几种比较常用的内建服务以及自定义服务的方法. [内建服务] (1)loc ...
- springboot 404返回自定义json(只进入过滤器)
今天在公司没事干,记一次springboot遇到的一些坑,在百度上也没有搜到类似的问题和答案(或者说 答案不是我想要的) 当我们在SpringBoot遇到了404或者500的错误的时候,你们会怎么办? ...
- AJAX回调函数,返回JSON格式,应该返回自定义状态STATUS,但是却返回200
返回200应该是方法已经执行通的意思,但是没返回自定义的status,仔细一看json格式拼错了...
- 配合crond服务实现自定义周期备份MySQL数据库(使用innobackupex进行备份)
备份 新建一个脚本/root/backup.py,内容如下: #!/usr/bin/env python# -*- coding: utf-8 -*- ''' 脚本作者:昨夜星辰 脚本作用:配合cro ...
- 客户端获取服务端自定义类数据 z
客户端获取服务端自定义类数据 问题一:超时问题,在最后获取数据的时候突然提示服务超时,服务已断开 解决:配置文件添加: <bindings> <wsHttpBinding> & ...
- 阿里云容器服务--配置自定义路由服务应对DDOS攻击
阿里云容器服务--配置自定义路由服务应对DDOS攻击 摘要: 容器服务中,除了slb之外,自定义路由服务(基于HAProxy)也可以作为DDOS攻击的一道防线,本文阐述了几种方法来应对普通规模的DDO ...
- Linq to Sql:N层应用中的查询(上) : 返回自定义实体
原文:Linq to Sql:N层应用中的查询(上) : 返回自定义实体 如果允许在UI层直接访问Linq to Sql的DataContext,可以省去很多问题,譬如在处理多表join的时候,我们使 ...
随机推荐
- UI坐标变换/转换
InverseTransformPoint Transform.InverseTransformPoint :相对于谁的坐标.如果是相对2D UI,请使用localposition,如果是3D场景,请 ...
- [No00004A]为什么你看了很多书,却依然没有洞见
摘要: 前几天有人在知乎上问:今天就回答下很多人问了很久的这个问题,并且解释一下如何构建系统化的知识体系.我想很多人看到这个问题,期待的答案是一个书单,可是我要告诉你这并没有什么卵用.我想大部分人都经 ...
- ASP.NET常用页面指令
1.<%@Page "属性"="值"%>指令 AutoEventWireup:指定页的事件是否自动绑定,默认值true为启用自动绑定. CodeBe ...
- http协议(十)实体首部字段
1.定义 包含在请求和响应中的实体部分所使用的首部,用于补充内容的更新时间等与实体相关的信息 2.Allow 通知客户端能够支持的Request-URI指定资源的所有http方法 如果服务器接收到不支 ...
- ONS C++ Windows SDK 调试方法及注意事项
此文将展示ONS C++ Windows SDK 整个调试过程,笔者直接使用sdk包中的example消息发送示例代码,开发环境为win7, 64位,Visual Studio Professiona ...
- Ant 命令行编译Android项目
首先把android sdk下的tools目录加到系统path环境变量里, 要么就得直接指定android.bat的绝对路径 对于一个新项目, 可以用这个命令创建需要的ant编译环境(可以看到andr ...
- vs2013怎么打开vs2010的解决方案
1.直接用vs2013打开解决方案的sln文件,vs会自动进行转换的2.或者你用记事本的方式打开sln文件 将版本号改一下Microsoft Visual Studio Solution File, ...
- 解决jquery.validate.js的验证bug
版本提示:jq为1.4.4, jquery.validate 为jQuery validation plug-in 1.7 问题: a.选填选项,如邮箱设置格式验证,那么情况输入框,验证label变成 ...
- C#开源系统大汇总
一.AOP框架 Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖配置文件的方式.这种部署方面(as ...
- Codevs 1910递归函数
1910 递归函数 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 对于一个递归函数w(a, b, c). 如果a <= ...