System.Net.Mail不会在生产中发送

时间:2012-11-27 18:59:48

标签: c# asp.net-mvc sql-server-2008

我正在尝试在我的网站中实施“忘记密码”方法。它在调试中完美运行。使用相同的代码和数据库,但发布到我们的Web服务器时,它在尝试发送消息时失败。

我得到的错误是:

There was an error sending you an email.
The specified string is not in the form required for an e-mail address.

电子邮件是有效的,所以我不知道它为什么会失败。

因为它是一个实时环境,所以我无法单步查看代码,以确切了解它失败的原因和原因。我实现了数据库日志记录,因此我可以看到它在失败之前获得了多远,并且到目前为止它成功执行了所有代码:

 var smtp = new SmtpClient
 {
     Host = host,
     Port = port,
     EnableSsl = ssl,
     DeliveryMethod = SmtpDeliveryMethod.Network,
     UseDefaultCredentials = false,
     Credentials = new NetworkCredential(fromAddress.Address, fromPw)
 };
 using (var message = new MailMessage()
 {
     Subject = subject,
     Body = body,
     IsBodyHtml = ishtml,
     From = fromAddress
 })

 {
     foreach (MailAddress t in toCol)
     { message.To.Add(t); }
     foreach (MailAddress c in ccCol)
     { message.CC.Add(c); }
     foreach (MailAddress b in bccCol)
     { message.Bcc.Add(b); }
     smtp.Send(message);
 }

它永远不会进入下一个db日志记录,所以它必须在这里失败。在我的测试中,我只有一个to的电子邮件地址,bcccc都没有。在调试中单步执行时,它会正确加载单个电子邮件地址,而不会为ccbcc加载任何内容。我不知道它是一个无效的电子邮件地址。

修改

我们使用Google Apps作为我们的邮件服务器,因此我的工作站和服务器都必须连接。我使用以下内容:

  • 主持人:smtp.gmail.com
  • 港口:587
  • EnableSsl:true
  • 凭据:在调试中有效的用户名和密码

编辑2: 包含你的一些建议。
使用db中的值来设置fromAddress,如下所示:

DataTable ts = DAL.Notification.GetNotificationSettings();
var fromEmail = ts.Rows[0]["fromadr"].ToString().Trim();
var fromName = ts.Rows[0]["fromname"].ToString().Trim();
var host = ts.Rows[0]["server"].ToString().Trim();
var port = Convert.ToInt32(ts.Rows[0]["smtpport"]);
var ssl = Convert.ToBoolean(ts.Rows[0]["is_ssl"]);
var ishtml = Convert.ToBoolean(ts.Rows[0]["is_html"]);
var bodyTemplate = ts.Rows[0]["bodyTemplate"].ToString();
body = bodyTemplate.Replace("{CONTENT}", body).Replace("{emailFooter}","");// Needs to use the Global emailFooter resource string

var fromAddress = new MailAddress(fromEmail, fromName);

我甚至尝试过对这样的地址进行硬编码:

message.From = new MailAddress("websystem@mydomain.com");

我仍然收到错误,但在定义消息时仍然失败。

有关如何查找和解决问题的其他建议吗?

ANSWER

我没有在web.config中定义默认地址,如下所示:

    <system.net>
     <mailSettings>
       <smtp from="email@yourdomain.com">
         <network host="smtp.yourdomain.com"/>
       </smtp>
     </mailSettings>   </system.net>

所以在我定义正确的var message = new MailMessage()地址之前,from失败了。

我需要在web.config中实现var message = new MailMessage(From,To)或提供默认的from地址(这就是我所做的)

2 个答案:

答案 0 :(得分:4)

此错误可能由两件事引起:

  1. 您使用的其中一个电子邮件地址(message.Tomessage.CCmessage.Bcc)无效,即它不符合{{1}所需的格式}。

  2. Web.Config 中配置的 From 地址无效:

    someuser@somedomain.xxx

答案 1 :(得分:1)

我的建议是使用try / catch语句来进一步缩小问题范围。我还会暂时丢失MailMessage的using语句,以便更轻松地进行故障排除。

示例:

var smtp;
try
{
    smtp = new SmtpClient
    {
        Host = host,
        Port = port,
        EnableSsl = ssl,
        DeliveryMethod = SmtpDeliveryMethod.Network,
        UseDefaultCredentials = false,
        Credentials = new NetworkCredential(fromAddress.Address, fromPw)
    };
}
catch (Exception exc)
{
    MessageBox.Show("Error creating SMTP client: " + exc.Message);
}

var message = new MailMessage();
try
{
    message.Subject = subject;
    message.Body = body;
    message.IsBodyHtml = ishtml;
    message.From = fromAddress;
}
catch (Exception exc)
{
    MessageBox.Show("Error creating MailMessage: " + exc.Message);
}


try
{
    foreach (MailAddress t in toCol)
        message.To.Add(t);
}
catch (Exception exc)
{
    MessageBox.Show("Error adding TO addresses: " + exc.Message);
}

try
{
    foreach (MailAddress c in ccCol)
        message.CC.Add(c);
}
catch (Exception exc)
{
    MessageBox.Show("Error adding CC addresses: " + exc.Message);
}

try
{
    foreach (MailAddress b in bccCol)
        message.Bcc.Add(b);
}
catch (Exception exc)
{
    MessageBox.Show("Error adding BCC addresses: " + exc.Message);
}

try
{
    smtp.Send(message);
}
catch (Exception exc)
{
    MessageBox.Show("Error sending message: " + exc.Message);
}

或者,您可以使用写入日志文件的内容替换各种MessageBox.Show()语句。通过打破这一点,您应该能够更准确地查明问题。