Sending Outlook Email with embedded image using VBS

后端 未结 2 2036
慢半拍i
慢半拍i 2020-12-11 07:24

I am currently using the following VBS script to send an email and it works fine, however the image is sent as an attachment. I would instead like to embed the image into t

2条回答
  •  轮回少年
    2020-12-11 08:19

    use the code below

    Const PR_ATTACH_MIME_TAG = "http://schemas.microsoft.com/mapi/proptag/0x370E001E"
    Const PR_ATTACH_CONTENT_ID = "http://schemas.microsoft.com/mapi/proptag/0x3712001E"
    Const PR_ATTACHMENT_HIDDEN = "http://schemas.microsoft.com/mapi/proptag/0x7FFE000B"
    
    
    Sub testing2()
    Dim ToAddress
    Dim FromAddress
    Dim MessageSubject
    Dim MyTime
    Dim MessageBody
    Dim MessageAttachment
    Dim ol, ns, newMail
    Dim realAttachment
    MyTime = Now
    
    ToAddress = "testing@address.com"
    MessageSubject = "Auto Stats " & MyTime
    MessageBody = "Stats Attached" & vbCrLf & "Produced at " & MyTime
    MessageAttachment = "C:\Users\Public\Pictures\Sample Pictures\Penguins.jpg"
    Set ns = Outlook.GetNamespace("MAPI")
    Set newMail = Outlook.CreateItem(olMailItem)
    newMail.Subject = MessageSubject
    newMail.Body = MessageBody
    newMail.Recipients.Add (ToAddress)
    Set realAttachment = newMail.Attachments.Add(MessageAttachment)
    Set oPA = realAttachment.PropertyAccessor
    oPA.SetProperty PR_ATTACH_MIME_TAG, "image/jpeg"
    oPA.SetProperty PR_ATTACH_CONTENT_ID, "myident" 'change myident for another other image
    newMail.HTMLBody = newMail.HTMLBody & "" 'need to match the "myident" above
    newMail.Send
    End Sub
    

    Hope it helps

提交回复
热议问题