1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Node.js中Request模块处理HTTP协议请求的使用介绍

Node.js中Request模块处理HTTP协议请求的使用介绍

时间:2020-10-31 00:17:59

相关推荐

Node.js中Request模块处理HTTP协议请求的使用介绍

web前端|js教程

Node,Request,HTTP协议,JavaScript,js

web前端-js教程这里来介绍一个Node.js的模块——request。有了这个模块,http请求变的超简单。

php小姐威客源码,ubuntu加载头文件,tomcat报错找不到类,screeps爬虫代码,php前后端生成框架,seo 内页lzw

本本啦笔记本网址导航源码,ubuntu 中搜索文件,解压版tomcat的卸载,龟缘爬虫,php可以异步吗,初学seo的文章seo技术lzw

Request使用超简单,同时支持https和重定向。

android开发 短信源码,微软vscode有效启动项,ubuntu设置教程,tomcat是什么概念,龙华爬虫防治,php mvc 例子,网站seo找兴田德润,如何获取网站url地址lzw

var request = require( equest);request(\, function (error, response, body) { if (!error && response.statusCode == 200) { console.log(body) // 打印google首页}})

流:

任何响应都可以输出到文件流。

request(/doodle.jpg).pipe(fs.createWriteStream(doodle.jpg))

反过来,也可以将文件传给PUT或POST请求。未提供header的情况下,会检测文件后缀名,在PUT请求中设置相应的content-type。

fs.createReadStream(‘file.json’).pipe(request.put(‘/obj.json’))

请求也可以pipe给自己。这种情况下会保留原content-type和content-length。

request.get(‘/img.jpg’).pipe(request.put(‘/img.jpg’))

表单:

request支持application/x-www-form-urlencoded和multipart/form-data实现表单上传。

x-www-form-urlencoded很简单:

request.post(/upload, {form:{key:value}})

或者:

request.post(/upload).form({key:value})

使用multipart/form-data不用操心设置header之类的琐事,request会帮你解决。

var r = request.post(/upload)var form = r.form()form.append(my_field, my_value)form.append(my_buffer, new Buffer([1, 2, 3]))form.append(my_file, fs.createReadStream(path.join(__dirname, doodle.jpg))form.append( emote_file, request(/doodle.jpg))

HTTP认证:

request.get(/).auth(username, password, false);

request.get(/, { auth: { user: username, pass: password, sendImmediately: false}});

sendImmediately,默认为真,发送一个基本的认证header。设为false之后,收到401会重试(服务器的401响应必须包含WWW-Authenticate指定认证方法)。

sendImmediately为真时支持Digest认证。

OAuth登录:

// Twitter OAuthvar qs = require(querystring) , oauth = { callback: /callback/ , consumer_key: CONSUMER_KEY , consumer_secret: CONSUMER_SECRET} , url = /oauth/request_token;request.post({url:url, oauth:oauth}, function (e, r, body) { // Ideally, you would take the body in the response // and construct a URL that a user clicks on (like a sign in button). // The verifier is only available in the response after a user has // verified with twitter that they are authorizing your app. var access_token = qs.parse(body) , oauth = { consumer_key: CONSUMER_KEY , consumer_secret: CONSUMER_SECRET , token: access_token.oauth_token , verifier: access_token.oauth_verifier} , url = /oauth/access_token; request.post({url:url, oauth:oauth}, function (e, r, body) { var perm_token = qs.parse(body) , oauth = { consumer_key: CONSUMER_KEY , consumer_secret: CONSUMER_SECRET , token: perm_token.oauth_token , token_secret: perm_token.oauth_token_secret} , url = /1/users/show.json? , params = { screen_name: perm_token.screen_name , user_id: perm_token.user_id}; url += qs.stringify(params) request.get({url:url, oauth:oauth, json:true}, function (e, r, user) {console.log(user)})})})

定制HTTP header

User-Agent之类可以在options对象中设置。在下面的例子中,我们调用github API找出某仓库的收藏数和派生数。我们使用了定制的User-Agent和https.

var request = require( equest);var options = { url: /repos/mikeal/request, headers: { User-Agent: equest}};function callback(error, response, body) { if (!error && response.statusCode == 200) { var info = JSON.parse(body); console.log(info.stargazers_count +"Stars"); console.log(info.forks_count +"Forks");}}request(options, callback);

cookies:

默认情况下,cookies是禁用的。在defaults或options将jar设为true,使后续的请求都使用cookie.

var request = request.defaults({jar: true})request(\, function () {request(\)})

通过创建request.jar()的新实例,可以使用定制的cookie,而不是request全局的cookie jar。

var j = request.jar()var request = request.defaults({jar:j})request(\, function () {request(\)})

或者

var j = request.jar()var cookie = request.cookie(your_cookie_here)j.setCookie(cookie, uri, function (err, cookie){})request({url: \, jar: j}, function () {request(\)})

注意,setCookie至少需要三个参数,最后一个是回调函数。

可以用request的pipe方法很方便的获取图片的文件流

var request = require( equest), fs = require(fs); request(.hk/images/srpr/logo3w.jpg).pipe(fs.createWriteStream(doodle.jpg));

更多使用方法和说明可点击这里继续阅读:/mikeal/request/

示例

这里写了一个很简单的示例,用来抓取去哪儿网的酒店查询数据(获取酒店某一时间段内各房型的价格排名):

var request = require( equest), fs = require(fs); var reqUrl = /price/detail.jsp?fromDate=-08-18&toDate=-08-19&cityurl=shanghai_city&HotelSEQ=shanghai_city_2856&cn=5; request({uri:reqUrl}, function(err, response, body) { //console.log(response.statusCode); //console.log(response); //如果数据量比较大,就需要对返回的数据根据日期、酒店ID进行存储,如果获取数据进行对比的时候直接读文件 var filePath = __dirname + /data/data.js; if (fs.exists(filePath)) { fs.unlinkSync(filePath); console.log(Del file + filePath); } fs.writeFile(filePath, body, utf8, function(err) { if (err) { throw err; } console.log(Save + filePath + ok~); }); console.log(Fetch + reqUrl + ok~); });

这个例子源于一个做酒店业务的朋友,想知道自己在网站上提供给客户的价格的竞争力:

1、如果提供的价格过低,自己赚到的钱就会少了,所以如果自己价格是最低了,就需要看第二低是多少,然后决定是否调整;

2、如果提供的价格过高,那么被搜索出来的排名结果就比较靠后,没什么客户来预订酒店,业务就没有了

因为做的酒店预订业务很多,比如超过2千家以上,如果一个一个依赖人工去查询排名就比较被动,而且很难再做大,所以他的这个需求我分析了一下是可行的,而且可以做成一个很好的实时预警系统(当然数据5~10分钟会自动在页面刷新一次)。这样才能保障利润最大化,提高销售、客户部门的工作效率,加快酒店的合作数量和公司的人员扩张:

1、不亏本,亏本的买卖不做;

2、如果发现提供的价格过低或是过高,需要支持调用平台的api接口,直接修改价格;

3、有自动生成分析报表功能,分析竞争对手在价格调整策略上的变化情况;

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。