VBA 中发送邮件(二. 使用 JMail 组件)

在上一篇 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'使用 JMail 组件来发送邮件
 2Function JmailSend(Subject, HtmlBody, MailTo)
 3    Dim JmailMsg As New jmail.Message
 4    With JmailMsg
 5        .Encoding = "GBK"
 6        .MailServerUserName = "Unmi" 'smtp 验证用户名
 7        .MailServerPassWord = "xxxxxx" 'smtp 验证密码
 8        .AddRecipient MailTo '收件人
 9        .AddRecipientCC "fantasia@sina.com" '抄送
10        .AddRecipientBCC "broodwar@2911.net" '暗送
11        .From = "unmi@2911.net"
12        .FromName = "隔叶黄莺"
13        .Charset = "GBK"
14        .ContentType = "text/html"
15        '.Priority = 1  '重要级别
16        .Logging = True '为 True,可用 JmailMsg.Log 获得与服务器交互的详细日志信息
17        .Silent = True '为 True,出错时会有 JmailMsg.ErrorMessage 回送消息
18        .Subject = Subject
19        '.Body = HtmlBody    '作为纯文本内容发送,设置 Body 属性
20        .HtmlBody = HtmlBody '用这个可以发送 Html 内容
21
22        .AddAttachment "c:\users.ctl"  '发送附件
23
24        If .Send("mail.2911.net") Then '指定邮件服务器
25            JmailSend = "发送成功"
26        Else
27            JmailSend = JmailMsg.ErrorMessage
28        End If
29        MsgBox JmailMsg.Log
30        .Close
31    End With
32    Set JmailMsg = Nothing
33End 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's Blog
[版权声明] 本文采用 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0) 进行许可。