- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试对 Office365 使用 OAuth 身份验证和 Exchange Web 服务 (EWS)。这是在成功将 OAuth2 与新的 RESTful Graph API 结合使用之后,但发现 Graph API 无法完成我需要对 secret 客户端“仅应用程序”流程执行的操作(这将由守护进程使用,所以没有用户交互)。
在我的 table 上敲了几个小时后,我发现(我希望如此!)带有 secret 客户端 OAuth 授权 header 的 EWS SOAP 事务必须具有使用 X.509 证书创建的承载访问 token ,而不仅仅是使用 X.509 证书创建的 client_id/client_secret您可以与 RESTful Graph API 一起使用。否则,EWS SOAP 会失败,并返回 401 Unauthorized HTTP,并显示一个名为 x-ms-diagnostics 的额外非标准 header ,其值为:
2000001;reason="The access token is acquired using an authentication method that is too weak to allow access for this application. Presented auth strength was 1, required is 2.";error_category="invalid_token"
遗憾的是,Azure 管理门户没有用于管理这些证书的 UI,因此您必须下载、编辑然后上传应用的 list (JSON 文件)。
我创建了一个自签名的 2048 位 X.509 证书(使用 openssl 生成一个名为 cert.pem 的 PEM 文件和一个名为 key.pem 的文件中的 key ),然后使用 cert.pem 生成一个 base64 编码的指纹:
echo $(openssl x509 -in cert.pem -fingerprint -noout) | sed 's/SHA1 Fingerprint=//g' | sed 's/://g' | xxd -r -ps | base64
我按照 this document 第 2 步中的说明进行操作尝试将证书放入 list 中(与现有的图形 API client_id/client_secret 设置一起,因为我仍然想在应用程序中尽可能使用更好/更现代的 RESTful Graph API)。为此,我向 JSON 文件中的 passwordCredentials 数组添加了一个新的数组元素数据结构:
{
"customKeyIdentifier": "<base64EncodedFingerprintFromAbove>",
"keyId": "<guid>",
"endDate": "2018-11-24T09:12:01.397205Z",
"type": "AsymmetricX509Cert",
"usage": "Verify",
"value": "MIIDvTCC (lots of certificate) cskQ=="
}
但是,当我现在尝试使用 Azure 管理门户上传编辑后的 list 时,出现错误:
ParameterValidationException=Invalid parameters provided; BadRequestException=Encrypted secret cannot be empty and can be at most 1024 bytes. Parameter name: encryptedSecretValue;
我的 list JSON 文件中没有名为 encryptedSecretValue 的参数,并且我无法通过 Google on what this error means 找到任何内容或what should go in this parameter .
所以我的问题是:应用程序 list JSON 文件中应包含哪些内容,以允许使用证书来获取 secret 客户端访问 token ,以通过 EWS SOAP 查询进行 OAuth 授权?我是不是找错了树?另外,假设我可以让它与 SOAP 一起使用,我可以将生成的访问 token 与 RESTful Graph API 调用以及 EWS SOAP 调用一起使用(即在同一守护程序中混合和匹配 Graph 和 EWS)吗?
最佳答案
passwordCredentials 用于共享 secret /密码(这就是 UI 中显示的内容)。
您需要使用 keyCredentials 来支持 X509/非对称 key 。因此,将上面的 JSON 包装为:
"keyCredentials": [
put your JSON block from above right here
]
将来,我们希望用户体验能够完全简化这个痛点,并实现简单的证书上传。然而,这就是我们现在所拥有的一切。
希望这有帮助,
关于azure - Azure 应用程序 list 中的 "encryptedSecretValue"参数中应该包含什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35610506/
我需要将文本放在 中在一个 Div 中,在另一个 Div 中,在另一个 Div 中。所以这是它的样子: #document Change PIN
奇怪的事情发生了。 我有一个基本的 html 代码。 html,头部, body 。(因为我收到了一些反对票,这里是完整的代码) 这是我的CSS: html { backgroun
我正在尝试将 Assets 中的一组图像加载到 UICollectionview 中存在的 ImageView 中,但每当我运行应用程序时它都会显示错误。而且也没有显示图像。 我在ViewDidLoa
我需要根据带参数的 perl 脚本的输出更改一些环境变量。在 tcsh 中,我可以使用别名命令来评估 perl 脚本的输出。 tcsh: alias setsdk 'eval `/localhome/
我使用 Windows 身份验证创建了一个新的 Blazor(服务器端)应用程序,并使用 IIS Express 运行它。它将显示一条消息“Hello Domain\User!”来自右上方的以下 Ra
这是我的方法 void login(Event event);我想知道 Kotlin 中应该如何 最佳答案 在 Kotlin 中通配符运算符是 * 。它指示编译器它是未知的,但一旦知道,就不会有其他类
看下面的代码 for story in book if story.title.length < 140 - var story
我正在尝试用 C 语言学习字符串处理。我写了一个程序,它存储了一些音乐轨道,并帮助用户检查他/她想到的歌曲是否存在于存储的轨道中。这是通过要求用户输入一串字符来完成的。然后程序使用 strstr()
我正在学习 sscanf 并遇到如下格式字符串: sscanf("%[^:]:%[^*=]%*[*=]%n",a,b,&c); 我理解 %[^:] 部分意味着扫描直到遇到 ':' 并将其分配给 a。:
def char_check(x,y): if (str(x) in y or x.find(y) > -1) or (str(y) in x or y.find(x) > -1):
我有一种情况,我想将文本文件中的现有行包含到一个新 block 中。 line 1 line 2 line in block line 3 line 4 应该变成 line 1 line 2 line
我有一个新项目,我正在尝试设置 Django 调试工具栏。首先,我尝试了快速设置,它只涉及将 'debug_toolbar' 添加到我的已安装应用程序列表中。有了这个,当我转到我的根 URL 时,调试
在 Matlab 中,如果我有一个函数 f,例如签名是 f(a,b,c),我可以创建一个只有一个变量 b 的函数,它将使用固定的 a=a1 和 c=c1 调用 f: g = @(b) f(a1, b,
我不明白为什么 ForEach 中的元素之间有多余的垂直间距在 VStack 里面在 ScrollView 里面使用 GeometryReader 时渲染自定义水平分隔线。 Scrol
我想知道,是否有关于何时使用 session 和 cookie 的指南或最佳实践? 什么应该和什么不应该存储在其中?谢谢! 最佳答案 这些文档很好地了解了 session cookie 的安全问题以及
我在 scipy/numpy 中有一个 Nx3 矩阵,我想用它制作一个 3 维条形图,其中 X 轴和 Y 轴由矩阵的第一列和第二列的值、高度确定每个条形的 是矩阵中的第三列,条形的数量由 N 确定。
假设我用两种不同的方式初始化信号量 sem_init(&randomsem,0,1) sem_init(&randomsem,0,0) 现在, sem_wait(&randomsem) 在这两种情况下
我怀疑该值如何存储在“WORD”中,因为 PStr 包含实际输出。? 既然Pstr中存储的是小写到大写的字母,那么在printf中如何将其给出为“WORD”。有人可以吗?解释一下? #include
我有一个 3x3 数组: var my_array = [[0,1,2], [3,4,5], [6,7,8]]; 并想获得它的第一个 2
我意识到您可以使用如下方式轻松检查焦点: var hasFocus = true; $(window).blur(function(){ hasFocus = false; }); $(win
我是一名优秀的程序员,十分优秀!