VB:收發電子郵件
成都創新互聯公司是一家朝氣蓬勃的網站建設公司。公司專注于為企業提供信息化建設解決方案。從事網站開發,網站制作,網站設計,網站模板,微信公眾號開發,軟件開發,微信小程序,十年建站對紙箱等多個行業,擁有豐富設計經驗。
發送和接收電子郵件,對于某些執行特殊任務的應用程序而言,是一個十分有用的功能。例如,一個監視網絡服務器資源使用情況的工具軟件,如果它具有自動發送電子郵件的功能,那么當它發現服務器的資源使用已經接近事先設定的臨界狀態時,便可以向系統管理員發送一封告警的電子郵件,從而使系統管理員能夠及時地采取措施,以避免重大事故的出現。在Visual Basic中,應用程序可以通過調用微軟公司的MAPI(Messaging Application Programming Interface,消息應用程序編程接口),實現收發電子郵件的功能。筆者將在本文中結合簡單實例,向大家介紹在VB程序中實現電子郵件收發功能的編程方法。
編制具有收發電子郵件功能的VB程序,必須使用Visual Basic 4.0以上的版本,因為只有4.0以上的Visual Basic才帶有兩個實現電子郵件收發功能的核心控件:MAPI會話控件和MAPI消息控件。MAPI會話控件用于建立和控制一個Microsoft Mail會話,MAPI消息控件用于創建和收發郵件消息。此外,程序必須運行在采用遵從MAPI的消息系統(如:Microsoft Exchange、Microsoft Mail、Outlook等)的環境中。
在開始編程之前,首先需要將MAPI控件加入VB工具箱。具體操作是:在VB菜單欄中選擇Tools菜單項中的Custom Controls命令,調出"Custom Controls"對話框,在其中的"Available Controls"列表框中選中"Microsoft MAPI Controls"表項,然后按"OK"命令按鈕退出該對話框。此后,工具箱中將新添兩個圖標,這就是MAPI會話控件和MAPI消息控件的圖標。
下面,筆者將以兩個簡單的VB程序為例,分別介紹發送郵件和接收郵件的程序編制方法。
郵件發送程序
郵件發送程序的基本處理過程是:根據用戶輸入信息組成郵件,然后使用MAPI消息控件的Send方法將郵件發出。編程步驟如下:
1、新建一個VB項目。
2、將缺省窗體Form1的Caption屬性設置為"發送郵件"。
3、將MAPI控件加入VB工具框。
4、在Form1中加入一個MAPI會話控件MAPISession1和一個MAPI消息控件MAPIMessages1。
5、在Form1中加入三個文本框控件,將它們的Name屬性分別設置為txtSendTo、txtSubject、txtMessage,并將txtMessage的Multiline屬性設置為True。這三個文本框控件將分別用于填寫郵件的收件人、主題和內容。
6、在Form1中加入三個標簽控件,將它們的Caption屬性分別設置為"收件人"、"主題"和"內容",并將它們放在合適的位置用以標注相應的文本框控件。
7、在Form1中加入一個命令按鈕控件,將其Caption屬性和Name屬性分別設置為"發送"和"cmdSend"。
8、將下列代碼加入Form1的Form_Load事件:
Private Sub Form_Load()
MAPISession1.SignOn
End Sub
9、將下列代碼加入Form1的Form_Unload事件:
Private Sub Form_Unload(Cancel As Integer)
MAPISession1.SignOff
End Sub
10、將下列代碼加入cmdSend的Click事件:
Private Sub cmdSend_Click()
With MAPIMessages1
.MsgIndex = -1
.RecipDisplayName = txtSendTo.Text
.MsgSubject = txtSubject.Text
.MsgNoteText = txtMessage.Text
.SessionID = MAPISession1.SessionID
.Send
End With
MsgBox "郵件發送完畢!", , "發送郵件"
End Sub
在填寫完郵件的收件人、主題和內容后,按"發送"命令按鈕,如果沒有出現運行時錯誤提示,那么就表明郵件已經成功地發往目的地了,否則,請檢查填寫的收件人地址是否準確無誤以及系統中運行的消息系統工作是否正常。
郵件接收程序
郵件接收程序比郵件發送程序稍微復雜一些。首先需要使用MAPI消息控件的Fetch方法讀取郵件,這個過程將把用戶收件箱中所有未讀郵件全部裝入MAPI消息控件中。然后,檢查MAPI消息控件的MsgCount屬性以確定通過Fetch方法讀取的郵件的總數。接著,可以通過設置MAPI消息控件的MsgIndex屬性來指定具體需要處理哪一封郵件。需要說明的是,MsgIndex屬性值的計數是從0開始的,也就是說,第一封郵件的索引號是0,第二封郵件的索引號是1,依次類推。編程步驟如下:
1、新建一個VB項目。
2、將缺省窗體Form1的Caption屬性設置為"接收郵件"。
3、將MAPI控件加入VB工具框。
4、在Form1中加入一個MAPI會話控件MAPISession1和一個MAPI消息控件MAPIMessages1。
5、在Form1中加入三個標簽控件和一個文本框控件,將三個標簽控件的Name屬性分別設置為lblMsgDateReceived、lblMsgOrigDisplayName、lblMsgSubject,將文本框控件的Name屬性設置為txtMsgNoteText,并將標簽控件的Caption屬性和文本框控件的Text屬性的內容清空。這四個控件將分別用于顯示郵件的日期、發件人、主題和內容。
6、將txtMsgNoteText控件的Locked屬性和Multiline屬性設置為True,ScrollBars屬性設置為2 - Vertical。
7、在Form1中再加入四個標簽控件用于標注上述四個控件,將它們的Caption屬性分別設置為"日期"、"發件人"、"主題"、"內容"。
8、在Form1中加入一個標簽控件,將其Name屬性設置為lblMsgCount,Caption屬性設置為"第 0 封郵件,總計 0 封郵件"。該控件用于顯示接收的郵件總數以及當前正在處理第幾封郵件。
9、在Form1中加入三個命令按鈕控件,將它們的Name屬性分別設置為cmdPrevious、cmdNext、cmdClose,Caption屬性分別設置為"上一封"、"下一封"、"關閉"。
10、編寫一個窗體級子例程FetchNewMail:
Public Sub FetchNewMail()
MAPIMessages1.FetchUnreadOnly = True
MAPIMessages1.Fetch
End Sub
11、編寫一個窗體級子例程DisplayMessage:
Public Sub DisplayMessage()
lblMsgCount.Caption = "第 " _
LTrim(Str(MAPIMessages1.MsgIndex + 1)) " 封郵件,總計 " _
LTrim(Str(MAPIMessages1.MsgCount)) " 封郵件"
lblMsgDateReceived.Caption = MAPIMessages1.MsgDateReceived
txtMsgNoteText.Text = MAPIMessages1.MsgNoteText
lblMsgOrigDisplayName.Caption = MAPIMessages1.MsgOrigDisplayName
lblMsgSubject.Caption = MAPIMessages1.MsgSubject
End Sub
12、將下列代碼加入Form1的Form_Load事件:
Private Sub Form_Load()
MAPISession1.SignOn
MAPIMessages1.SessionID = MAPISession1.SessionID
FetchNewMail
DisplayMessage
End Sub
13、將下列代碼加入cmdPrevious的Click事件:
Private Sub cmdPrevious_Click()
If MAPIMessages1.MsgIndex 0 Then
MAPIMessages1.MsgIndex = MAPIMessages1.MsgIndex - 1
DisplayMessage
Else
Beep
End If
End Sub
14、將下列代碼加入cmdNext的Click事件:
Private Sub cmdNext_Click()
If MAPIMessages1.MsgIndex MAPIMessages1.MsgCount - 1 Then
MAPIMessages1.MsgIndex = MAPIMessages1.MsgIndex + 1
DisplayMessage
Else
Beep
End If
End Sub
15、將下列代碼加入cmdClose的Click事件:
Private Sub cmdClose_Click()
Unload Me
End Sub
在窗體加載過程中,窗體Load事件中的代碼會讀取新郵件,如果有新郵件,就顯示第一個新郵件。如果有多個新郵件,則可以使用"上一封"和"下一封"命令按鈕前后翻閱。
接收郵件
本例是讀取用戶收件箱中所有未讀郵件,如果要讀取收件箱中所有的郵件,那么只需在執行Fetch方法之前,將MAPI消息控件的FetchUnreadOnly屬性設置為False。具體接收的郵件是否已經讀過,可以通過MsgRead屬性來判別。如果郵件的正文或附件曾經被瀏覽過,那么該郵件就會自動標記為已讀,不過只瀏覽郵件的主題不會標記該郵件已讀。
郵件附件
與處理郵件的方式一樣,MAPI也為郵件的附件提供了一個計數器和一個索引。在處理收到的郵件時,可以通過檢查AttachmentCount屬性來確定該郵件攜帶了多少個附件,然后可以通過設置AttachmentIndex屬性依次處理每一個附件。
AttachmentIndex的合法取值范圍為0至AttachmentIndex-1。在設置了AttachmentIndex屬性值后,可以讀取附件的下列屬性:
AttachmentName:當附件是一個文件時,該屬性用于指定文件的名稱。當附件是一個OLE對象時,該屬性用于指定對象的類型。
AttachmentPath:該屬性用于指定做為附件的文件的全路徑名。
AttchmentPosition:該屬性用于指定附件在郵件內容部分中的位置。當郵件收發程序顯示郵件內容時,將使用該屬性提供的信息把附件的標志放在合適的位置。
AttachmentType:該屬性用于指定附件的類型,其合法取值為三個整數型數值,在VB中分別由下列常量表示:
·mapData-附件是一個數據文件
·mapEOLE-附件是一個嵌入式OLE對象
·mapSOLE-附件是一個靜態OLE對象
發送郵件時,上述屬性的使用方法與接收郵件時相同,只不過由讀操作改為寫操作了。值得一提的是AttachmentIndex屬性,發送郵件時可以將其設置為任意值。而AttachmentCount屬性則會自動設置為正確的值,無需人為設置。
小結
通過分析上述兩個程序的代碼,可以歸納出具有收發電子郵件功能的VB程序的基本流程如下:
1、使用MAPI會話控件建立一個郵件會話。
2、使用MAPI消息控件進行郵件的處理工作。
3、再次使用MAPI會話控件釋放郵件會話。
由于上述兩個VB程序只是簡單的示例,因而略去了一些與本文主題關系不大的細節,如錯誤處理等。在編制實用程序時,為了保證程序的可靠性,應該考慮加入這些細節部分。
抄個自己的回答:
建議你去看阿江翻譯的JMAIL開發文檔:
把這幾個對象看一下:
POP3。MESSAGES,MESSAGE,ATTS,ATT
過程:
1。先用POP3對象連接郵件服務(當然你郵箱要開POP設置)并接受到MESSAGES
2。取到MESSAGES后,輪循到MESSAGE對象后。
3。對MESSAGE解析,得到郵件標題,內容,收發人,
4。如果有附件還要對ATTS對象輪循并解析(可以把附件存在本地或寫鏈接)
MESSAGES是信件集
MESSAGE是單封信件
ATTS是附件集
ATT是單個附件
————————————————————————
發信分割線
————————————————————————
拿個別人的回答改了一下,俺VB幾乎沒用過,只會VB。NET
先注冊DLL
然后VB代碼如下:
Private Sub Command1_Click()
SendMail "標題", "正文"
End Sub
Sub SendMail(Optional ByVal sSubject As String, _
Optional ByVal sBody As String)
Dim jmail
Set jmail = CreateObject("jmail.Message")
jmail.Charset = "gb2312"
jmail.Silent = False
jmail.Priority = 1 '郵件狀態,1-5 1為最高
jmail.MailServerUserName = "XXX" 'Email帳號
jmail.MailServerPassWord = "XXX" 'Email密碼
jmail.FromName = "XXX" '發信人姓名
jmail.From = "XXX@XXX.XXXX" '發郵件地址地址
jmail.Subject = sSubject '主題
jmail.AddRecipient "XXX@XXX.XXXX" '收信人地址
jmail.body = sBody '信件正文
jmail.Send ("smtp.163.com") 'SMTP服務器,如smtp.sohu.com
Set jmail = Nothing
End Sub
全了。FromName 和FROM 建議都用郵件地址,不然有的郵箱不收的
'創建發件連接,根據你的發送郵箱的SMTP設置填充
Dim smtp As New System.Net.Mail.SmtpClient("smtp.163.com", 25)
'發件郵箱身份驗證,參數分別為 發件郵箱登錄名和密碼
smtp.Credentials = New System.Net.NetworkCredential("用戶名", "密碼")
'創建郵件
Dim mail As New System.Net.Mail.MailMessage()
'郵件主題
mail.Subject = "郵件主題"
'主題編碼
mail.SubjectEncoding = System.Text.Encoding.GetEncoding("GB2312")
'郵件正文件編碼
mail.BodyEncoding = System.Text.Encoding.GetEncoding("GB2312")
'發件人郵箱
mail.From = New System.Net.Mail.MailAddress("example@163.com")
'郵件優先級
mail.Priority = System.Net.Mail.MailPriority.Normal
'HTML格式的郵件,為false則發送純文本郵箱
mail.IsBodyHtml = True
'郵件內容
mail.Body = "郵件正文內容"
'添加收件人,如果有多個,可以多次添加
mail.To.Add("收件人地址")
'定義附件,參數為附件文件名,包含路徑,推薦使用絕對路徑
'如果不需要附件,下面三行可以不要
Dim a As New System.Net.Mail.Attachment("附件文件")
'附件文件名,用于收件人收到附件時顯示的名稱
a.Name = "附件文件名"
'加入附件,可以多次添加
mail.Attachments.Add(a)
'發送郵件
Try
smtp.Send(mail)
MessageBox.Show("發送成功")
Catch
MessageBox.Show("發送失敗")
Finally
mail.Dispose()
End Try
可以明確告訴你,不用控件是辦不到的,不過使用的控件也很簡單,只需要
MAPI會話控件MAPISession1和一個MAPI消息控件MAPIMessages1,不用一個小時就可以學會了
我只有ACCESS的VBA代碼供你參考,vba與vb很多代碼是可以共用的,你不妨參與研究下:
ACCESS發送郵件代碼
access 2009-02-11 16:41 閱讀23 評論0 字號: 大大 中中 小小 Private Sub Command1_Click() '發送郵件,依據ACCESS開發答疑200問P226頁
'首先,確保已經安裝了OutLook,然后在引用中引用Microsoft OutLook對象,在輸入以下代碼就可實現創建一個新郵件,并添加一個附件到郵件中,然后發送郵件的功能。
'通過引用OutLook.Application對象,Access可以循環OutLook對象里面的所有內容,例如可以讀取OutLook里的所有郵件、聯系人、約會、日記等信息,還可修改OutLook內置的“規則精靈”
'的內容。
Dim myOlApp As Object
Dim myNamespace As Object
Set myOlApp = CreateObject("OutLook.Application") '創建OutLook應用程序對象
Set myNamespace = myOlApp.getNamespace("MAPI") '獲取MAPI命名空間
Set myFolder = myNamespace.getDefaultFolder(6) '獲取默認的文件夾
Set myitem = myOlApp.CreateItem(0) '創建新郵件
myitem.Display
Set myRecipient = myitem.Recipients.Add("rcylbx@21cn.com") '為郵件添加收件人
myRecipient.Type = 1
myitem.Subject = "test" '設置郵件主題
MsgBox "ok"
myitem.Attachments.Add ("d:\test.txt") '添加郵件附件,注意確保硬盤下有這個文件
myitem.Save
myitem.Send
MsgBox "ok"
End Sub
Private Sub Command2_Click()
'代碼說明:
'本代碼可以在安裝了outlook(2000以上版本的)的機器上運行。不過outlook xp 以上
'的版本由于出于防止郵件病毒的目的,對發送郵件進行監控,運用本程序每發送一封
'email都需要用戶確認,會有點麻煩,但是還是出于安全的角度考慮。
'可以將這段代碼嵌入access的模塊?excel的宏中運行?
'程序要求:
'需要引用 "microsoft outlook x.x library"
'代碼:
Dim olkapp As Outlook.Application '在使用outlook之前必須先聲明outlook應用程序的對象,應用程序
Dim newmail As MailItem '在使用outlook之前必須先聲明outlook應用程序的對象,郵件項目對象
Dim emailadd, para As String
Set olkapp = CreateObject("outlook.application") '指定outlook應用程序的實體變量
Set newmail = olkapp.CreateItem(olMailItem) '指定郵件項目的實體變量
'郵件正文內容
para = para + "祝新春快樂,并友情提醒注意新的郵件病毒。"
'收件人的email地址,這里沒有輸入內容。
emailadd = "rcylbx@21cn.com"
With newmail
.To = emailadd '發送郵件地址
.Subject = "新春快樂" ' 郵件的主題
.Importance = olImportanceHigh '郵件的為重要等級
.Body = para '將郵件正文內容指定para變量內容
'.Send '發送
.Display '啟動視窗
End With
On Error GoTo continue
SendEmail:
newmail.Display
DoEvents
SendKeys "%s", Wait:=True
DoEvents
AppActivate newmail
GoTo SendEmail '發送不成功誓不罷休
continue:
On Error GoTo 0
Set olkapp = Nothing
Set newmail = Nothing
End Sub
Sub email_send()
Dim olkapp As Outlook.Application
Dim newmail As MailItem
Dim emailadd, para As String
Set olkapp = CreateObject("outlook.application")
Set newmail = olkapp.CreateItem(olMailItem)
'郵件正文內容
para = para + "祝新春快樂,并友情提醒注意新的郵件病毒。"
'收件人的email地址,這里沒有輸入內容。
emailadd = ""
With newmail
.To = emailadd
.Subject = "新春快樂" ' 郵件的主題
.Importance = olImportanceHigh '郵件的為重要等級
.Body = para '將郵件正文內容指定para變量內容
.Send '發送
End With
End Sub
Private Sub Command3_Click()
'方法一是用代碼模擬發送郵件確認 (代碼引用論壇前輩的代碼)
Dim objOL As Object
Dim itmNewMail As Object
'引用Microsoft Outlook 物件模型
Set objOL = CreateObject("Outlook.Application")
Set itmNewMail = objOL.CreateItem(olMailItem)
With itmNewMail
.Subject = "chijanzen Mail Test" '主旨
.Body = "發送郵件測試2222" '本文
.To = "rcylbx@21cnl.com" '收件者
.Attachments.Add "d:\test.txt", olByValue, 1, "4th Quarter 1996 Results Chart"
.Display '啟動視窗
End With
On Error GoTo continue
SendEmail:
AppActivate itmNewMail
DoEvents
SendKeys "%s", Wait:=True
DoEvents
AppActivate itmNewMail
GoTo SendEmail '發送不成功誓不罷休
continue:
On Error GoTo 0
Set objOL = Nothing
Set itmNewMail = Nothing
'再次測試中發現,窗口標題為中文時,AppActivate命令不能執行。將AppActivate命令改為Display方法,可解決此問題,即將AppActivate itmNewMail改為itmNewMail.display。
End Sub
'方法一是用代碼模擬發送郵件確認 (代碼引用論壇前輩的代碼)
Sub SendMail()
Dim objOL As Object
Dim itmNewMail As Object
'引用Microsoft Outlook 物件模型
Set objOL = CreateObject("Outlook.Application")
Set itmNewMail = objOL.CreateItem(olMailItem)
With itmNewMail
.Subject = "chijanzen Mail Test" '主旨
.Body = Application.UserName "發送郵件測試2222" '本文
.To = "171262953@qq.com" '收件者
.Attachments.Add "C:\PDOS.DEF", olByValue, 1, "4th Quarter 1996 Results Chart"
.Display '啟動視窗
End With
On Error GoTo continue
SendEmail:
AppActivate itmNewMail
DoEvents
SendKeys "%s", Wait:=True
DoEvents
AppActivate itmNewMail
GoTo SendEmail '發送不成功誓不罷休
continue:
On Error GoTo 0
Set objOL = Nothing
Set itmNewMail = Nothing
End Sub
'再次測試中發現,窗口標題為中文時,AppActivate命令不能執行。將AppActivate命令改為Display方法,可解決此問題,即將AppActivate itmNewMail改為itmNewMail.display。
**************************************
***************************************
Sub Send_Order_Mail()
Dim cnn As ADODB.Connection
Dim rst_cusid, rst_order_list As ADODB.Recordset
Dim olkapp As Outlook.Application
Dim newmail As MailItem
Set olkapp = CreateObject("outlook.application")
Set cnn = New ADODB.Connection
cnn.Open CurrentProject.Connection
Set rst_cusid = New ADODB.Recordset
rst_cusid.Open "select distinct CustomerID,CompanyName,Email from v_order_list", cnn, adOpenKeyset, adLockReadOnly
If rst_cusid.RecordCount 1 Then Exit Sub
Set rst_order_list = New ADODB.Recordset
For i = 1 To rst_cusid.RecordCount
rst_order_list.Open "select * from v_order_list where CustomerID = " + "'" + rst_cusid.Fields(0) + "'", cnn, adOpenKeyset, adLockReadOnly
With rst_order_list
para = "Dear " + .Fields(1) + ":" + Chr(10)
para = para + Space(3) + "Your Company " + .Fields(0) + " has Order those Good:" + Chr(10)
For j = 1 To .RecordCount
para = para + Space(3) + "Good Name :" + .Fields(2) + " Order Date :" + CStr(.Fields(3)) + " Price:" + CStr(.Fields(4)) + Chr(10)
Next
End With
rst_order_list.Close
para = para + Space(30) + "Yours Loadhigh" 'para為信件內容
Set newmail = olkapp.CreateItem(olMailItem)
With newmail
.To = rst_cusid.Fields(2) '接收郵件的信箱
.Subject = rst_cusid.Fields(1) + " Order List" '信件標題
.Body = para
.Send '發送
End With
rst_cusid.MoveNext
para = ""
Next
rst_cusid.Close
Set rst_cusid = Nothing
Set rst_order_list = Nothing
cnn.Close
Set cnn = Nothing
End Sub
***********************************************************
Function test1()
Dim objMail As MailItem
Dim objAttachments As Attachment
Dim App As New Outlook.Application
Set objMail = App.CreateItem(olMailItem)
objMail.Save
Set objAttachments = objMail.Attachments.Add("c:\temp\a.xls", olByValue, 1, "a.xls")
With objMail
.To = "chenge@shtip.com.cn" '接收郵件的信箱
.Subject = "test" '信件標題
.Body = "test"
.Send '發送
End With
'objMail.Display
End Function
*********************************************************
VBScript code
Set Msg =
CreateObject("CDO.Message")
With Msg
.To = "someone@microsoft.com"
.From = "userX@microsoft.com"
.Subject = "Lunch meeting"
.TextBody = "I have attached the suggested menu."
.AddAttachment ""
.Send
End With
另,若因發垃圾郵件被163.com封賬號,可以聯系客服解釋是電腦中了病毒。
在Identity2.0里面封裝了IIdentityMessageService接口,可以用來發送接收郵件。
看看
Imports System.Threading.Tasks
Imports System.Security.Claims
Imports Microsoft.AspNet.Identity
Imports Microsoft.AspNet.Identity.EntityFramework
Imports Microsoft.AspNet.Identity.Owin
Imports Microsoft.Owin
Imports Microsoft.Owin.Security
public function SendAsync(message as IdentityMessage) as task
dim credentialUserName = "郵箱登錄名"
dim sentFrom = "你的郵箱地址"
dim pwd= "郵箱登錄密碼";
dim client as new System.Net.Mail.SmtpClient("smtp服務器地址")
client.Port = 25'mtp郵件服務器端口
client.DeliveryMethod = System.Net.Mail.SmtpDeliveryMethod.Network
client.UseDefaultCredentials = false
dim credentials as new System.Net.NetworkCredential(credentialUserName, pwd)
client.EnableSsl = true
client.Credentials = credentials
dim mail as new System.Net.Mail.MailMessage(sentFrom, message.Destination)
mail.Subject = message.Subject
mail.Body = message.Body
return client.SendMailAsync(mail)
end function
分享題目:vb.net如何收郵件 vbs發送郵件帶附件
文章地址:http://newbst.com/article30/docpopo.html
成都網站建設公司_創新互聯,為您提供標簽優化、網站導航、定制開發、電子商務、用戶體驗、微信小程序
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯