VB邮件检查程序(二)

2016-02-19 21:09 7 1 收藏

生活已是百般艰难,为何不努力一点。下面图老师就给大家分享VB邮件检查程序(二),希望可以让热爱学习的朋友们体会到设计的小小的乐趣。

【 tulaoshi.com - 编程语言 】

下面是Winsock的DataArrival事件中的代码。该代码的绝大部分是注释以向你解释程序所做的每一步。如果你觉得闷的话就跳过不看就是了。
  
  PrivateSubWinsock1_DataArrival(ByValbytesTotalAsLong)
  
  DimstrDataAsString
  
  StaticintMessagesAsInteger'要下载的消息数(也就是邮件数)
  StaticintCurrentMessageAsInteger'已下载的消息数
  StaticstrBufferAsString'正在下载的消息的缓冲
  
  将收到的数据存放在strData变量中
  Winsock1.GetDatastrData
  
  IfLeft$(strData,1)=" "Orm_State=POP3_RETRThen
  '如果来自服务器的回应的第一个字符为加号
  '表明服务器已收到你发出的命令并等待下一个命令
  '如果服务器返回的字符串的第一个字符为减号,那我们在这里就什么也做不了。
  '操作被转到ELSE后面部分的代码。
  '当处于数据接收状态时,来自服务器的字符串的第一个字符就可能不是加号或减号,所以要用到第二个条件
  'm_State=POP3_RETR(正在接收消息的状态)
  SelectCasem_State
  CasePOP3_Connect
  '
  '重置消息数
  intMessages=0
  '
  '改变进程状态
  m_State=POP3_USER
  '
  '向服务器发出带参数的USER命令
  '参数是信箱名
  '别忘了在命令的最后加上vbCrLf
  Winsock1.SendData"USER"&txtUserName&vbCrLf
  '这是本次事件的结束,下次开始跳过上一部分,而从下面开始执行
  'CasePOP3_USER部分
  CasePOP3_USER
  
  '如果用户名检查通过就进行下一部分
  '现在向服务器发送你的密码
  
  '改变进程的状态
  m_State=POP3_PASS
  '
  '向服务器发送PASS命令,以你的密码为参数
  Winsock1.SendData"PASS"&txtPassword&vbCrLf
  CasePOP3_PASS
  '
  '如果服务器通过了你的身份验证,我们就可以向服务器发送STAT命令了
  '作为对STAT的回应,服务器会传回你邮箱中的消息数及大小
  '
  '改变当前进程的状态
  m_State=POP3_STAT
  '
  '现在发送STAT命令
  Winsock1.SendData"STAT"&vbCrLf
  CasePOP3_STAT
  '
  '服务器对STAT的回应看上去象这样
  '" OK00"(邮箱中没有邮件)或" OK37564"
  '(邮箱中有邮件).显然,我们必须找到来自服务器返回的字符串中的第一个数字
  
  intMessages=CInt(Mid$(strData,5,InStr(5,strData,"")-5))
  IfintMessages0Then
  '
  '如果邮箱中有邮件
  '改变进程的状态
  m_State=POP3_RETR
  '
  intCurrentMessage=intCurrentMessage 1
  '
  '现在准备向服务器发送RETR命令
  '以便接收第一条消息
  Winsock1.SendData"RETR1"&vbCrLf
  Else
  '如果邮箱中没有邮件就断开同服务器的连接结束进程
  
  m_State=POP3_QUIT
  Winsock1.SendData"QUIT"&vbCrLf
  MsgBox"Youhavenotmail.",vbInformation
  EndIf
  CasePOP3_RETR
  '在接收邮件时执行下面执行下面的代码
  '邮件可能会很大,并触发多次DataArrival事件
  '接收到的数据被存放在strBuffer变量中
  strBuffer=strBuffer&strData
  '
  '用下面的语句判断消息的结束
  '邮件是以小数点结尾的
  IfInStr(1,strBuffer,vbLf&"."&vbCrLf)Then
  '
  '邮件下载完毕
  '
  '删除由服务器返回的第一行字符串
  strBuffer=Mid$(strBuffer,InStr(1,strBuffer,vbCrLf) 2)
  '
  '删除最后一个只有小数点的字符
  strBuffer=Left$(strBuffer,Len(strBuffer)-3)
  '
  '把消息存放在m_colMessages集合中
  Setm_oMessage=NewCMessage
  m_oMessage.CreateFromTextstrBuffer
  m_colMessages.Addm_oMessage,m_oMessage.MessageID
  Setm_oMessage=Nothing
  '
  '清空缓冲,准备接收下一条邮件
  strBuffer=""
  '
  '将已收的邮件数同服务器目前的邮件数作比较
  IfintCurrentMessage=intMessagesThen
  '如果相等,表示已接收完所有的邮件
  '所以发送一个QUIT命令给服务器
  m_State=POP3_QUIT
  Winsock1.SendData"QUIT"&vbCrLf
  Else
  '如果二者不等,表明还有邮件没有接收
  
  intCurrentMessage=intCurrentMessage 1
  '
  '改变当前进程的状态
  m_State=POP3_RETR
  '
  '向服务器发出RETR命令接收下一个邮件
  Winsock1.SendData"RETR"&CStr(intCurrentMessage)&vbCrLf
  EndIf
  EndIf
  CasePOP3_QUIT
  '不管我们收到什么样的邮件,记得关闭同服务器的连接
  Winsock1.Close
  '现在调用ListMessages子程序,以便在ListView中显示收到的邮件
  CallListMessages
  EndSelect
  Else
  '下面的错误处理的代码
  '只须关闭socket并将来自服务器的回应显示出来就行了。
  '即使是那些高级的邮件接收程序所做也不外如此
  Winsock1.Close
  MsgBox"POP3Error:"&strData,_
  vbExclamation,"POP3Error"
  EndIf
  
  EndSub
  
  一切看上去都一目了然,除了下面的语句:
  
  Setm_oMessage=NewCMessage
  m_oMessage.CreateFromTextstrBuffer
  m_colMessages.Addm_oMessage,m_oMessage.MessageID
  Setm_oMessage=Nothing->

来源:http://www.tulaoshi.com/n/20160219/1625413.html

延伸阅读
只要掌握了原理,你也能写出一个所谓的黑客程序。下面笔者带领大家用VB亲自编写一个远程控制程序。从而揭开它的神秘面纱。 一、所用控件 在程序中将使用Winsock控件。Winsock控件是一个ActiveX控件,使用TCP协议或UDP协 议连接到远程计算机上并与之交换数据。和定时器控件一样,Winsock控件在运行时是不可见的。Winsock的工...
标签: PHP
  最近做一个新闻系统,为了模仿各大网站的在线发信功能就写了这个小程序,希望对各位菜鸟兄弟有用。     我没有给出一部分代码,只给出关键部分。其中shouxin代表收信人地址,shouren代表收信人姓名,jixin代表发信人地址,faren代表发信人姓名。id是前边传过来的参数,对你来说根本没什么用的。 <? if($shou...
标签: PHP
  <HTML <TITLE UNTITLED </TITLE <?php   include "connect.inc.php"; if ($subject) { $query = "select name,email from user"; $res = mysql_query($query);   $row = mysql_fetch_array($res);   while ($row) { mail($row['email'],$subject,$row['name'].&qu...
编写快速高效的Windows程序是我们的实际需要。当前越来越多的专业和非专业编程人员都倾向于用VB来编写一些Windows下的应用软件。但不可否认:VB所写的应用软件由于不是真编译代码,逊色于用C++和后起之秀Delphi编写的应用程序。以下参考有关资料并结合日常的使用经验,来谈谈如何在最大程度上弥补VB的这些不足,从而写出更加有效的Windows程序...
用VB实现程序的隐形 在一些系统,为了特定目的,经常要求程序隐藏起来运行,例如DCS(集散控制系统)中的后台监控系统、木马控制程序、源码防拷贝等,以减少被发现、截杀和反汇编的风险。这种功能模块要求程序在运行期间不仅不会在桌面出现,也不允许被操作者从任务管理器列表中发现。 程序隐形的原理 对于一个隐形程...

经验教程

120

收藏

16
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部