“租户 GUID X 的租户不存在”,对于自己的电子邮件帐户(我是唯一的成员)

2024年 2月 13日 67.7k 0

“租户 guid x 的租户不存在”,对于自己的电子邮件帐户(我是唯一的成员)

php小编鱼仔在解决电子邮件帐户问题时,可能会遇到错误信息“租户 GUID X 的租户不存在”,特别是当自己是唯一成员时。这个错误信息可能会导致无法登录或访问电子邮件帐户。针对这个问题,我们有一些解决方案可以尝试,以恢复对电子邮件帐户的访问和正常使用。在下文中,我们将介绍一些可能的解决方法和步骤,希望能对您解决问题提供帮助。

问题内容

我想阅读我的个人帐户的电子邮件,但收到“租户 guid x 的租户不存在”消息。

  • 我在 https://entra.microsoft.com/ 上使用单租户创建了一个应用程序

  • 然后我授予它发送电子邮件的权限

  • 然后我创建了一个客户端密钥

  • 然后我使用此代码来获取令牌:

    import(""github.com/azuread/microsoft-authentication-library-for-go/apps/confidential")
    cred, err := confidential.newcredfromsecret("{secret value}")
    if err != nil {
    log.println(err)
    return
    }
    confidentialclient, err := confidential.new("https://login.microsoftonline.com/{tenant id}", "{client id}", cred)
    if err != nil {
    log.println(err)
    return
    }
    scopes := []string{"https://graph.microsoft.com/.default"}
    result, err := confidentialclient.acquiretokensilent(context.todo(), scopes)
    if err != nil {
    result, err = confidentialclient.acquiretokenbycredential(context.todo(), scopes)
    if err != nil {
    log.println(err)
    return
    }
    }

    登录后复制

  • 我使用该代码成功获取了令牌

    {
    "account": {
    "additionalfields": null
    },
    "idtoken": {
    "rawtoken": "",
    "additionalfields": null
    },
    "accesstoken": "{token}",
    "expireson": "2023-12-13t14:57:09.4905758-05:00",
    "grantedscopes": [
    "https://graph.microsoft.com/.default"
    ],
    "declinedscopes": null
    }

    登录后复制

  • 然后我获取用户 id(我是唯一的用户):

    req, err := http.newrequest("get", "https://graph.microsoft.com/v1.0/users", nil)
    if err != nil {
    log.println(err)
    return
    }
    req.header.add("authorization", "{token}")
    client := http.client{}
    resp, err := client.do(req)
    if err != nil {
    log.println(err)
    return
    }
    body, err := io.readall(resp.body)
    if err != nil {
    log.println(err)
    return
    }

    登录后复制

  • 但是当我尝试获取电子邮件时:

    req, err := http.newrequest("get", "https://graph.microsoft.com/v1.0/users/{user_id}/messages", nil)
    if err != nil {
    log.println(err)
    return
    }
    req.header.add("authorization", "{token}")
    client := http.client{}
    resp, err := client.do(req)
    if err != nil {
    log.println(err)
    return
    }
    body, err := io.readall(resp.body)
    if err != nil {
    log.println(err)
    return
    }

    登录后复制

我得到:

{
"error": {
"code": "OrganizationFromTenantGuidNotFound",
"message": "The tenant for tenant guid '0a6ac917-332a-4f47-881e-0b35fb1b2ab5' does not exist.",
"innerError": {
"oAuthEventOperationId": "c096c5c9-e743-4daa-9a97-d14d915e9842",
"oAuthEventcV": "N0nHeUJm9gwnrFZefuEA4w.1.1",
"errorUrl": "https://aka.ms/autherrors#error-InvalidTenant",
"requestId": "c0272999-9743-44ee-98b5-947acc52e7d8",
"date": "2023-12-13T19:11:22"
}
}
}

登录后复制

错误上的id 0a6ac917-332a-4f47-881e-0b35fb1b2ab5是tenand id

解决方法

要阅读个人 outlook 帐户的邮件,需要切换到委托流程(例如交互流程或生成访问令牌的授权码流程)并调用 /me/ messages 端点。

注册多租户应用程序,帐户类型为“任何组织目录中的帐户(任何 microsoft entra id 租户 - 多租户)和个人 microsoft 帐户(例如 skype、xbox)” >“:

如果您使用交互流生成令牌,请确保启用公共客户端选项:

现在,根据您的需要在您的应用注册中添加委托类型的mail.readmail.readwrite权限:

要使用交互流生成访问令牌,您可以参考此示例go代码,然后使用它来调用 /me/messages 端点:

package public_test

import (
"context"

"github.com/azuread/microsoft-authentication-library-for-go/apps/public"
)

func example() {
client, err := public.new("client_id", public.withauthority("https://login.microsoftonline.com/common"))
if err != nil {
}

var result public.authresult
scopes := []string{"https://graph.microsoft.com/.default"}

accounts, err := client.accounts(context.todo())
if err != nil {
// todo: handle error
}
if len(accounts) > 0 {
result, err = client.acquiretokensilent(context.todo(), scopes, public.withsilentaccount(accounts[0]))
}
if err != nil || len(accounts) == 0 {
result, err = client.acquiretokeninteractive(context.todo(), scopes)
if err != nil {
}
}
_ = result.account
_ = result.accesstoken
}

登录后复制

您还可以登录graph explorer 使用该帐户并运行以下查询来获取电子邮件:

GET https://graph.microsoft.com/v1.0/me/messages

登录后复制

回应:

参考:

微软身份验证-library-for-go/apps/public/example_test.go 位于 main · azuread/microsoft-authentication-library-for-go · github

以上就是“租户 GUID X 的租户不存在”,对于自己的电子邮件帐户(我是唯一的成员)的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论