【发布时间】:2018-07-18 03:57:28
【问题描述】:
似乎以某种方式缓存了授权访问 gmailAPI 的凭据。当我更改客户端 ID 和密码以及电子邮件地址时,没有任何变化。此外,当我更改范围时,没有任何变化。我正在尝试强制刷新凭据。有没有办法强制凭据重新提示用户?
有没有我可以找到并删除的文件?
我正在使用 c# 和 nuget 的 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,
});
此外,一旦我获得凭据,我的范围就设置好了:在我删除并更新密钥和客户端 ID 之前无法更改范围。此外,生成凭据需要两次运行,第一次会导致错误,但第二次会提示授权。
我很确定这是因为凭据以某种方式缓存在某处,即使我没有指定任何存储...但我不确定。无论哪种方式,问题似乎都取决于 gmail api 包中的代码,但我无法为我正在处理的问题找到解决方案。
最终,我需要向 ASP 网站部署一个功能,该网站将访问 gmail 帐户作为电子邮件的存储库,因此我需要弄清楚这个授权,以便服务器在部署时可以访问电子邮件帐户(或很容易之后)。在没有中间错误的情况下发生它并不是真的必要(但希望)。
是否有解决方案(简单或困难)来控制此缓存过程并处理权限?
【问题讨论】:
-
您能详细说明一下吗?您使用的是什么库和语言?我会假设你的图书馆仍然认为你拥有的令牌是有效的,所以它不会打扰重新认证。
-
我认为这正是正在发生的事情。我继续删除了我的秘密和客户端 ID,并创建了一个新的。这迫使系统重新进行身份验证。但是必须有一种更清洁的方法来做到这一点?我正在使用 C# 和 nuget gmail api 包。
-
我认为您应该只进行一次身份验证,并使用库中的其他简洁功能在访问令牌用完时(通常在一个小时后)刷新访问令牌:)
-
哦,我知道这很容易 :) 我会尝试看看这是否有效 - 但我不能经常授权电子邮件......它应该只授权一次.. . 让它在服务器上运行存在问题:是否可以在凭据完整的情况下进行部署?否则,我觉得我需要以某种方式控制令牌..