Teams Tab的Single Sign-On

本文介绍了Teams Tab应用中Single Sign-On(SSO)功能的开发者预览阶段,旨在简化获取用户token的过程。该功能目前仅支持工作组织账号,不支持Microsoft Account。流程包括前端调用方法触发Teams客户端向Azure AD申请token,然后将token返回给tab应用。开发者需要注意,通过这种方式获取的token仅限于用户权限,若需调用Graph API则需额外授权。
摘要由CSDN通过智能技术生成

在我写这篇文章的时候,这个SSO机制还是在 Developer Preview 阶段,可能在发布前还会有一些改进。不过我觉得这个功能很好,所以先和大家分享一下。

如果大家之前已经开发过Teams的tab应用,可能会发现如果你需要一个当前用户的token十分繁琐,这个SSO的设计就是用来解决这个问题的,目前只支持工作组织账号(暂不支持Microsoft Account)。

我们先来看一下处理的流程:

sso

  1. 在你的tab前端代码里,调用getAuthToken()方法,这个方法会告知Teams客户端,你的tab app想要一个token。
  2. 如果这个是当前用户第一次,并且你的app需要用户审核,那teams客户端就会弹出一个审核的窗口。类似于下图

 

  1. Teams客户端会向Azure AD发送申请用户token的请求。
  2. 如果一切顺利,AzureAD就会把token返回给Teams客户端
  3. Teams客户端把token返回给你的tab应用,token作为getAuthToken()的返回对象。要注意,这是一个异步的调用
  4. 你的tab app拿到token后就可以对token进行解析获取用户的一些身份信息,下面是一个tab app的解析的代码:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值