ここでは、Node.js モジュールであるリクエストを紹介します。このモジュールを使用すると、http リクエストが非常にシンプルになります。
リクエストは非常に使いやすく、https とリダイレクトをサポートしています。
var request = require('request'); request('http://www.google.com', function (error, response, body) { if (!error && response.statusCode == 200) { console.log(body) // 打印google首页 } })
ストリーム:
あらゆる応答をファイル ストリームに出力できます。
request('http://google.com/doodle.png').pipe(fs.createWriteStream('doodle.png'))
逆に、ファイルを PUT または POST リクエストに渡すこともできます。ヘッダーが指定されていない場合は、ファイル拡張子が検出され、対応するコンテンツ タイプが PUT リクエストに設定されます。
fs.createReadStream('file.json').pipe(request.put('http://mysite.com/obj.json'))
リクエストは自分自身にパイプすることもできます。この場合、元の content-type と content-length は保持されます。
request.get('http://google.com/img.png').pipe(request.put('http://mysite.com/img.png'))
フォーム:
リクエストは、フォームのアップロードを実装するために application/x-www-form-urlencoded および multipart/form-data をサポートしています。
x-www-form-urlencoded は簡単です:
request.post('http://service.com/upload', {form:{key:'value'}})
または:
request.post('http://service.com/upload').form({key:'value'})
multipart/form-data を使用すると、ヘッダーの設定などの些細なことを心配する必要がなくなります。これは問題を解決するのに役立ちます。
var r = request.post('http://service.com/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.png')) form.append('remote_file', request('http://google.com/doodle.png'))
HTTP 認証:
request.get('http://some.server.com/').auth('username', 'password', false);
または
request.get('http://some.server.com/', { 'auth': { 'user': 'username', 'pass': 'password', 'sendImmediately': false } });
sendImmediately、デフォルトは true、基本認証ヘッダーを送信します。 false に設定すると、401 を受信したときに再試行されます (サーバーの 401 応答には、指定された認証方法 WWW-Authenticate が含まれている必要があります)。
sendImmediately が true の場合、ダイジェスト認証がサポートされます。
OAuth ログイン:
// Twitter OAuth var qs = require('querystring') , oauth = { callback: 'http://mysite.com/callback/' , consumer_key: CONSUMER_KEY , consumer_secret: CONSUMER_SECRET } , url = 'https://api.twitter.com/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 = 'https://api.twitter.com/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 = 'https://api.twitter.com/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 ヘッダー
optionsオブジェクトにはUser-Agentなどを設定できます。次の例では、github API を呼び出して、特定のウェアハウスのコレクション番号と派生番号を調べます。カスタマイズされたユーザー エージェントと https を使用しました。
var request = require('request'); var options = { url: 'https://api.github.com/repos/mikeal/request', headers: { 'User-Agent': 'request' } }; 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);
クッキー:
デフォルトでは、Cookie は無効になっています。後続のリクエストで Cookie が使用されるように、デフォルトまたはオプションで jar を true に設定します。
var request = request.defaults({jar: true}) request('http://www.google.com', function () { request('http://images.google.com') })
request.jar() の新しいインスタンスを作成すると、リクエストのグローバル Cookie jar の代わりにカスタム Cookie を使用できます。
var j = request.jar() var request = request.defaults({jar:j}) request('http://www.google.com', function () { request('http://images.google.com') })
または
var j = request.jar() var cookie = request.cookie('your_cookie_here') j.setCookie(cookie, uri, function (err, cookie){}) request({url: 'http://www.google.com', jar: j}, function () { request('http://images.google.com') })
setCookie には少なくとも 3 つのパラメータが必要であることに注意してください。最後のパラメータはコールバック関数です。
リクエストパイプメソッドを使用すると、画像のファイルストリームを簡単に取得できます
var request = require('request'), fs = require('fs'); request('https://www.google.com.hk/images/srpr/logo3w.png').pipe(fs.createWriteStream('doodle.png'));
使用方法と手順の詳細については、ここをクリックして読み続けてください: https://github.com/mikeal/request/
例
Qunar.com からホテルのクエリ データを取得する非常に簡単な例を次に示します (一定期間内のホテルの各部屋タイプの価格ランキングを取得します)。
var request = require('request'), fs = require('fs'); var reqUrl = 'http://hotel.qunar.com/price/detail.jsp?fromDate=2012-08-18&toDate=2012-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~'); });
この例は、ホテル業界に携わる友人からのもので、Web サイトで顧客に提供する価格の競争力を知りたいと考えています。
1. 提供された価格が低すぎると収益が少なくなります。そのため、価格が最も低い場合は、2 番目に低い価格を確認して、調整するかどうかを決定する必要があります。
2. 提供された価格が高すぎると、ランキング結果が低くなり、ホテルを予約する顧客がいなくなり、ビジネスが消滅します。
弊社では2,000軒以上のホテル予約業務を多数行っておりますので、手作業によるランキングの一つ一つチェックに頼ると受動的になり、さらなる拡大が難しくなりますので、彼のニーズを分析したところ、それは実現可能であり、優れたリアルタイム警告システムを作成することができます (もちろん、データは 5 ~ 10 分ごとにページ上で自動的に更新されます)。この方法によってのみ、利益を最大化し、営業部門と顧客部門の作業効率を向上させ、ホテルの協力数と会社の人員拡大を加速することができます。
1. 損失を出さない場合は、損失の出る取引をしないでください。
2. 提供された価格が低すぎる、または高すぎる場合は、プラットフォームの API インターフェイスを呼び出して価格を直接変更できるようにする必要があります。
3. 競合他社の価格調整戦略の変化を分析する分析レポートを自動生成する機能があります。