如何解决C#OAuth2 SMTPclient.Authenticate异常
我将服务帐户添加到我的email@gmail.com,为此激活了OAuth2并下载了密钥。然后,我按照本(挽救生命)post中描述的步骤进行操作,唯一的区别是实例化了Json文件中的“凭据”(加载p12总是会给我“无效的网络密码”)。有了这个,我可以成功获取访问令牌,这是完成访问的行:
Task<bool> result = credential.RequestAccessTokenAsync(CancellationToken.None);
然后我从MailKit实例化SmtpClient并尝试连接和认证:
client.Connect("smtp.gmail.com",587,SecureSocketOptions.StartTls);
var oauth2 = new SaslMechanismOAuth2("email@gmail.com",credential.Token.AccessToken);
client.Authenticate(oauth2);
最后一行生成的异常读取为 555:5.5.2语法错误,再见。 l13sm3080685qtv.82-gsmtp 。以.82结尾的部分随每个后续调用而变化。根据{{3}},我为“ email@gmail.com”(即
同时,我尝试了2种其他实现方式,声称它们做对了。没有任何效果-它们都成功获得访问令牌,但在“身份验证”上失败。所有这些使您一目了然,并使工作更加无望。一个人想知道是否有任何C#代码可以真正成功地使用OAuth2发送gmail消息...任何提示或其他形式的帮助将不胜感激。
下面的jstedfast指出的方法效果很好,但是我想跟进一些问题。标准注释太多了,所以我在这里添加了它:
首次执行该流程时,它将打开弹出浏览器窗口,并且用户必须登录/批准该应用程序/服务才能访问gmail帐户。看起来访问密钥必须存储在硬盘驱动器上。如果我从GoogleAuthorizationCodeFlow构造函数中删除了“ DataStore”,那么每次执行代码时浏览器似乎都会弹出。我必须修复的应用程序通常无需任何用户交互即可运行。有没有一种方法可以通过在开发人员控制台中定义的gmail帐户或服务/应用中启用/禁用某些功能来避免浏览器弹出?如果无法通过这种方式使用标准gmail帐户,那么可以成为GSuite域一部分的电子邮件吗?拥有该应用程序的客户使用Google GSuite,他们的域名包含电子邮件和文档。我认为现在我了解了jstedfast关于客户端到服务器和服务器到服务器的评论。
解决方法
请按照以下说明进行操作:https://github.com/jstedfast/MailKit/blob/master/GMailOAuth2.md
如果正在加载.p12,则说明您做错了。该方法用于服务到服务,而不是客户到服务。我上面提供的说明适用于客户到服务。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。