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;
似乎以某种方式缓存了授权访问 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;