Я разрабатываю веб-надстройку для Outlook.
Я пытаюсь проверить токен, который я передаю на серверную сторону, через библиотеку node.js
, но она не работает, и я могуне понимаю, почему.
Это то, что я делаю для получения токена идентификации пользователя.
Office.context.mailbox.getUserIdentityTokenAsync(function(result) {
result.value // contains the token.
// send this value to server side, which I can see that it's working.
})
На стороне сервера я получаю токен и делаю следующее:
token; // contains the token passed from the web-app.
const jwt = require('jsonwebtoken');
const request = require('request');
let decoded = jwt.decode(token, {complete: true});
// Get the key, we'll need this later since we'll have to
// find the matching key from the config file.
let key = decoded.header.x5t;
let amurl = JSON.parse(decoded.payload.appctx).amurl;
// Make a request to the url to get the configuration json file.
request(amurl, {}, (err, response, body) => {
let keys = JSON.parse(body).keys;
// Filter the keys so we get the one which we can verify.
let s = keys.filter(t => t.keyinfo.x5t === key);
let cert = s[0].keyvalue.value;
// Fails the verification.
console.log(jwt.verify(token, cert));
});
Просто чтобы уточнить, я правильно извлекаю токен, и этот пакет npm, кажется, работает нормально для других токенов jwt.(Так что на самом деле это не проблема конфигурации)