在上一篇 VBA 中发送邮件(使用 Outlook)中,VBA 通过 Outlook 来发邮件不仅频繁的弹出提示窗口要求确定,而且需要在 Outlook 中配置好,不能随意使用邮件服务器。对此,是否有相当于 JavaMail 那样的第三方组件呢?Google 帮忙,果然找到一个,名曰 w3 JMail,J 为首,其实与 Java 无任何关系。
可以在网络上搜索 w3 JMail Personal V4.3,或者直接到官网 http://www.dimac.net 去下载,w3 Jmail 的授权方式是免费的。默认位置安装好 JMail 之后,是在 C:\Program Files\Dimac\w3JMail4 可以看到 Examples 目录、jmail.dll、w3jmail4.pdf 和 readme.txt 文件。可以查阅w3jmail4.pdf 中的使用帮助。我们所要的文件其实只是那个 jmail.dll,安装程序会自动帮你注册 jmail.dll。若未运行安装程序,只是拷贝了 jmail.dll,则要运行 regsvr32 jmail.dll 注册它即可。
可以看看那个 Examples 目录,发现可支持 ASP、Assembly、Delphi、Visual C++、xml,自然像 JS、VBS、VB、VBA 那样的语言中也能使用。它不仅可以用来发送邮件,也能通过 POP 协议接收邮件。下面看一段接收邮件的代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
'使用 JMail 组件来发送邮件 Function JmailSend(Subject, HtmlBody, MailTo) Dim JmailMsg As New jmail.Message With JmailMsg .Encoding = "GBK" .MailServerUserName = "Unmi" 'smtp 验证用户名 .MailServerPassWord = "xxxxxx" 'smtp 验证密码 .AddRecipient MailTo '收件人 .AddRecipientCC "fantasia@sina.com" '抄送 .AddRecipientBCC "broodwar@2911.net" '暗送 .From = "unmi@2911.net" .FromName = "隔叶黄莺" .Charset = "GBK" .ContentType = "text/html" '.Priority = 1 '重要级别 .Logging = True '为 True,可用 JmailMsg.Log 获得与服务器交互的详细日志信息 .Silent = True '为 True,出错时会有 JmailMsg.ErrorMessage 回送消息 .Subject = Subject '.Body = HtmlBody '作为纯文本内容发送,设置 Body 属性 .HtmlBody = HtmlBody '用这个可以发送 Html 内容 .AddAttachment "c:\users.ctl" '发送附件 If .Send("mail.2911.net") Then '指定邮件服务器 JmailSend = "发送成功" Else JmailSend = JmailMsg.ErrorMessage End If MsgBox JmailMsg.Log .Close End With Set JmailMsg = Nothing End Function |
在 Excel 的 Microsoft Visual Basic 编辑器中要引用注册的“JMail 4.0 Library”, 代码中的 AddXxx 方法可以执行多次,如增加多个收件人、多个附件等。真正实现批量全自动发送,程序中可动态的选择邮件服务器。
用 w3 JMail 组件比起调用 Outlook 可要方便的多,Outlook 可以不用配置,发布时只需要带个 jmail.dll 动态库,用 regsvr32 jmail.dll 注册一下即可。
参考:1. 用VBA+Jmail发邮件
本文链接 https://yanbin.blog/vba-send-email-jmail/, 来自 隔叶黄莺 Yanbin Blog
[版权声明] 本文采用 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0) 进行许可。