e-mail utilizzando Access e VBA, senza MAPI
-
12-09-2019 - |
Domanda
Vorrei inviare e-mail da Microsoft Access automatica utilizzando VBA. Capisco che il metodo “InviaOggetto” built-in utilizza istruzioni di sicurezza significato MAPI e qualcosa come Outlook configurato. Dal momento che voglio utilizzare l'utilità di pianificazione per dare il via diverse relazioni, mi sono appoggiato da MAPI e preferirei qualche altra soluzione. Non una domanda di spedizione, ma solo in-house. Idee?
Soluzione
È necessario un server SMTP che permetterà di inviare e-mail. Allora avete bisogno di utilizzare l'oggetto CDO messaggio.
Altri suggerimenti
Ecco il codice di prova che ha funzionato per me con CDO e Gmail.
Sub mtest()
Dim cdoConfig
Dim msgOne
Set cdoConfig = CreateObject("CDO.Configuration")
With cdoConfig.Fields
.Item("http://schemas.microsoft.com/cdo/configuration/sendusing") = 2
.Item("http://schemas.microsoft.com/cdo/configuration/smtpserver") = 465
.Item("http://schemas.microsoft.com/cdo/configuration/smtpserver") = "smtp.gmail.com"
.Item("http://schemas.microsoft.com/cdo/configuration/sendusername") = "gmailname"
.Item("http://schemas.microsoft.com/cdo/configuration/sendpassword") = "yourpw"
.Item("http://schemas.microsoft.com/cdo/configuration/smtpusessl") = True
.Item("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate") = 1
.Update
End With
Set msgOne = CreateObject("CDO.Message")
Set msgOne.Configuration = cdoConfig
msgOne.To = "target@target.com"
msgOne.From = "I@dontThinkThisIsUsed.com"
msgOne.Subject = "Test email"
msgOne.TextBody = "It works just fine"
msgOne.send
End Sub
Si potrebbe trovare di Tony Toews accesso e-mail FAQ a portata di mano.
Lo faccio in questo modo, nota, è necessario che Outlook installato per farlo funzionare.
Sub btnSendEmail_Click()
Dim OutApp As Object
Dim OutMail As Object
Application.ScreenUpdating = False
Set OutApp = CreateObject("Outlook.Application")
OutApp.Session.Logon
strBody = "<html><head></head><body>"
strBody = strBody & "Your message goes here"
strBody = strBody & "</body></html>"
Set OutMail = OutApp.CreateItem(0)
OutMail.To = "name@example.com"
OutMail.BCC = "bcc@example.com"
OutMail.Subject = "Test message"
OutMail.HTMLBody = strBody
OutMail.Send 'Send | Display
Set OutMail = Nothing
End Sub
Redemption Outlook è gratuito e molto diffuso: http://www.dimastr.com/redemption/
E 'molto molto vicino al modello a oggetti di Outlook originale, in modo che la curva di apprendimento è la torta:)