SKPSMTPMessage 完全不依賴于iOS系統(tǒng)內(nèi)置的發(fā)送郵件程序,可內(nèi)置于你的應(yīng)用實現(xiàn)后臺發(fā)送郵件目的。
下載第三庫時導(dǎo)入文件會報錯,因為它是支持非ARC的,所以現(xiàn)在要導(dǎo)入我們的工程支持ARC,只需要在下圖中把要導(dǎo)入的文件添加-fno-objc-arc就可以運行了。

支持ARC
下面我們進入正題,怎么操作實現(xiàn)郵件發(fā)送。
- 首先導(dǎo)入類頭文件
#import "SKPSMTPMessage.h"
#import "NSData+Base64Additions.h"
- 設(shè)置基本參數(shù)
_myMail = [[SKPSMTPMessage alloc] init];
// 發(fā)送者信息
_myMail.fromEmail = @"my@163.com"; //
_myMail.login = @"my@163.com";
_myMail.pass = @"myPassword";
_myMail.relayHost = @"smtp.163.com"; //
// 接收者信息
_myMail.toEmail = @"other@qq.com"; //
_myMail.requiresAuth = YES;
_myMail.wantsSecure = YES;
_myMail.delegate = self;
- 設(shè)置郵件內(nèi)容
// 主題
_myMail.subject = @"這是信息的主題!";
// 正文
NSDictionary *plainPart = @{kSKPSMTPPartContentTypeKey : @"text/plain;charset=UTF-8",
kSKPSMTPPartMessageKey : @"This is a tést mess?ge.",
kSKPSMTPPartContentTransferEncodingKey : @"8bit",
};
// 附件部分
NSString *vcfPath = [[NSBundle mainBundle] pathForResource:@"002.doc" ofType:nil];
NSData *vcfData = [NSData dataWithContentsOfFile:vcfPath];
NSDictionary *vcfPart = @{kSKPSMTPPartContentTypeKey: @"text/directory;\r\n\tx-unix-mode=0644;\r\n\tname=\"002.doc\"",
kSKPSMTPPartContentDispositionKey: @"attachment;\r\n\tfilename=\"002.doc\"",
kSKPSMTPPartMessageKey: [vcfData encodeBase64ForData],
kSKPSMTPPartContentTransferEncodingKey: @"base64"
};
// 執(zhí)行發(fā)送郵件代碼:
[_myMail setParts:@[plainPart, vcfPart]]; // 郵件首部字段、郵件內(nèi)容格式和傳輸編碼
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
[_myMail send];
});
- 代理回調(diào)函數(shù)
#pragma mark - SKPSMTPMessageDelegate -
-(void)messageSent:(SKPSMTPMessage *)message {
NSLog(@"messageSent - %@", message);
}
-(void)messageFailed:(SKPSMTPMessage *)message error:(NSError *)error {
NSLog(@"message - %@\nerror - %@", message, error);
}
使用前需要需要注意以下幾點:
1. 郵件主題為中文時,KPSMTPMessage.m文件中的sendParts方法中,需要修改 NSDatamessageData = [message dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES] 為NSData messageData = [message dataUsingEncoding:NSUTF8StringEncoding allowLossyConversion:YES], 否則會出現(xiàn)中文亂碼問題。
2. 發(fā)送方的郵箱需要開啟 SMTP 服務(wù),不然郵件無法從發(fā)送方郵箱發(fā)出。
3. 如果發(fā)送的時候報出503的code時,要檢查您發(fā)送郵件的賬號密碼是否正確,這時的登陸密碼不是設(shè)置的密碼,要開啟SMTP服務(wù)器自己設(shè)置的一個授權(quán)碼的。
4. 如果爆出連接三次的都連不上郵箱服務(wù)器的話那就是網(wǎng)絡(luò)有問題的。
5. gmail的郵箱是不用填授權(quán)碼的,直接填登陸密碼就好了。