node.js請求php接口

在nodejs的開發(fā)中祠丝,有時需要后臺去調(diào)用其他服務(wù)器的接口栓撞,這個時候杠氢,就需要發(fā)送HTTP請求了

現(xiàn)在我們來模擬一下簡單地?cái)?shù)據(jù)請求
//request.php
<?php 
    echo 10;
 ?>
1.當(dāng)然也可以使用axios來發(fā)送請求

具體方式請看這個:http://www.reibang.com/p/e36956dc78b8

2.當(dāng)時我們使用request來發(fā)送這個請求
a). 現(xiàn)在我們通過express來搭建一個項(xiàng)目

(具體流程自行百度吧氯哮,教程很多掂碱。者甲。)

b). 安裝request模塊
cnpm install request --save-dev
c). 然后在routes下的index.js文件下寫我們的請求
var express = require('express');
var router = express.Router();

//引入request模塊
var request = require("request");

/* GET home page. */
router.get('/', function(req, res, next) {
    //向我們剛才創(chuàng)建的request.php文件發(fā)起請求
    request('http://localhost/node-request/php/request.php', function (error, response, body) {
    
      if (!error && response.statusCode == 200) {
        console.log(body) // 打印獲取到的數(shù)據(jù)撞蚕,這里輸出10
      }
    }) 

//渲染主頁
  res.render('index', { title: 'Express'});
});

module.exports = router;
d). POST application/json
//requestJson.php
<?php 
    $obj = '{"age":20}';
    echo json_encode($obj);
 ?>
e). GET請求

這時候index.js文件下是這樣的

var express = require('express');
var router = express.Router();
var request = require("request");
/* GET home page. */

router.get('/', function(req, res, next) {
    
    request({
        url: "http://localhost/node-request/php/requestJson.php",
        method: "GET",
        json: true,
        headers: {
            "content-type": "application/json",
        }
    }, function(error, response, body) {
        if (!error && response.statusCode == 200) {
            body = JSON.parse(body);
            console.log(body.age);//這里輸出的是20
        }
    }); 

  res.render('index', { title: 'Express'});
});

module.exports = router;
對于請求中傳遞參數(shù),如果是get方法的話过牙,直接將參數(shù)拼接到url后面就好了

f). 對于post請求
request.post('http://service.com/upload', {form:{key:'value'}})
// or
request.post('http://service.com/upload').form({key:'value'})
// or
request.post({url:'http://service.com/upload', form: {key:'value'}}, function(err,httpResponse,body){ /* ... */ })

對于多部分/表單數(shù)據(jù)甥厦,我們使用@ FelixGE格式數(shù)據(jù)庫。對于大多數(shù)情況下寇钉,您可以通過FromDATA選項(xiàng)傳遞您的上傳表單數(shù)據(jù)刀疙。
var formData = {
  // Pass a simple key-value pair
  my_field: 'my_value',
  // Pass data via Buffers
  my_buffer: Buffer.from([1, 2, 3]),
  // Pass data via Streams
  my_file: fs.createReadStream(__dirname + '/unicycle.jpg'),
  // Pass multiple values /w an Array
  attachments: [
    fs.createReadStream(__dirname + '/attachment1.jpg'),
    fs.createReadStream(__dirname + '/attachment2.jpg')
  ],
  // Pass optional meta-data with an 'options' object with style: {value: DATA, options: OPTIONS}
  // Use case: for some types of streams, you'll need to provide "file"-related information manually.
  // See the `form-data` README for more information about options: https://github.com/form-data/form-data
  custom_file: {
    value:  fs.createReadStream('/dev/urandom'),
    options: {
      filename: 'topsecret.jpg',
      contentType: 'image/jpeg'
    }
  }
};
request.post({url:'http://service.com/upload', formData: formData}, function optionalCallback(err, httpResponse, body) {
  if (err) {
    return console.error('upload failed:', err);
  }
  console.log('Upload successful!  Server responded with:', body);
});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市扫倡,隨后出現(xiàn)的幾起案子谦秧,更是在濱河造成了極大的恐慌,老刑警劉巖撵溃,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件疚鲤,死亡現(xiàn)場離奇詭異,居然都是意外死亡缘挑,警方通過查閱死者的電腦和手機(jī)集歇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來语淘,“玉大人诲宇,你說我怎么就攤上這事』谭” “怎么了姑蓝?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長吕粗。 經(jīng)常有香客問我纺荧,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任宙暇,我火速辦了婚禮输枯,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘客给。我一直安慰自己用押,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布靶剑。 她就那樣靜靜地躺著蜻拨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪桩引。 梳的紋絲不亂的頭發(fā)上缎讼,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天,我揣著相機(jī)與錄音坑匠,去河邊找鬼血崭。 笑死,一個胖子當(dāng)著我的面吹牛厘灼,可吹牛的內(nèi)容都是我干的夹纫。 我是一名探鬼主播,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼设凹,長吁一口氣:“原來是場噩夢啊……” “哼舰讹!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起闪朱,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤月匣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后奋姿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體锄开,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年称诗,在試婚紗的時候發(fā)現(xiàn)自己被綠了萍悴。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡粪狼,死狀恐怖退腥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情再榄,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布享潜,位于F島的核電站困鸥,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜疾就,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一澜术、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧猬腰,春花似錦鸟废、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至鼠冕,卻和暖如春添寺,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背懈费。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工计露, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人憎乙。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓票罐,卻偏偏與公主長得像,于是被迫代替她去往敵國和親泞边。 傳聞我的和親對象是個殘疾皇子该押,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)繁堡,斷路器沈善,智...
    卡卡羅2017閱讀 134,601評論 18 139
  • Express是Node社區(qū)里的超級明星闻牡,他的作者TJ Holowaychuk也因此成為了社區(qū)里大紅大紫的開發(fā)者。...
    2MuchT閱讀 2,988評論 1 30
  • 搭建開發(fā)環(huán)境并模擬交互數(shù)據(jù) 一绳矩、實(shí)驗(yàn)說明 下述介紹為實(shí)驗(yàn)樓默認(rèn)環(huán)境罩润,如果您使用的是定制環(huán)境,請修改成您自己的環(huán)境介...
    玄月府的小妖在debug閱讀 2,114評論 0 15
  • ◎一條路 這是一條穿越崇山峻嶺的路翼馆。 往子午嶺槐林深處走去割以,是一條結(jié)滿堅(jiān)冰的路,在清晨微明中北突应媚。 這是一條貫穿黃...
    北原的深藍(lán)閱讀 569評論 0 0
  • 文言版 光緒年間严沥,有書生嗜書。 凡書皆好中姜,儒消玄、道跟伏、法、名翩瓜、墨受扳,亦或縱橫、雜兔跌、農(nóng)勘高、小說、兵坟桅、天文歷數(shù)华望、五行、醫(yī)方[1...
    李錦囊閱讀 262評論 0 1