授权访问gmailAPI的凭据似乎以某种方式缓存。当我更改客户端ID和密码以及电子邮件地址时,没有任何变化。此外,当我更改范围时,没有任何变化。我试图强制刷新凭据。有没有办法强制凭据重新提示用户?
我可以找到并删除一个文件吗?
我正在使用c#和nuget的gmail api包。凭证的代码是:
(a+c*b) / (d-2*c)
a=1
b=2
c=3
d=8
a+c*b = 1+3*2 = 7
d-2*c = 8-2*3 = 2
7 / 2 = quotient 3, remainder 1
此外,一旦我凭证,我的范围设置:在删除并更新secret和clientID之前无法更改范围。此外,它需要两次运行才能生成凭据,第一次导致错误,但第二次导致提示授权。
我很确定这种情况正在发生,因为即使我没有指定任何存储空间,凭据也会缓存在某处,但我不确定。无论哪种方式,问题似乎都依赖于gmail api包中的代码,但我无法找到解决方案来解决我正在处理的问题。
最终,我需要将一个功能部署到一个ASP网站,该网站将访问gmail帐户作为电子邮件的存储库,所以我需要弄清楚这个授权的事情,以便服务器在部署时可以访问该电子邮件帐户(或之后很容易)。没有中间错误就没有必要(但希望)它发生。
是否有解决方案(简单或困难)来控制此缓存过程并处理权限?
答案 0 :(得分:1)
如果您未指定响应令牌的存储位置,则将其存储在:
C:\ Users \“您的用户” \ 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;