Gmail API: 强制授权重新提示用户

Gmail API: forcing the authorization to reprompt the user

似乎以某种方式缓存了授权访问 gmailAPI 的凭据。当我更改客户端 ID 和密码以及电子邮件地址时,没有任何变化。此外,当我更改范围时,没有任何变化。我正在尝试强制刷新凭据。有没有办法强制凭据重新提示用户?

有没有我可以找到并删除的文件?

我正在使用来自 nuget 的 c# 和 gmail api 包。认证代码是:

 _emailAddress = Settings.EmailAddress;
string clientSecret = Settings.ClientSecret;
string clientId = Settings.ClientId;
ClientSecrets clientSecrets = new ClientSecrets {ClientId = clientId, ClientSecret = clientSecret};
UserCredential credential;
credential = GoogleWebAuthorizationBroker.AuthorizeAsync(
    clientSecrets,
    Scopes,
    "user",
    CancellationToken.None).Result;

_service = new GmailService(new BaseClientService.Initializer()
{
   HttpClientInitializer = credential,
   ApplicationName = "Draft Sender", //applicationName,
});

此外,一旦我获得凭据,我的范围就设置好了:在我删除并更新机密和 clientID 之前不能更改范围。此外,它需要两次 运行-throughs 才能生成凭据,第一次导致错误,第二次导致授权提示。

我很确定会发生这种情况,因为凭据以某种方式缓存在某个地方,即使我没有指定任何存储...但我不确定。无论哪种方式,问题似乎都取决于 gmail api 包中的代码,但我无法为我正在处理的问题找到解决方案。

最终,我需要将一项功能部署到 ASP 网站,该网站将访问 gmail 帐户作为电子邮件的存储库,因此我需要弄清楚这个授权问题,以便服务器可以访问在部署时(或之后很容易)发送到电子邮件帐户。在没有中间错误的情况下发生它并不是真的必要(但希望)。

是否有解决方案(简单或困难)来控制此缓存过程并处理权限?

如果您没有指定存储响应令牌的位置,它将存储在:

C:\Users\'Your user'\AppData\Roaming\Google.Apis.Auth

如果你想指定目录看这个: (注意:你只需要在你的项目中创建目录App_Data

string path = HostingEnvironment.MapPath("~/App_Data");    
credential = GoogleWebAuthorizationBroker.AuthorizeAsync(
                         new ClientSecrets
                         {
                             ClientId = "Client_ID",
                             ClientSecret = "Secret_Client"
                         },
                         Scopes,
                         "me",
                         CancellationToken.None,
                         new FileDataStore(path)

                         ).Result;