http请求头中的Content-Type属性在angular 和 node中的用法

post请求的请求体有以下两种格式:

1. 字符串: ‘name=code_bunny&age=12‘

这种格式的请求体,需要配置请求头 ‘Content-Type‘:‘application/x-www-form-urlencoded‘

2. json: {name:‘code_bunny‘,age:12}

这种格式的请求体,需要配置请求头 ‘Content-Type‘:‘application/json;charset=UTF-8‘

注意: 请求体格式和请求头的Content-Type类型必须保持一致,如果1的格式,设置Content-Type是application/json,或者2的格式,设置Content-Type是application/x-www-form-urlencoded,后台接收到的请求提都会是空的.

在jquery的ajax中,默认都是第一种,虽然在写请求体参数的时候,写的是json格式,但是jquery内部已经对json做了转换,最后还是以字符串的格式进行发送的.

所以,jquery的ajax,采用的是第一种方式提交请求体

但是在angular的$http中,默认是第二种,所以使用$http(config)提交请求体,config中的data项,必须是json格式的值.

如果需要提交的请求体是第一种格式,那么就需要配置$http(config)中的headers中的Content-Type值为‘application/x-www-form-urlencoded‘

再来说说node后台对这两种请求格式的处理:

1. 首先是最新express版本4.7.2:

4.7.2版本的express没有了bodyParser方法,需要另外安装body-parser模板:

于是另外安装了body-parser模板1.5.2版本

使用代码如下:

var express = require(‘express‘);
var bodyParser = require(‘body-parser‘);
var app = express();

// parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: false }));

// parse application/json
app.use(bodyParser.json());

使用bodyParser.urlencoded(),使node后台支持了第一种请求体.

使用bodyParser.json(),使node后台支持了第二种请求体.

后定义的不会覆盖先定义的... 也就是说,这段代码同时支持了这两种请求体. 另外,虽然请求体的格式不同,但是经过node解析后,他们最终得到的都是json格式的对象.

(参数的作用目前不太清楚,看不懂英文...)

demo地址: https://github.com/OOP-Code-Bunny/angular/tree/master/OREILLY/18.4%20%24http(2)

2. 旧版的express(举例3.4.7)

使用 app.use(express.bodyParser())后,直接支持了这两种格式.

demo地址: https://github.com/OOP-Code-Bunny/angular/tree/master/OREILLY/18.2%20%24http.post

http请求头中的Content-Type属性在angular 和 node中的用法

时间: 2024-10-05 08:18:33

http请求头中的Content-Type属性在angular 和 node中的用法的相关文章

深入理解jQuery、Angular、node中的Promise

最初遇到Promise是在jQuery中,在jQuery1.5版本中引入了Deferred Object,这个异步队列模块用于实现异步任务和回调函数的解耦.为ajax模块.队列模块.ready事件提供基础功能.在用jQuery操作DOM的时候对Promise的使用欲不够强烈,最近学习node和Angular,需要用js写业务逻辑和数据操作代码的时候这种场景需求就出来了.一般来说事件适合在交互场景中运用,因为用户的行为本来就是分散的,而promise这样的流程控制适合在后台逻辑中处理业务. //j

html中button的type属性

接触web开发不久,今天遇到了一个问题,点击button按钮,浏览器没有反应,尝试了自己可以想到的所有办法,还是无果.只得请教他人,才发现是button的type属性搞得怪,原来: 1)<button type="submit">为form提交,可以向服务器提交表单(form). 2)<button type="button">响应用户自定义的事件,如果不指定onclick等事件处理函数,它是不做任何事情. 我遇到的便是第二种情况,请求没有发

CSOM创建Content Type并指定GUID

SharePoint 2013 Client Object Mode在创建Content Type时有一个限制,不能给Content Type指定一个GUID,只能由系统随机生成.而在用farm solution部署时,则可以在xml中指定好Content Type的GUID,或者用服务器端对象模型来指定GUID. SharePoint 2013 SP1发布之后,这个问题就迎刃而解了.在新的CSOM对象模型中,可以在创建Content Type时指定GUID.在o365上申请一个免费的开发网站,

.NET获取文件的MIME类型(Content Type)

第一种:这种获取MIME类型(Content Type)的方法需要在.NET 4.5之后才能够支持,但是非常简单. 优点:方便快捷 缺点:只能在.NET 4.5之后使用 public FileResult down() { var file = Server.MapPath(@"\Download\fff.zip"); return File(file, MimeMapping.GetMimeMapping(file)); } 之后可以直接使用MimeMapping类的静态方法获取文件

在CG/HLSL中访问着色器属性(Properties)

在CG/HLSL中访问着色器属性 Shader在Properties块中访问材质属性.如果你想在一个着色程序中访问一些属性,你需要声明一个Cg/HLSL具有相同的名称和一个匹配的类型的变量. Properties 例如这些材质属性: _MyColor ("Some Color", Color) = (1,1,1,1) _MyVector ("Some Vector", Vector) = (0,0,0,0) _MyFloat ("My float"

(转)automaticallyAdjustsScrollViewInsets(个人认为iOS7中略坑爹的属性)

转自http://m.blog.csdn.net/blog/humingtao2013/27662093 automaticallyAdjustsScrollViewInsets(个人认为iOS7中略坑爹的属性) @当我们在一个UIViewController中同时创建2个tableView的时候,如果把它们的frame中的Y坐标设置为一样,你可能会发现它们的位置并没有达到你想要的结果.比如第一tableView个frame(0,0,320,568),另一个也frame(0,0,320,568)

http请求头出现provisional headers are shown

http请求头出现provisional headers are shown Provisional headers are shown provisional 详细用法>> 英 [pr?'v??(?)n(?)l]美 [pr?'v???nl] adj. 临时的,暂时的:暂定的 n. 临时邮票 [例句] McGuiness assured him of the Provisionals' good will. 麦吉尼斯向他保证爱尔兰共和军临时派有善意. show 详细用法>> 英 [

简单剖析Node中的事件监听机制(一)

使用js的class类简单的实现一个事件监听机制,不同于浏览器中的时间绑定与监听,类似于node中的时间监听,并且会在接下来的文章中去根据自己的理解去写一下Event模块中的原理. Node.js使用了一个事件驱动.非阻塞式I/O的模型,使其轻量又高效.并且Node中的大量模块都使用了Event机制,因此可以说是整个Node中最重要的模块之一. 实例: let event = new eventEmitter(); event.on('someType',function(){ }); even

Node中的模块系统

加载require var 自定义变量名称 = require('模块') 两个作用: 执行被加载模块的代码 得到被加载模块中的exports导出接口对象 导出exports node中是模块作用域,默认文件中所有成员只在当前文件模块有效 对于希望可以被其他模块访问的成员,我们就把这些成员都挂载到exports接口对象中就可以了. 导出单个成员(拿到的就是:函数,字符串) module.exports = 'hello' 导出多个成员(必须在对象中) module.exports={ add:f