2

我已通过托管公司购买了经过身份验证的 SMTP 包。

我已经通过 Outlook 2010 成功测试了帐户设置。

展望设置:

电子邮件:me@domain.com 发送 SMTP:smtp.hostingcompany.net

登录信息:

  • 用户:mydomain.com_account
  • 通行证:密码

更多设置 > 传出服务器:

  • 我的传出服务器 (SMTP) 需要身份验证
  • 用户:mydomain
  • 通行证:密码

我在指定 NetworkCredentials 时尝试了所有可能的组合,但我不断收到SMTP 异常:“Faulure Sending Email” InnerException:Base-64 字符数组的长度无效。

public static void SendEmail(string To, string Subject, string Body)
    {
        try
        {
            using (SmtpClient mySmtpClient = new SmtpClient(GlobalSettings.EmailHost))
            {
                mySmtpClient.UseDefaultCredentials = false;
                //mySmtpClient.EnableSsl = false;
                mySmtpClient.Credentials = new NetworkCredential(mydomain.com_account, GlobalSettings.EmailPassword);

                MailAddress from = new MailAddress("email@mydomain");
                MailAddress to = new MailAddress(To);

                using (
                    MailMessage myMail = new MailMessage(from, to)
                    {
                        Subject = Subject,
                        SubjectEncoding = Encoding.UTF8,
                        Body = Body,
                        BodyEncoding = Encoding.UTF8,
                        IsBodyHtml = true
                    })
                {
                    mySmtpClient.Send(myMail);
                }
            }
        }
        catch (SmtpException ex)
        {
            Log.WriteLog(string.Format("[Send Mail Exception] --> SMTPException has occurred: {0}", ex.Message), LogLevel.Error);
        }
        catch (Exception ex)
        {
            Log.WriteLog(string.Format("[Send Mail Exception] --> Exception has occurred: {0}", ex.Message), LogLevel.Error);
        }
    }

我已经为 NetworkCredential() 尝试了三个可能的用户名登录参数。

提前致谢。

编辑:NTLM 黑客

我在我的代码中添加了以下几行:

FieldInfo transport = _client.GetType().GetField("transport",
    BindingFlags.NonPublic | BindingFlags.Instance);

FieldInfo authModules = transport.GetValue(_client).GetType()
    .GetField("authenticationModules",
        BindingFlags.NonPublic | BindingFlags.Instance);

Array modulesArray = authModules.GetValue(transport.GetValue(_client)) as Array;
modulesArray.SetValue(modulesArray.GetValue(2), 0);
modulesArray.SetValue(modulesArray.GetValue(2), 1);
modulesArray.SetValue(modulesArray.GetValue(2), 3);

我现在收到一条新消息:

Mailbox unavailable. The server response was: relay not permitted
4

2 回答 2

1

根据以下文章:“Hacking” System.Net.Mail.SmtpClient,当 SmtpClient 选择使用NTLM身份验证进行身份验证时,可能会引发异常。

该文章提供了一个修复程序,尽管正如文章名称所暗示的那样,它是一个 hack。

然而,在评论中,一位发帖人还指出,错误的密码可能会导致同样的异常。

于 2011-11-04T15:28:41.623 回答
1

关于你的第二个问题:

信箱不可用。服务器响应是:不允许中继

发生这种情况是因为服务器现在没有可接受的身份验证方法,并且不愿意冒险获得“开放中继”的声誉。

这可能是可以修复的。问题是你使用的黑客太重了。它正在覆盖除“Digest”之外的所有身份验证模块,而我们需要做的就是覆盖 NTLM。

试试这个精​​简版:

FieldInfo transport = _client.GetType().GetField("transport",
BindingFlags.NonPublic | BindingFlags.Instance);

FieldInfo authModules = transport.GetValue(_client).GetType()
    .GetField("authenticationModules",
        BindingFlags.NonPublic | BindingFlags.Instance);

Array modulesArray = authModules.GetValue(transport.GetValue(_client)) as Array;
modulesArray.SetValue(modulesArray.GetValue(2), 1);
于 2012-07-27T09:44:16.087 回答