下面是Winsock的DataArrival事件中的代码。该代码的绝大部分是注释以向你解释程序所做的每一步。如果你觉得闷的话就跳过不看就是了。
Private Sub Winsock1_DataArrival(ByVal bytesTotal As Long)
Dim strData As String
Static intMessages As Integer '要下载的消息数(也就是邮件数) Static intCurrentMessage As Integer '已下载的消息数 Static strBuffer As String '正在下载的消息的缓冲
将收到的数据存放在strData变量中 Winsock1.GetData strData
If Left$(strData, 1) = "+" Or m_State = POP3_RETR Then '如果来自服务器的回应的第一个字符为加号 '表明服务器已收到你发出的命令并等待下一个命令 '如果服务器返回的字符串的第一个字符为减号,那我们在这里就什么也做不了。 '操作被转到ELSE后面部分的代码。 '当处于数据接收状态时,来自服务器的字符串的第一个字符就可能不是加号或减号,所以要用到第二个条件 'm_State = POP3_RETR (正在接收消息的状态) Select Case m_State Case POP3_Connect ' '重置消息数 intMessages = 0 ' '改变进程状态 m_State = POP3_USER ' '向服务器发出带参数的USER命令 '参数是信箱名 '别忘了在命令的最后加上vbCrLf Winsock1.SendData "USER " & txtUserName & vbCrLf '这是本次事件的结束,下次开始跳过上一部分,而从下面开始执行 ' Case POP3_USER部分 Case POP3_USER
'如果用户名检查通过就进行下一部分 '现在向服务器发送你的密码
'改变进程的状态 m_State = POP3_PASS ' '向服务器发送PASS命令,以你的密码为参数 Winsock1.SendData "PASS " & txtPassword & vbCrLf Case POP3_PASS ' '如果服务器通过了你的身份验证,我们就可以向服务器发送STAT命令了 '作为对STAT的回应,服务器会传回你邮箱中的消息数及大小 ' '改变当前进程的状态 m_State = POP3_STAT ' '现在发送STAT命令 Winsock1.SendData "STAT" & vbCrLf Case POP3_STAT ' '服务器对STAT的回应看上去象这样 '"+OK 0 0" (邮箱中没有邮件)或 "+OK 3 7564" '(邮箱中有邮件).显然,我们必须找到来自服务器返回的字符串中的第一个数字
intMessages = CInt(Mid$(strData, 5, InStr(5, strData, " ") - 5)) If intMessages > 0 Then ' '如果邮箱中有邮件 '改变进程的状态 m_State = POP3_RETR ' intCurrentMessage = intCurrentMessage + 1 ' '现在准备向服务器发送RETR命令 '以便接收第一条消息 Winsock1.SendData "RETR 1" & vbCrLf Else '如果邮箱中没有邮件就断开同服务器的连接结束进程
m_State = POP3_QUIT Winsock1.SendData "QUIT" & vbCrLf MsgBox "You have not mail.", vbInformation End If Case POP3_RETR '在接收邮件时执行下面执行下面的代码 '邮件可能会很大,并触发多次DataArrival事件 '接收到的数据被存放在 strBuffer变量中 strBuffer = strBuffer & strData ' '用下面的语句判断消息的结束 '邮件是以小数点结尾的 If InStr(1, strBuffer, vbLf & "." & vbCrLf) Then ' '邮件下载完毕 ' '删除由服务器返回的第一行字符串 strBuffer=Mid$(strBuffer, InStr(1, strBuffer, vbCrLf)+2) ' '删除最后一个只有小数点的字符 strBuffer = Left$(strBuffer, Len(strBuffer) - 3) ' '把消息存放在m_colMessages集合中 Set m_oMessage = New CMessage m_oMessage.CreateFromText strBuffer m_colMessages.Add m_oMessage, m_oMessage.MessageID Set m_oMessage = Nothing ' '清空缓冲,准备接收下一条邮件 strBuffer = "" ' '将已收的邮件数同服务器目前的邮件数作比较 If intCurrentMessage = intMessages Then '如果相等,表示已接收完所有的邮件 '所以发送一个QUIT命令给服务器 m_State = POP3_QUIT Winsock1.SendData "QUIT" & vbCrLf Else '如果二者不等,表明还有邮件没有接收
intCurrentMessage = intCurrentMessage + 1 ' '改变当前进程的状态 m_State = POP3_RETR ' '向服务器发出RETR命令接收下一个邮件 Winsock1.SendData "RETR " & CStr(intCurrentMessage) & vbCrLf End If End If Case POP3_QUIT '不管我们收到什么样的邮件,记得关闭同服务器的连接 Winsock1.Close '现在调用 ListMessages子程序,以便在ListView中显示收到的邮件 Call ListMessages End Select Else '下面的错误处理的代码 '只须关闭socket并将来自服务器的回应显示出来就行了。 '即使是那些高级的邮件接收程序所做也不外如此 Winsock1.Close MsgBox "POP3 Error: " & strData, _ vbExclamation, "POP3 Error" End If
End Sub
一切看上去都一目了然,除了下面的语句:
Set m_oMessage = New CMessage m_oMessage.CreateFromText strBuffer m_colMessages.Add m_oMessage, m_oMessage.MessageID Set m_oMessage = Nothing 
2/2 首页 上一页 1 2 |