- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我按照本文创建了一个 Web API:https://learn.microsoft.com/en-us/azure/active-directory/develop/quickstart-v1-nodejs-webapi
const restify = require('restify'),
restifyPlugins = require('restify-plugins'),
config = require('./config'),
serverPort = process.env.PORT || config.serverPort,
passport = require('passport'),
BearerStrategy = require('passport-azure-ad').BearerStrategy,
authenticatedUserTokens = [];
const server = restify.createServer({ name: 'Azure Active Directroy with Node.js Demo' });
const authenticationStrategy = new BearerStrategy(config.credentials, (token, done) => {
let currentUser = null;
let userToken = authenticatedUserTokens.find((user) => {
currentUser = user;
user.sub === token.sub;
});
if (!userToken) {
authenticatedUserTokens.push(token);
}
return done(null, currentUser, token);
});
passport.use(authenticationStrategy);
server.use(restifyPlugins.authorizationParser());
server.use(passport.initialize());
server.use(passport.session());
server.get('/api', (req, res, next) => {
res.send(200, 'Try: curl -isS -X GET http://127.0.0.1:3000/api');
next();
});
server.get('/authenticated', passport.authenticate('oauth-bearer', { session: false }), (req, res, next) => {
res.json({ message: 'response form authenticated API endpoint' });
return next();
});
server.listen(serverPort);
但是当我尝试调用 api 时,出现此错误:Strategy.prototype.jwtVerify: 无法验证 token
它说它无法验证 token ......我读到了这个:https://github.com/AzureAD/passport-azure-ad/issues/373我添加了 Audience 属性,但它不起作用:
以下是 Passport 选项:
const tenantName = "MY_TENANT",
clientID = "CLIENT_ID",
serverPort = 3000;
module.exports.serverPort = serverPort;
module.exports.credentials = {
identityMetadata: `https://login.microsoftonline.com/${tenantName}.onmicrosoft.com/v2.0/.well-known/openid-configuration`,
//identityMetadata: `https://login.microsoftonline.com/${tenantName}.onmicrosoft.com/.well-known/openid-configuration`,
clientID: clientID,
audience: `https://${tenantName}.onmicrosoft.com/9fc847b6-92d0-4739-9eb1-6201752d6af1`
};
这个想法是从客户端或其他 Web 应用程序调用经过身份验证的 API...这是我正在使用的方法:
static async Task CallWebApiProtectedAsync()
{
var parameters = new PlatformParameters(PromptBehavior.Always);
string authority = "https://login.microsoftonline.com/72f988bf-86f1-41af-91ab-2d7cd011db47/oauth2/token";
string resource = "9fc847b6-92d0-4739-9eb1-6201752d6af1"; //Web API Client Id
string clientId = "0564e082-e1f3-4506-9263-d2171516f934";
string clientSecret = "CLIENT_SECRET";
string redirectUri = "http://clientAPIADD";
try
{
var authContext = new AuthenticationContext(authority);
//var token = await authContext.AcquireTokenAsync(resource, clientId, new Uri(redirectUri), parameters);
var clientCredential = new ClientCredential(clientId, clientSecret);
var token = await authContext.AcquireTokenAsync(resource,clientCredential);
var authHeader = token.CreateAuthorizationHeader();
Console.WriteLine($"AccessTokenType: {token.AccessTokenType} AccessToken:{token.AccessToken}");
var client = new HttpClient();
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(token.AccessTokenType, token.AccessToken);
var requestURI = new Uri("http://localhost:3000/authenticated");
Console.WriteLine($"Reading values from '{requestURI}'.");
HttpResponseMessage httpResponse = await client.GetAsync(requestURI);
Console.WriteLine($"HTTP Status Code: '{httpResponse.StatusCode.ToString()}'");
Console.WriteLine($"HTTP Response: '{httpResponse.ToString()}'");
string responseString = await httpResponse.Content.ReadAsStringAsync();
var json = JsonConvert.DeserializeObject(responseString);
Console.WriteLine($"JSON Response: {json}");
}
catch (Exception ex)
{
Console.WriteLine("Exception in CallWebApirotectedAsync(): " + ex.Message);
}
}
}
有什么想法吗?
谢谢!
最佳答案
正确配置 BearerStrategy
会带来很多麻烦,因此我分享有效的配置:
audience: 'https://graph.windows.net/'
属性添加到您的策略配置中,CallWebApiProtectedAsync
方法的示例中,将 resource
变量更改为 string resource = "https://graph.windows.net/"
,所以基本上您是在请求使用 Microsoft Graph API 的权限(即使您不需要使用它,您也需要将其放入配置中)。希望这有帮助:D
关于node.js - Passport azure 广告 Strategy.prototype.jwtVerify : cannot verify token,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52582547/
我有以下两个问题,我尝试用谷歌搜索这些问题,但没有找到任何运气。请帮助我。 我已将 AdMob 广告集成到我的 iPhone 应用程序中。当点击admob View 时,safari会被打开,如果加载
我用简单的代码在我的网站上使用了自动点击代码并且它起作用了。下面是我之前使用的代码。 $(document).ready(function(){ var list = document.getEle
我需要将自定义 BLE 广告数据从 ios/android 设备广播到许多自定义 BLE 设备。我的目标是设置 ble adv 包的字节以将其广播到附近的 ble 设备。 据我所知,我需要设置我的 i
我想从动态内容的广告意义上展示广告,即调用 API 并发送一些关键字来获取广告,这可能吗? 例如: Adsense.GetAdsForKeywords("car, subaru, auckland")
一位客户要求我使用他的 Google 发布商 ID 和广告 ID 创建他的广告。 他告诉我在博客上创建这个。 我现在的问题是我不知道他到底是什么意思,因为我习惯的是复制代码并粘贴它。 那么,有人可以向
经过大量搜索,我找不到任何支持以非常小的尺寸(40*40 平方或更少像素)展示广告的广告网络。 我看到应用程序可以这样做(就像左上角的高清摄像头 [附图片])。点击此广告后,它会直接进入 google
我有一个博客,上面有一些赞助帖子。 如果用户访问链接到赞助商的帖子,我希望在其他网站(使用 AdSense)上为最近访问过我网站的访问者显示与该赞助商相关的 AdSense 广告。 这是否可以使用动态
我正在开发一个网站,我想在其中展示 Google 广告。如何在我的网站上测试广告?此外: Google 允许我测试广告吗? 它是否认为我的测试是假印象? 我会被 Adsense 屏蔽吗? 这是网站链接
我在尝试显示来自 Admob 的实时广告时遇到问题。测试广告工作正常,但当我切换到实时广告时,我不断收到此错误 Unable to get provider com.google.android.g
我已经集成了 https://pub.dev/packages/firebase_admob进入我的应用程序并实现 rewarded ads .我现在的问题是我想通过这个插件使用中介。唯一的事情是我知
有关背景信息,请参阅:this question 因此,授权流程的第一步是使用 Web 浏览器中的 URL 获取授权 token ,如下所示。对于桌面应用程序,它需要具有以下签名(我对其进行了未编码以
大约一周前(9 月 13 日)Facebook 推出了新的后置链接格式(看起来更像照片后置 - 大图等)。但是,当我通过 API 上传帖子时(效果很好),尽管 Facebook 界面(直接 Faceb
我有来自 webhook 调用的以下 JSOn 响应 { "responseId": "d5c70d8b-e8ad-41df-bb3b-26b0e51d60ca-a14fa99c", "que
我想在内容前面放置一个 Logo /广告,有很多方法可以做到,但问题是它们使用 JS 显示/隐藏方法。发生的情况是,当用户观看 Logo /广告时,内容不会加载,这会导致用户首先等待 Logo /广告
我一直在按照本教程 ( http://www.kilobolt.com/day-7-creating-an-android-game-from-start-to-finish.html ) 创建 An
我有一个包含 dfp 广告的单页网络应用程序。我有两个我正在触发的 dfp adunits,它们位于内容之间,内容是特定类别的文章列表。 当我点击另一个类别时,它只会加载不同类别的文章(不会更改地址栏
我通过 Facebook 的 Power Editor 上传了 212 封电子邮件的 csv,几秒钟后我可以看到观众中有 200 位用户。 我通过 Facebook 的 Power Editor 将相
我的移动应用程序中有一个 AdMob banndr 广告。大多数时候它不会出现。这是它的工作方式,还是我在设置时做错了什么?泰德 最佳答案 如果没有要显示的广告,则不会返回广告。如果您在 admob
我最近让 admob 广告正常工作,我通过以下方式对其进行了测试: AdRequest adRequest = new AdRequest.Builder()
我正在尝试将 Admob 横幅对齐到设备屏幕的右侧。但是它对我不起作用。我正在创建这样的横幅 RelativeLayout layout = new RelativeLayout(activity
我是一名优秀的程序员,十分优秀!