欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解NodeJs支付寶移動支付簽名及驗簽

 更新時間:2017年01月06日 08:35:29   作者:浩浩浩浩浩浩蕩  
本文主要介紹了NodeJs支付寶移動支付簽名及驗簽的方法,具有一定的參考價值,下面跟著小編一起來看下吧

非常感謝 :http://www.jianshu.com/p/8513e995ff3a?utm_campaign=hugo&utm_medium=reader_share&utm_content=note&utm_source=weibo 的文章,如果不是找到這篇文章我可能還要繼續(xù)坑幾天,代碼也基本都是照著他的搬過來的,不過支付寶移動支付文檔寫的非常糟糕而且沒有node的SDK和demo,寫起來異常痛苦..好在找到了這篇文章順便折騰了一下午支付寶的技術人員總算把移動支付整個流程給做完了,所以就順便記錄一下自己遇到的坑,和對移動支付整個流程的梳理。

支付寶給的流程圖還是很清晰的,其實基本流程就是

  1. 用戶向服務器請求一個付款
  2. 服務器生成一個帶簽名的訂單發(fā)送給客戶端
  3. 客戶端通過這個訂單向app sdk請求付款
  4. sdk把用戶引入支付寶付款界面進行支付
  5. 支付成功后支付寶向前端返回支付成功結果,并且向服務器發(fā)送一個支付通知
  6. 服務器接收通知并且驗證是否是支付寶發(fā)送的成功結果

app客戶端需要做的很簡單:

  1. 向自己的服務器請求一個訂單,
  2. 接收到訂單后,向支付寶sdk發(fā)情一個支付請求
  3. 交易結束后返回一個成功或者失敗

服務器做的事情稍微多一點(注意:服務端需要存放應用的私鑰進行簽名,還有支付寶的公鑰進行驗簽):

1.接收到客戶端請求時候,生成一個帶簽名訂單返回給客戶端,中間的步奏有

1) 把相應的配置數(shù)據(jù)生成一個數(shù)組,再把數(shù)組的數(shù)據(jù)生成一個有序的字符串

//將支付寶發(fā)來的數(shù)據(jù)生成有序數(shù)列
function getVerifyParams(params) {
 var sPara = [];
 if(!params) return null;
 for(var key in params) {
 if((!params[key]) || key == "sign" || key == "sign_type") {
 continue;
 };
 sPara.push([key, params[key]]);
 }
 sPara = sPara.sort();
 var prestr = '';
 for(var i2 = 0; i2 < sPara.length; i2++) {
 var obj = sPara[i2];
 if(i2 == sPara.length - 1) {
 prestr = prestr + obj[0] + '=' + obj[1] + '';
 } else {
 prestr = prestr + obj[0] + '=' + obj[1] + '&';
 }
 }
 return prestr;
}

  2) 將這組支付串進行RSA-SHA1算法,得到的結果再與存在服務端的私鑰進行簽名

//驗簽
function veriySign(params) {
 try {
 var publicPem = fs.readFileSync('./rsa_public_key.pem');
 var publicKey = publicPem.toString();
 var prestr = getVerifyParams(params);
 var sign = params['sign'] ? params['sign'] : "";
 var verify = crypto.createVerify('RSA-SHA1');
 verify.update(prestr);
 return verify.verify(publicKey, sign, 'base64')

 } catch(err) {
 console.log('veriSign err', err)
 }
}

  3) 有序的字符串+得到的簽名+簽名方法就是生成的訂單,將這組訂單返回給客戶端

//發(fā)送訂單號
 sendAlipay: function(req, res) {
 var code = ""
 for(var i = 0; i < 4; i++) {
 code += Math.floor(Math.random() * 10);
 }
 //訂單號暫時由時間戳與四位隨機碼生成
 AlipayConfig.out_trade_no = Date.now().toString() + code;
 var myParam = getParams(AlipayConfig);
 var mySign = getSign(AlipayConfig)
 var last = myParam + '&sign="' + mySign + '"&sign_type="RSA"';
 console.log(last)
 return res.send(last)
 }

2.前半段的工作就做完了,接下來如果前端支付成功,支付寶會向我們預留好的回調接口發(fā)送一個POST請求,讓我們驗證用戶是否支付成功

  1) 將支付寶發(fā)送過來的數(shù)據(jù)生成一個有序的字符串

//將支付寶發(fā)來的數(shù)據(jù)生成有序數(shù)列
function getVerifyParams(params) {
 var sPara = [];
 if(!params) return null;
 for(var key in params) {
 if((!params[key]) || key == "sign" || key == "sign_type") {
 continue;
 };
 sPara.push([key, params[key]]);
 }
 sPara = sPara.sort();
 var prestr = '';
 for(var i2 = 0; i2 < sPara.length; i2++) {
 var obj = sPara[i2];
 if(i2 == sPara.length - 1) {
 prestr = prestr + obj[0] + '=' + obj[1] + '';
 } else {
 prestr = prestr + obj[0] + '=' + obj[1] + '&';
 }
 }
 return prestr;
}

  2) 將獲取的數(shù)據(jù)進行hash然后根據(jù)公鑰進行對簽名的有效應驗證,返回true和false

//驗簽
function veriySign(params) {
 try {
 var publicPem = fs.readFileSync('./rsa_public_key.pem');
 var publicKey = publicPem.toString();
 var prestr = getVerifyParams(params);
 var sign = params['sign'] ? params['sign'] : "";
 var verify = crypto.createVerify('RSA-SHA1');
 verify.update(prestr);
 return verify.verify(publicKey, sign, 'base64')

 } catch(err) {
 console.log('veriSign err', err)
 }
}

  3) 如果驗簽成功再生成支付寶通知url,來驗證是否是支付寶發(fā)來的通知(支付寶的驗證一大堆,腦殼都痛了),如果有數(shù)據(jù)則說明確實是支付寶發(fā)來的通知,這次交易有效

//回調驗簽
 getAlipay: function(req, res) {
 console.log(req.body)
 var params = req.body
 var mysign = veriySign(params);
 //驗證支付寶簽名mysign為true表示簽名正確
 console.log(mysign)
 try {
 //驗簽成功
 if(mysign) {
 if(params['notify_id']) {
 var partner = AlipayConfig.partner;
 //生成驗證支付寶通知的url
 var url = 'https://mapi.alipay.com/gateway.do?service=notify_verify&' + 'partner=' + partner + '&notify_id=' + params['notify_id'];
 console.log('url:' + url)
 //驗證是否是支付寶發(fā)來的通知
 https.get(url, function(text) {
 //有數(shù)據(jù)表示是由支付寶發(fā)來的通知
 if(text) {
 //交易成功
 console.log('success')
 } else {
 //交易失敗
 console.log('err')
 }
 })
 }
 }
 } catch(err) {
 console.log(err);
 }
 }

這樣整個流程就跑完了,代碼原博客都有,這里最多只是有些改成了sails的寫法,主要寫一下這次遇到的幾個坑和值得注意的幾個地方

1. 由于移動支付的文檔描述不清楚,私鑰其實上上傳到賬戶信息的mapi網(wǎng)管產(chǎn)品密鑰里:

而不是上傳到應用的密鑰里

2. 移動支付只支持RSA(SHA1)

3.  ./是在sails里獲取的到根目錄下的密鑰(有點搞不懂sails的這個路徑)

4. 生成訂單時候的有序字符串格式是body="測試" ,有雙引號,但是驗簽生成的有序字符串里不能有雙引號

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

相關文章

  • Node.js異步I/O學習筆記

    Node.js異步I/O學習筆記

    這篇文章主要介紹了Node.js異步I/O學習筆記,本文詳細講解了異步I/O的基本概念、Node的異步I/O、非I/O的異步API、事件驅動與高性能服務器等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • 總結Node.js中9種fs模塊文件操作方法(文件夾遞歸刪除知識)

    總結Node.js中9種fs模塊文件操作方法(文件夾遞歸刪除知識)

    這篇文章主要介紹了總結Node.js中9種fs模塊文件操作方法(文件夾遞歸刪除知識),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-07-07
  • nodemon實現(xiàn)Typescript項目熱更新的示例代碼

    nodemon實現(xiàn)Typescript項目熱更新的示例代碼

    這篇文章主要介紹了nodemon實現(xiàn)Typescript項目熱更新的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • Node.js文件寫入教程逐步深入探討

    Node.js文件寫入教程逐步深入探討

    這篇文章主要為大家介紹了Node.js文件寫入教程逐步深入探討,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Express.js 全局錯誤處理實現(xiàn)

    Express.js 全局錯誤處理實現(xiàn)

    本文主要介紹了Express.js 全局錯誤處理實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • Node.js 進程平滑離場剖析小結

    Node.js 進程平滑離場剖析小結

    這篇文章主要介紹了Node.js 進程平滑離場剖析小結,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • 總結幾道關于Node.js的面試問題

    總結幾道關于Node.js的面試問題

    這篇文章主要總結了幾道關于Node.js的面試問題,通過這些問題就來判斷一個人的Node.js水平是不太嚴謹?shù)?,但是它能讓你對面試者在Node.js上的經(jīng)驗如何有個大概的了解。有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01
  • 詳解IWinter 一個路由轉控制器的 Nodejs 庫

    詳解IWinter 一個路由轉控制器的 Nodejs 庫

    本篇文章主要介紹了詳解IWinter 一個路由轉控制器的 Nodejs 庫,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 詳談Node.js之操作文件系統(tǒng)

    詳談Node.js之操作文件系統(tǒng)

    下面小編就為大家?guī)硪黄斦凬ode.js之操作文件系統(tǒng)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • 詳解從Node.js的child_process模塊來學習父子進程之間的通信

    詳解從Node.js的child_process模塊來學習父子進程之間的通信

    這篇文章主要介紹了從Node.js的child_process模塊來學習父子進程之間的通信,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03

最新評論