Nodejs同步訪問RestAPI的Utils封裝

前言


該Utils實現(xiàn)了以下封裝

  • 根據(jù)API式樣對request數(shù)據(jù)按進行封裝
  • 根據(jù)API式樣對response數(shù)據(jù)進行解析
  • 使用co風格同步發(fā)送API請求

導入第三方Package


var request = require('request');

關于request沪伙,參考其github

Request封裝處理和Response解析處理


  • 封裝處理用于對請求data添加共通部分(commonRequest)
  • 解析處理用于從響應信息中獲取data

假設API式樣的共通部分如下
Request示例

{
  commonRequest: {
  },
  data: …
}

Response示例

{
  commonResponse: {
    code: I01001,
    message: success
  },
  data: …
}

** 處理用代碼如下 **

var setReqData = function(json) {
  var reqData = {
    commonRequest: {},
    data: json
  };
  return reqData;
};

var getResData = function(json) {
  var code = json.commonResponse.code;
  if (code !== 'I00001') {
    throw new Error(json.commonResponse.message);
  }
  return json.data;
};

使用co風格同步發(fā)送API請求


由于request本身不提供co風格的調用接口毛秘。
而且如果使用co-request,需要使用node --harmony simple.js的方法啟動nodejs,
為了避免不必要的麻煩介蛉,自己對request進行簡單封裝

var send = function*(api, data) {
  var options = {
    headers: {
      charset: 'UTF-8'
    },
    url: 'https://127.0.0.1:8080/' + api,
    method: 'POST',
    body: setReqData(data),
    json: true
  };
  var rep = yield new Promise(function(resolve, reject) {
    return request(options, function(err, response, body) {
      if (err) {
        reject(err);
      } else {
        resolve(response);
      }
    });
  });
  return getResData(rep);
};

調用示例


var restUtils = require('./rest_utils');
var co = require('co');

co(function*() {
  var retvalue = yield restUtils.send('test/list', {id:1000});
  console.log(retvalue);
});

完整代碼


'use strict';

var request = require('request');
var config = require('../config');

var setReqData = function(json) {
  var reqData = {
    commonRequest: {},
    data: json
  };

  return reqData;
};

var getResData = function(json) {
  var code = json.commonResponse.code;
  if (code !== 'I00001') {
    throw new Error(json.commonResponse.message);
  }
  return json.data;
};

var send = function*(api, data) {
  var options = {
    headers: {
      charset: 'UTF-8'
    },
    url: config.rest.PROTOCOL + '://' + config.rest.HOST + ':' +
      config.rest.PORT + '/' + api,
    method: 'POST',
    body: setReqData(data),
    json: true
  };

  var rep = yield new Promise(function(resolve, reject) {
    return request(options, function(err, response, body) {
      if (err) {
        reject(err);
      } else {
        resolve(response);
      }
    });
  });

  return getResData(rep);
};

module.exports = {
  send: send
};
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末本缠,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子缭黔,更是在濱河造成了極大的恐慌食茎,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件馏谨,死亡現(xiàn)場離奇詭異别渔,居然都是意外死亡,警方通過查閱死者的電腦和手機惧互,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門哎媚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人喊儡,你說我怎么就攤上這事拨与。” “怎么了艾猜?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵买喧,是天一觀的道長。 經常有香客問我匆赃,道長淤毛,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任算柳,我火速辦了婚禮低淡,結果婚禮上,老公的妹妹穿的比我還像新娘埠居。我一直安慰自己查牌,他們只是感情好,可當我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布滥壕。 她就那樣靜靜地躺著纸颜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪绎橘。 梳的紋絲不亂的頭發(fā)上胁孙,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天唠倦,我揣著相機與錄音,去河邊找鬼涮较。 笑死稠鼻,一個胖子當著我的面吹牛,可吹牛的內容都是我干的狂票。 我是一名探鬼主播候齿,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼闺属!你這毒婦竟也來了慌盯?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤掂器,失蹤者是張志新(化名)和其女友劉穎亚皂,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體国瓮,經...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡灭必,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了乃摹。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片禁漓。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖孵睬,靈堂內的尸體忽然破棺而出璃饱,到底是詐尸還是另有隱情,我是刑警寧澤肪康,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站撩穿,受9級特大地震影響磷支,放射性物質發(fā)生泄漏。R本人自食惡果不足惜食寡,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一雾狈、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧抵皱,春花似錦善榛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至伤为,卻和暖如春咒循,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工叙甸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留颖医,地道東北人。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓裆蒸,卻偏偏與公主長得像熔萧,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子僚祷,可洞房花燭夜當晚...
    茶點故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理佛致,服務發(fā)現(xiàn),斷路器久妆,智...
    卡卡羅2017閱讀 134,651評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,077評論 25 707
  • 國家電網公司企業(yè)標準(Q/GDW)- 面向對象的用電信息數(shù)據(jù)交換協(xié)議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 10,958評論 6 13
  • scrapy學習筆記(有示例版) 我的博客 scrapy學習筆記1.使用scrapy1.1創(chuàng)建工程1.2創(chuàng)建爬蟲模...
    陳思煜閱讀 12,696評論 4 46
  • 因片中段劇情的緊湊 讓人看的時候有種緊張感 愛的力量很強大 常說我愛你并不代表愛 可女人總喜歡甜言蜜語 男女之間...
    mimihoka閱讀 269評論 0 0