nodejs的http.request使用post方式提交数据请求
官方api文档 http://nodejs.org/docs/v0.6.1/api/http.html#http.request虽然也有POST例子,但是并不完整。
直接上代码:http_post.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
var http=require( 'http' ); var qs=require( 'querystring' ); var post_data={a:123,time: new Date().getTime()}; //这是需要提交的数据 var content=qs.stringify(post_data); var options = { host: '127.0.0.1' , port: 80, path: '/post.php' , method: 'POST' , headers:{ 'Content-Type' : 'application/x-www-form-urlencoded' , 'Content-Length' :content.length } }; console.log( "post options:\n" ,options); console.log( "content:" ,content); console.log( "\n" ); var req = http.request(options, function (res) { console.log( "statusCode: " , res.statusCode); console.log( "headers: " , res.headers); var _data= '' ; res.on( 'data' , function (chunk){ _data += chunk; }); res.on( 'end' , function (){ console.log( "\n--->>\nresult:" ,_data) }); }); req.write(content); req.end(); |
接受端地址为:http://127.0.0.1/post.php
1
2
|
<?php echo json_encode( $_POST ); |
要正确的使用nodejs模拟浏览器(nodejs httpClient)提交数据,关键是下面两点:
- 使用 querystring.stringify 对数据进行序列化
- request的 options中添加相应headers信息:Content-Type和Content-Length
https的request和http的request是一样的,所以只需要将require('http')修改为require('https') 既可以进行https post提交了。
这个是我写的一个进行POST的函数,支持http和https:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
function post(url,data,fn){ data=data||{}; var content=require( 'querystring' ).stringify(data); var parse_u=require( 'url' ).parse(url, true ); var isHttp=parse_u.protocol== 'http:' ; var options={ host:parse_u.hostname, port:parse_u.port||(isHttp?80:443), path:parse_u.path, method: 'POST' , headers:{ 'Content-Type' : 'application/x-www-form-urlencoded' , 'Content-Length' :content.length } }; var req = require(isHttp? 'http' : 'https' ).request(options, function (res){ var _data= '' ; res.on( 'data' , function (chunk){ _data += chunk; }); res.on( 'end' , function (){ fn!=undefined && fn(_data); }); }); req.write(content); req.end(); } |
如下使用
1.http方式:
1
2
3
|
post( 'http://127.0.0.1/post.php?b=2' ,{a:1}, function (data){ console.log(data); }); |
2.https方式:
1
2
3
|
post( 'https://127.0.0.1/post.php' ,{a:1}, function (data){ console.log(data); }); |
nodejs的http.request使用post方式提交数据请求的更多相关文章
- Android 使用Post方式提交数据(登录)
在Android中,提供了标准Java接口HttpURLConnection和Apache接口HttpClient,为客户端HTTP编程提供了丰富的支持. 在HTTP通信中使用最多的就是GET和POS ...
- request接收表单提交数据及其中文参数乱码问题
一.request接收表单提交数据: getParameter(String)方法(常用) getParameterValues(String name)方法(常用) getParameterMap( ...
- Android 采用post方式提交数据到服务器
接着上篇<Android 采用get方式提交数据到服务器>,本文来实现采用post方式提交数据到服务器 首先对比一下get方式和post方式: 修改布局: <LinearLayout ...
- Android(java)学习笔记213:开源框架post和get方式提交数据(qq登录案例)
1.前面提到Http的get/post方式 . HttpClient方式,实际工作的时候不常用到,因为这些方式编写代码是很麻烦的 2.Android应用会经常使用http协议进行传输,网上会有很完善 ...
- Android 使用Post方式提交数据
在Android中,提供了标准Java接口HttpURLConnection和Apache接口HttpClient,为客户端HTTP编程提供了丰富的支持. 在HTTP通信中使用最多的就是GET和POS ...
- 苹果微信浏览器不能post方式提交数据问题
form表单中采用post方式提交数据时,在苹果的微信浏览器中无法传递,安卓的可以 如图: 在controller中获取该数据为 null 将表单的提交方式修改为get就能够获取到 现在采用Ajax方 ...
- Android(java)学习笔记156:开源框架post和get方式提交数据(qq登录案例)
1. 前面提到Http的get/post方式 . HttpClient方式,实际工作的时候不常用到,因为这些方式编写代码是很麻烦的 2. Android应用会经常使用http协议进行传输,网上会有很 ...
- postman 中post方式提交数据
post方式提交数据时,把参数填写在body中而不是pOST下面的哪一行
- Android 采用get方式提交数据到服务器
首先搭建模拟web 服务器,新建动态web项目,servlet代码如下: package com.wuyudong.web; import java.io.IOException; import ja ...
随机推荐
- C语言 百炼成钢25
/* 题目61:编写一个名为removestring的函数,该函数用于从一个字符串中删除一定量的字符. 该函数接受三个参数: 第1参数代表源字符串 第2参数代表需要删除字符的起始位置(位置从0开始) ...
- 补图BFS(hdu 5876)
题目大意: 给出一个图和起点S,求补图中S到其他点的最短距离. http://acm.hdu.edu.cn/showproblem.php?pid=5876 我自己的垃圾做法: 用线段树来维护dijk ...
- java collection 类图
转载:http://visionsky.blog.51cto.com/733317/371809/
- webpack文档翻译
https://segmentfault.com/a/1190000007568507
- Android中自动跳转到系统设置界面
// 转到手机设置界面,用户设置GPS Intent intent = new Intent( Settings.ACTION_LOCATION_SOURCE_SETTINGS); startActi ...
- 网络通信框架Volley使用详细说明
前一篇粗略的介绍了一下Volley,并在最后附上了一段使用代码,这一篇详细的介绍一下Volley的使用.前面也说了Volley主要获取JSON对象和图片加载,这里也分为两部分介绍. 1.获取JSON对 ...
- css3动画效果:3 3D动画
立方体旋转动画效果 css #container{ width: 400px; height: 400px; ; ; -webkit-perspective-origin:50% 225px; per ...
- textarea输入字符有限制
function limitedNumberOfInputCharacters(limitedNumber, string){ var strLength = 0; if(string !== nul ...
- iOS与导航相关的都在这
// 设置导航背景图片 (一旦设置背景图片(变为不透明),透明层不起作用) [self.navigationBar setBackgroundImage:[UIImage imageNamed:@&q ...
- 七、H5 直播视频播放
HTML5实现视频直播功能思路详解_html5教程技巧_脚本之家 https://m.jb51.net/html5/587215.html 七.H5 直播视频播放 移动端iOS和 Android 都天 ...