sql – xp_smtp_sendmail随机添加到html的空格

我有一个proc,我生成带有链接的小html文档,并通过xp_smtp_sendmail proc发送出去.链接是根据查询结果生成的,并且很长.这适用于大多数情况.但是,由于空格被插入到查询字符串变量名中,有时链接会被破坏,即& Na me = John.

这可能因电子邮件客户端而异(同一链接在Gmail中有效,但由于空格可能无法在comcast中使用.空间似乎是随机插入的,因此在每个损坏的电子邮件链接空间中可能会破坏其他查询字符串变量.当我从proc执行PRINT时链接很干净,没有空格.

这是我在main proc中执行的邮件proc的示例(获取查询结果并为@Message生成html).无论我是否编码网址,似乎都插入了空格.

预先感谢您的帮助.如果代码在这里没有正确显示,我可以发送更清晰的代码版本.

….上面的查询结果

SET @Message = NULL
SET @Message = @Message +
+ '<br/>Dear ' + @FirstName + ' ' + @LastName + ','
+ '<br/><br/>Recently you took "' + @Title + '". ' 
+ 'In response to the question "What is it?" ' 
+ 'you responded "' + @Response + '".' 
+ '<br/><br/>Following up on prevIoUs mailing'
+ '<br/><br/>Please click on the link below'
+ '<br/><br/><a href="' + @Link + '">Please click here</a>'
+ '<br/><br/>plain text'
+ '<br/><br/>plain text,'
+ '<br/><br/>plain text<br/>
plain text<br/>
plain text<br/>
plain text<br/>
plain text<br/>
plain text

EXEC @rc = master.dbo.xp_smtp_sendmail
 @FROM         = 'any@any.com',@FROM_NAME    = 'Any User',@TO           = @Email,@priority     = N'norMAL',@subject      = N'My email',@message      = @Message,@messagefile  = N'',@type         = N'text/html',@attachment   = N'',@attachments  = N'',@codepage     = 0,@server       = 'smtp.server.any'

解决方法

1 – 检查您生成的消息的长度,并切换到从文件发送它的长度接近4000 char.

2 – 在每个句子或段落之前注入cr / lf字符.

3 – 确保在标签打开之前和之后你有cr / lf(或者只是如果这是smtp服务器喜欢的那样)

4 – 与任何关于缩短嵌入链接长度的人交谈 – 这显然是不可持续的

5 – 询问smtp服务器上的任何配置选项,以便将电子邮件作为完全编码的二进制文件发送(需要MIME头和Base64编码)

6 – 寻找xp_smtp_sendmail的最新替代品,也许是.NET xp

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 &#39;EastRiver&#39; 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...