电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 认证考试-> 全国等级考试
vb邮件检查程序(二)_visualbasic教程
作者:网友供稿 点击:0
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
下面是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))
IfintMessages>0Then

如果邮箱中有邮件
改变进程的状态
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.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·全国计算机等级考试四级复习纲要一[4]_全国等级考试
·photoshop滤镜打造个性不规则须毛边框_photoshop教程
·photoshop教你制作美丽魔幻星云_photoshop教程
·照片特效处理:为肖像照片增加杂色颗粒_photoshop教程
·07上半年计算机等级考试辽宁报名19日结束_全国等级考试
·计算机等级考试四级考试的体会和感受_全国等级考试
·全国计算机等级考试四级复习纲要一[1]_全国等级考试
·07年4月计算机等级二级vf模拟笔试题五_全国等级考试
·全国计算机等级考试四级复习纲要一[3]_全国等级考试
·photoshop水彩特效表现处理方法_photoshop教程

最新文章
·photoshop鼠绘实例:浪漫夏夜壁纸_photoshop教程
·无需工具使用自带功能轻松优化win xp_windows xp
·windows server 2008十大新技术亮点_windows server 2008
·c#网络应用编程基础练习题与答案(十)_全国等级考试
·c#网络应用编程基础练习题与答案(九)_全国等级考试
·c#网络应用编程基础练习题与答案(八)_全国等级考试
·c#网络应用编程基础练习题与答案(七)_全国等级考试
·c#网络应用编程基础练习题与答案(六)_全国等级考试
·c#网络应用编程基础练习题与答案(五)_全国等级考试
·c#网络应用编程基础练习题与答案(四)_全国等级考试


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号