Rust使用lettre實現(xiàn)郵件發(fā)送功能
POP、IMAP、SMTP是什么
- POP(Post Office Protocol):,用于客戶端從郵件服務(wù)器上下載電子郵件。它允許用戶將郵件服務(wù)器上的郵件檢索到本地設(shè)備(如個人電腦、手機等)進行閱讀、處理等操作
- IMAP(Internet Mail Access Protocol):交互式郵件存取協(xié)議,用于客戶端訪問郵件服務(wù)器上的郵件,但與 POP 不同的是,用戶可以通過 IMAP 協(xié)議在客戶端上對郵件服務(wù)器上的郵件進行各種操作,如閱讀、移動、刪除、標記等,始終保持郵件存儲在服務(wù)器上,用戶可以從任何支持 IMAP 的設(shè)備訪問和管理郵件
- SMTP(Simple Mail Transfer Protocol):簡單郵件傳輸協(xié)議,負責(zé)將郵件從發(fā)件人的郵件客戶端(如 Outlook、Thunderbird 等)或者郵件發(fā)送服務(wù)器(如本案例)傳輸?shù)绞占说泥]件服務(wù)器
這里使用SMTP發(fā)送郵件,所以要開啟SMTP,由于outlook需要付費,這里使用qq郵箱
生成授權(quán)碼,這個授權(quán)碼就是郵件發(fā)送者的密碼
1、添加crate
lettre = "0.11"
2、創(chuàng)建郵件對象和郵件發(fā)送者
同步發(fā)送,會阻塞代碼
use lettre::{ message::header::ContentType, transport::smtp::authentication::Credentials, Message, SmtpTransport, Transport, }; async fn main() { // 創(chuàng)建郵件對象 let email = Message::builder() // 設(shè)置郵件的發(fā)件人地址 .from("xxxxxxx@qq.com".parse().unwrap()) // 設(shè)置郵件的回復(fù)地址 .reply_to("xxxxxx@qq.com".parse().unwrap()) // 設(shè)置郵件的收件人地址 .to("xxxxxx@gmail.com".parse().unwrap()) // 設(shè)置郵件的主題 .subject("銹化動力商城驗證碼") // 設(shè)置郵件的內(nèi)容類型為純文本 .header(ContentType::TEXT_PLAIN) // 設(shè)置郵件的正文內(nèi)容 .body(String::from("驗證碼為:123456")) .unwrap(); // 創(chuàng)建郵件發(fā)送者,第一個參數(shù)是郵件發(fā)送者賬號,第二個參數(shù)是郵件發(fā)送者密碼,這里使用授權(quán)碼 let creds = Credentials::new("xxxx@qq.com".to_owned(), "password".to_owned()); // 使用ssl打開mail遠程鏈接,填寫發(fā)送郵件服務(wù)器地址,端口為465或587 let mailer = SmtpTransport::starttls_relay("smtp.qq.com") .unwrap() .credentials(creds) .port(587) .build(); // 發(fā)送郵件 match mailer.send(&email) { Ok(_) => println!("Email sent successfully!"), Err(e) => println!("Could not send email: {e:?}"), } }
異步發(fā)送,不會阻塞代碼 Cargo.toml配置
tokio = { version = "1", features = ["full"] } lettre = { version = "0.11.7", features = ["tokio1-native-tls", "builder"] }
代碼
use lettre::{ AsyncSmtpTransport, AsyncTransport, Message, message::header::ContentType, Tokio1Executor, transport::smtp::authentication::Credentials, }; #[tokio::main] async fn main() { // 創(chuàng)建郵件對象 let email = Message::builder() // 設(shè)置郵件的發(fā)件人地址 .from("xxxxx@qq.com".parse().unwrap()) // 設(shè)置郵件的回復(fù)地址 .reply_to("xxxx@qq.com".parse().unwrap()) // 設(shè)置郵件的收件人地址 .to("xxxx@gmail.com".parse().unwrap()) // 設(shè)置郵件的主題 .subject("銹化動力商城驗證碼") // 設(shè)置郵件的內(nèi)容類型為純文本 .header(ContentType::TEXT_PLAIN) // 設(shè)置郵件的正文內(nèi)容 .body(String::from("驗證碼為:123456")) .unwrap(); // 創(chuàng)建郵件發(fā)送者,第一個參數(shù)是郵件發(fā)送者賬號,第二個參數(shù)是郵件發(fā)送者密碼,這里使用授權(quán)碼 let creds = Credentials::new("xxxxx@qq.com".to_owned(), "password".to_owned()); // 使用ssl打開mail遠程鏈接,填寫發(fā)送郵件服務(wù)器地址,端口為465或587 let mailer: AsyncSmtpTransport<Tokio1Executor> = AsyncSmtpTransport::<Tokio1Executor> ::starttls_relay("smtp.qq.com") .unwrap() .credentials(creds) .port(587) .build(); match mailer.send(email).await { Ok(_) => println!("Email sent successfully!"), Err(e) => println!("Could not send email: {e:?}"), } }
效果
實際生產(chǎn)請將unwrap()
替換為?
傳遞錯誤或其他錯誤處理方式,使用郵件進行注冊登陸時可以生成的驗證碼往redis里寫一份,key設(shè)置為郵件名,設(shè)置過期時間為60s,注冊登陸時與redis中的驗證碼比較即可
到此這篇關(guān)于Rust使用lettre實現(xiàn)郵件發(fā)送功能的文章就介紹到這了,更多相關(guān)Rust lettre郵件發(fā)送內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
rust標準庫std::env環(huán)境相關(guān)的常量
在本章節(jié)中, 我們探討了Rust處理命令行參數(shù)的常見的兩種方式和處理環(huán)境變量的兩種常見方式, 拋開Rust的語法, 實際上在命令行參數(shù)的處理方式上, 與其它語言大同小異, 可能影響我們習(xí)慣的也就只剩下語法,本文介紹rust標準庫std::env的相關(guān)知識,感興趣的朋友一起看看吧2024-03-03如何使用VSCode配置Rust開發(fā)環(huán)境(Rust新手教程)
這篇文章主要介紹了如何使用VSCode配置Rust開發(fā)環(huán)境(Rust新手教程),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07