版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、基于BCB開發(fā)具有身份認證功能的郵件發(fā)送程序摘要本文介紹了如何增強BCB中發(fā)送電子郵件的NMSMTP控件的功能,實現(xiàn)具有身份認證功能的郵件發(fā)送程序。關(guān)鍵詞ESMTP,MIME,身份認證1引言為了更有效地抑制垃圾郵件的泛濫,目前多數(shù)網(wǎng)站的郵件收發(fā)系統(tǒng)都使用了ESMTP服務(wù)的身份認證功能。即用戶發(fā)送郵件時,需要對用戶的身份進行驗證,如果帳號或密碼錯誤,郵件服務(wù)器會拒絕發(fā)送郵件。BlCBuilder6中有豐富的控件供開發(fā)者使用,其中當然也包括
2、郵件發(fā)送控件NMSMTP,這個控件使用方便,但是惟一的缺點是不支持郵件發(fā)送時的身份認證功能。筆者通過對郵件發(fā)送協(xié)議的分析,在使用控件的基礎(chǔ)上設(shè)計了具有身份認證功能的郵件發(fā)送程序。2ESMTP協(xié)議分析為了實現(xiàn)身份認證功能,目前ESMTP協(xié)議中增加了一部分內(nèi)容,這就是身份認證。下面我們看看這段認證過程,以筆者在網(wǎng)易的郵箱為例(其中C表示客戶端,S表示郵件服務(wù)器):(1)C:AUTHLOGIN(2)S:334dXNlcm5hbWU6(3)C:
3、d3lxX2puX3NkX2Nu(4)S:334UGFzc3dvcmQ6(5)C:密碼略去(6)S:235Authenticationsuccessful詳細說明:(1)客戶端向服務(wù)器發(fā)送認證指令。(2)服務(wù)器返回Base64編碼串,334意味成功。編碼字符串解碼后為“username:“,說明要求客戶端發(fā)送用戶名。(3)客戶端發(fā)送Base64編碼的用戶名串,此處為“wyq_jn_sd_cn“。(4)服務(wù)器返回Base64編碼串,334
4、意味成功。編碼字符串解碼后為“passwd:“,說明要求客戶端發(fā)送用戶口令。(5)客戶端發(fā)送Base64編碼的口令串,此處略去。(6)服務(wù)器返回普通字符串,235意味成功,表示認證成功可以發(fā)送郵件了。3MIMEBase64編碼解釋一般的計算機編碼的一個字節(jié)是8bit,0——FF就是256種不同的8bit組合。我們現(xiàn)在要介紹的這種Base64編碼則是每個字節(jié)6bit,共有26=64種組合。其中每種組合對應(yīng)一個字符,這些字符是“ABCDEF
5、GHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789。”這就意味著每3個普通編碼可以轉(zhuǎn)換成4個Base64編碼,那么如果需要轉(zhuǎn)換的普通編碼不是3的整數(shù)倍怎么辦?Base64規(guī)定,位數(shù)不足的字節(jié)后面補0,然后差幾個字符補幾個‘=’號。4設(shè)計思路我們可以使用NMSMTP控件與郵件服務(wù)器連接。通過調(diào)用Connect方法,然后監(jiān)聽OnConnect事件;在OnConnect事件里我們可
6、以增加身份認證功能。這里是主要利用了NMSMTP從Powersock中繼承的一些基本網(wǎng)絡(luò)通訊函數(shù),包括ReadDataAvailableSendBuffer等來實現(xiàn)身份認證過程。如果身份認證成功,就可以繼續(xù)進334意味著服務(wù)器要求輸入口令if(rData.TrimLeft().SubString(03)==“334“)AddLog(“正在驗證口令......“)b_ok=trueif(!b_ok)AddLog(“登錄失敗,正在退出...
7、...“)NMSMTP1Disconnect()returnrData=““Data=encode(Edit5Text)“rn“口令轉(zhuǎn)換成Base64編碼。NMSMTP1SendBuffer(Data.c_str()Data.Length())發(fā)送口令rData=WaitFReply(5)b_ok=falseif(rData.Length()=3)if(rData.TrimLeft().SubString(03)==“235“)AddL
8、og(“登錄成功......“)b_ok=trueif(!b_ok)AddLog(“登錄失敗,正在退出......“)NMSMTP1Disconnect()returnSendMailEnabled=true允許發(fā)送郵件disconnectEnabled=true允許斷開連接Logon1Enabled=false不允許再次登錄5.3MIMEBase64編碼轉(zhuǎn)換AnsiStringTFm1::encode(AnsiStrings)intm
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 具有身份認證及數(shù)據(jù)加密U盤的研究與實現(xiàn).pdf
- 具有身份驗證和災(zāi)備功能的高效數(shù)據(jù)同步模型.pdf
- php功能齊全的發(fā)送郵件類
- 具有仲裁或多發(fā)送功能的認證碼的新構(gòu)造.pdf
- 發(fā)送郵件方法
- 基于android的有身份識別功能的流媒體播放器的設(shè)計與實現(xiàn)
- javamail 郵件程序開發(fā)詳解
- 發(fā)送和接受郵件
- 郵件高效發(fā)送方法
- javamail的使用之郵件發(fā)送
- 限制用戶發(fā)送 internet 郵件
- 基于身份的郵件加密系統(tǒng).pdf
- 如何用javamail發(fā)送郵件
- 持有身份證情況自查表
- 課程設(shè)計---電子郵件客戶端發(fā)送功能
- 基于Android的有身份識別功能的流媒體播放器的設(shè)計與實現(xiàn).pdf
- 信息魅力跨域發(fā)送郵件
- 有身份者與無身份者共同犯罪研究.pdf
- 具有彩信發(fā)送功能的GPRS終端的設(shè)計與實現(xiàn).pdf
- 基于人臉識別的身份認證系統(tǒng)的設(shè)計與開發(fā).pdf
評論
0/150
提交評論