开发者

Failure sending mail. Unable to write data to the transport connection

开发者 https://www.devze.com 2023-03-01 00:01 出处:网络
I am using a Gmail SMTP server to send mail from VB.Net. Although it sends some emails fine, for some others it returns the following开发者_如何学运维 error:

I am using a Gmail SMTP server to send mail from VB.Net. Although it sends some emails fine, for some others it returns the following开发者_如何学运维 error:

Failure sending mail. Unable to write data to the transport connection System.Net.Sockets.SocketException: An established connection was aborted by the software in your host machine


I was experiencing this same issue recently with SmtpClient.SendMail(MailMessage) being used repeatedly with an email with a 350k attachment. Every 33rd message, the error you gave would occur.

Turns out our shared component which encapsulated the SendMail functionality was not calling Dispose() on the SmtpClient class when the message was finished sending.

Adding client.Dispose() to the SmtpClient instance cleared the problem right up and now messages go out no problem - hundreds of them (and yes they're legitimate product notifications to our customers, not spam) ;)


From what I read on the net, the Winsock error code associated with this exception is WSAECONNABORTED.

You can read more about it at this address for an explanation: WSAECONNABORTED

Basically it means that the server closed the connection while your application was trying to send a large e-mail.

Maybe you should check the Gmail documentation to see if it has some limitation on message size, or total number of messages sent. Looks like you're pumping too much data on the socket.

0

精彩评论

暂无评论...
验证码 换一张
取 消