我创建了一种发送电子邮件的方法,例如:
public async Task SendEmailCC(string body, string subject, List<string> mainRecievers, List<string> receivers)
{
SmtpClient client = new SmtpClient("smtp-mail.outlook.com")
{
UseDefaultCredentials = true,
Port = 587,
EnableSsl = true,
DeliveryMethod = SmtpDeliveryMethod.Network,
Credentials = new NetworkCredential("Test@gmail.com", "MyMailPassword")
};
MailMessage mailMessage = new MailMessage { From = new MailAddress("job@test.org") };
foreach (var reciever in mainRecievers)
{
mailMessage.To.Add(reciever);
}
foreach (var item in receivers)
{
mailMessage.CC.Add(item);
}
mailMessage.Body = body;
mailMessage.IsBodyHtml = true;
mailMessage.Subject = subject;
await client.SendMailAsync(mailMessage);
}
Run Code Online (Sandbox Code Playgroud)
为了测试,我给自己发送了一封电子邮件,但我没有收到电子邮件。我怎样才能找到我的问题?
我的例外是连接身份验证。
小智 5
邮件服务器是谷歌,我使用了 OutLookSmtp,对于我的代码的这一部分,我有那个,我改变了。喜欢:
SmtpClient client = new SmtpClient("smtp-mail.outlook.com")
Run Code Online (Sandbox Code Playgroud)
并改变了:
SmtpClient client = new SmtpClient("smtp.gmail.com")
Run Code Online (Sandbox Code Playgroud)
之后我得到这个异常:
SMTP 服务器需要安全连接或客户端未通过身份验证。服务器响应为:5.5.1 Authentication Required”,由于以下情况可能会发生错误。
对于这个问题,我试试这个:
情况一:密码错误时
情况 2:当您尝试从某个 App 登录时
情况 3:当您尝试从时区/域/计算机以外的域登录时(大多数情况下从代码发送邮件时都是这种情况)
每个都有一个解决方案
情况1的解决方法:输入正确的密码。
情况 2 的解决方案 1:转到以下链接中的安全设置https://www.google.com/settings/security/lesssecureapps并启用安全性较低的应用程序。这样您就可以从所有应用程序登录。
情况 2 的解决方案 2:(参见/sf/answers/670107091/)启用双因素身份验证(又名两步验证),然后生成特定于应用程序的密码。使用新生成的密码通过 SMTP 进行身份验证。
案例 3 的解决方案 1:(这可能会有所帮助)您需要查看活动。但由于最新的安全标准,查看活动将无济于事,链接将无用。所以试试下面的案例。
情况 3 的解决方案 2:如果您已将代码托管在生产服务器上的某处,并且您有权访问生产服务器,则将远程桌面连接到生产服务器并尝试从生产服务器的浏览器登录一次。这将为登录 google 添加 excpetionon,您将被允许从代码登录。
但是如果您无权访问生产服务器怎么办。尝试解决方案 3
情况 3 的解决方案 3:您必须为您的 google 帐户启用从其他时区/ip 登录。
要执行此操作,请点击链接https://g.co/allowaccess并通过单击继续按钮允许访问。
就是这样。干得好。现在,您将可以从任何一台计算机通过任何应用程序登录到您的 Google 帐户
| 归档时间: |
|
| 查看次数: |
66 次 |
| 最近记录: |