基于BCB开发具有身返妮认证功能的邮件发送程序.docVIP

基于BCB开发具有身返妮认证功能的邮件发送程序.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于BCB开发具有身返妮认证功能的邮件发送程序

基于BCB开发具有身份认证功能的邮件发送程序 摘 要 本文介绍了如何增强BCB中发送电子邮件的NMSMTP控件的功能,实现具有身份认证功能的邮件发送程序。关键词 ESMTP,MIME,身份认证1 引言为了更有效地抑制垃圾邮件的泛滥,目前多数网站的邮件收发系统都使用了ESMTP服务的身份认证功能。即用户发送邮件时,需要对用户的身份进行验证,如果帐号或密码错误,邮件服务器会拒绝发送邮件。Borland C++ Builder 6中有丰富的控件供开发者使用,其中当然也包括邮件发送控件NMSMTP,这个控件使用方便,但是惟一的缺点是不支持邮件发送时的身份认证功能。笔者通过对邮件发送协议的分析,在使用控件的基础上设计了具有身份认证功能的邮件发送程序。2 ESMTP协议分析为了实现身份认证功能,目前ESMTP协议中增加了一部分内容,这就是身份认证。下面我们看看这段认证过程,以笔者在网易的邮箱为例(其中C表示客户端,S表示邮件服务器):(1)C: AUTH LOGIN(2)S: 334 dXNlcm5hbWU6(3)C: d3lxX2puX3NkX2Nu(4)S: 334 UGFzc3dvcmQ6(5)C: 密码略去(6)S: 235 Authentication successful详细说明:(1)客户端向服务器发送认证指令。(2)服务器返回Base64编码串,334意味成功。编码字符串解码后为”username:”,说明要求客户端发送用户名。(3)客户端发送Base64编码的用户名串,此处为”wyq_jn_sd_cn”。(4)服务器返回Base64编码串,334意味成功。编码字符串解码后为”password:”,说明要求客户端发送用户口令。(5)客户端发送Base64编码的口令串,此处略去。(6)服务器返回普通字符串,235意味成功,表示认证成功可以发送邮件了。3 MIME Base64编码解释一般的计算机编码的一个字节是8bit,0——FF就是256种不同的8bit组合。我们现在要介绍的这种Base64编码则是每个字节6bit,共有26=64种组合。其中每种组合对应一个字符,这些字符是“ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxy89+/。”这就意味着每3个普通编码可以转换成4个Base64编码,那么如果需要转换的普通编码不是3的整数倍怎么办?Base64规定,位数不足的字节后面补0,然后差几个字符补几个=’号。4 设计思路我们可以使用NMSMTP控件与邮件服务器连接。通过调用Connect方法,然后监听OnConnect事件;在OnConnect事件里我们可以增加身份认证功能。这里是主要利用了NMSMTP从Powersock中继承的一些基本网络通讯函数,包括Read,DataAvailable,SendBuffer等来实现身份认证过程。如果身份认证成功,就可以继续进行邮件发送;否则,提示错误信息,断开网络连接。5 程序实现 使用BCB设计如图1所示的窗体。图1 程序主界面5.1 在登录按钮的onClick事件中调用连接函数void __fastcall TForm1::Logon1Click(TObject *Sender){ AddLog(“正在登录”+Edit1-gt;Text+”......”); NMSMTP1-gt;Host = Edit1-gt;Text; //主机地址 NMSMTP1-gt;Port = 25; //主机端口,缺省为25 NMSMTP1-gt;UserID = Edit4-gt;Text; //用户名 NMSMTP1-gt;Connect(); //连接主机}5.2 处理OnConnect事件void __fastcall TForm1::NMSMTP1Connect(TObject *Sender){ AddLog(“连接服务器成功。”); AnsiString Data=““,rData=““; bool b_ok; if(CheckBox1-gt;Checked){ Data=“AUTH LOGIN”; //登录请求命令 NMSMTP1-gt;SendBuffer(Data.c_str(),Data.Length()); //命令发出 rData = WaitForReply(5); //等待接收返回数据,5秒内必须返回 b_ok = false; if(rData.Length()gt;=3){ //334意味着服务器要求输入用户名 if(rData.TrimLeft().SubString(0,3)==“334”){ AddLog(“正在验证身份......”); b_ok =true; } } if(!b_ok)

文档评论(0)

ayangjiayu3 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档