どのようにasyncとawaitのこの組の設計の統一のAccess Tokenの関数を使いますか?
2009 ワード
最近はSAPクラウドのマシンを使ってAPIとSAPシステムの統合を勉強しています.SAP Cloud Platform Leonard上のマシンは学期APIで、消費するたびにAccess Tokenを伝えなければなりません.ですから、実際にAPIを呼び出す前に、Acess Tokenを取得するように要請します.この要求の応答は、実際のtokenに戻る以外に時間があります.inフィールド:
OAuth 2.0標準により定義され、expires_inフィールドは、サーバから与えられたtokenを表し、有効期限までの残りの秒数を表します.
私のコードは以下の通りです.
OAuth 2.0標準により定義され、expires_inフィールドは、サーバから与えられたtokenを表し、有効期限までの残りの秒数を表します.
私のコードは以下の通りです.
const request = require('request-promise-native');
var config = require('../config.js');
var TOKEN = undefined;
var EXPIRES_IN = undefined;
var TOKEN_FETCHED_SINCE = undefined;
function isCurrentDateExpired(){
var current = new Date();
var diffInMilliSeconds = current - TOKEN_FETCHED_SINCE;
var diffInSecond = Math.ceil(diffInMilliSeconds/1000);
var expired = diffInSecond >= EXPIRES_IN ? true:false;
// for debug;
// expired = true;
return expired;
}
async function getAccessToken(){
if( TOKEN === undefined || isCurrentDateExpired()){
var raw = new Buffer(config.username + ":" + config.password);
const accessToken = await request({
method: 'GET',
headers: {
'Authorization': 'Basic ' + raw.toString('base64')
},
url: config.ACCESS_TOKEN,
json: false
});
var oToken = JSON.parse(accessToken);
EXPIRES_IN = oToken.expires_in;
TOKEN = oToken.access_token;
TOKEN_FETCHED_SINCE = new Date();
return oToken.access_token;
}
else{
return TOKEN;
}
}
var request1 = getAccessToken();
var freshNewToken, secondTimeToken;
request1.then(function(o){
// console.log("token1: " + o);
freshNewToken = o;
});
function test2(){
var b = getAccessToken();
b.then(function(o){
// console.log("token2: " + o);
secondTimeToken = o;
console.log("they should be equal: " + (freshNewToken == secondTimeToken));
});
}
setTimeout( test2, 6000);
もっとJerryのオリジナル記事を取得するには、公衆番号の「汪子煕」に注目してください.