iOS-調用系統的發送短信和發送郵件功能,實現短信分享和郵件分享

一、郵件分享

1、iOS系統自帶郵件設置郵箱(此處以QQ郵箱為例)

a.打開電腦,登錄郵箱(以QQ郵箱為例),進入設置-賬戶-找到“POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服務”將“IMAP/SMTP服務”打開后并生成授權碼。

b、生成授權碼由16位隨機字母組成

c、設置手機端。打開設置-郵件-添加賬戶


d、此處以QQ郵箱為例,其他郵箱也可。

e、按要求填寫后點擊下一步。

f、按圖中所示進行設置后,最后點擊“發件服務器”SMTP設置

g、繼續點擊。“主要服務器”設置

h、按圖中設置,最后完成。

i、選擇“郵件”app,即可使用。

注意:由于QQ郵箱激活時間不滿14天,暫時無法設置POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服務

會造成只能發送郵件,但是郵件接收不到的情況。

2、實現功能

- (void)displayMailComposerSheet

{

MFMailComposeViewController *picker = [[MFMailComposeViewController alloc] init];

// 設置picker的委托方法,完成之后會自動調用成功或失敗的方法

picker.mailComposeDelegate = self;

// 添加主題

[picker setSubject:@"文件分享"];

// 添加收件人

//NSArray *toRecipients = [NSArray arrayWithObject:@"收件人@qq.com"];

// 說明:也可以添加多個收件人,代碼如下所示:

//NSArray *toRecipients = [NSArray arrayWithObjects:@"one@qq.com",@"two@qq.com",nil];

// 添加抄送

//NSArray *ccRecipients = [NSArray arrayWithObjects:@"second@qq.com",@"third@qq.com", nil];

// 添加密送

//NSArray *bccRecipients = [NSArray arrayWithObject:@"fourth@qq.com"];

[picker setToRecipients:toRecipients];

//[picker setCcRecipients:ccRecipients];

//[picker setBccRecipients:bccRecipients];

// 直接在HTML代碼中寫入圖片的地址

NSString *emailBody = [NSString stringWithFormat:@"

我分享了圖片

"];

[picker setMessageBody:emailBody isHTML:YES];

[self presentModalViewController:picker animated:YES];

[picker release];

}

這樣實現的效果是,在郵件中會顯示一個圖片和一段文本,關鍵是第25行代碼,一定要設置isHTML為YES。但實際應用中,圖片一般我們沒有上傳到服務器上,而是在客戶端,這時候我們可以用下面的方式來發送圖片(將第23行代碼替換成下面的代碼):

// 發送圖片附件(其他格式的附件,可以都先轉化稱NSData類型,然后設置相應的mimeType即可,如txt類型為@"text/txt",doc類型為@"text/doc",pdf類型為@"file/pdf"等等)

NSData *myData = [NSData dataWithContentsOfFile:[[NSHomeDirectory() stringByAppendingPathComponent:@"Documents"] stringByAppendingPathComponent:@"new.png"]];

[picker addAttachmentData:myData mimeType:@"image/jpeg" fileName:@"new.png"];

NSString *emailBody = [NSString stringWithFormat:@"

我分享了圖片

"];

使用上面這種方式,將isHTML設置為YES的話,圖片會顯示在正文中;isHTML設置為NO的話,圖片會顯示在附件中。

》添加郵箱附件方法:

//發送圖片附件

NSString *path = [[NSBundle mainBundle] pathForResource:@"rainy" ofType:@"jpg"];

NSData *myData = [NSData dataWithContentsOfFile:path];

[picker addAttachmentData:myData mimeType:@"image/jpeg" fileName:@"rainy.jpg"];

//發送txt文本附件

NSString *path = [[NSBundle mainBundle] pathForResource:@"MyText" ofType:@"txt"];

NSData *myData = [NSData dataWithContentsOfFile:path];

[picker addAttachmentData:myData mimeType:@"text/txt" fileName:@"MyText.txt"];

//發送doc文本附件

NSString *path = [[NSBundle mainBundle] pathForResource:@"MyText" ofType:@"doc"];

NSData *myData = [NSData dataWithContentsOfFile:path];

[picker addAttachmentData:myData mimeType:@"text/doc" fileName:@"MyText.doc"];

//發送pdf文檔附件

NSString *path = [[NSBundlemainBundle]pathForResource:@"CodeSigningGuide"ofType:@"pdf"];

NSData *myData = [NSDatadataWithContentsOfFile:path];

[pickeraddAttachmentData:myDatamimeType:@"file/pdf"fileName:@"rainy.pdf"];

郵件發送完成之后,可以在如下的委托方法中進行相應的處理,委托方法如下所示:

- (void)mailComposeController:(MFMailComposeViewController*)controller

didFinishWithResult:(MFMailComposeResult)result error:(NSError*)error

{

switch (result)

{

case MFMailComposeResultCancelled:

NSLog(@"Result: Mail sending canceled");// 郵件發送取消

break;

case MFMailComposeResultSaved:

NSLog(@"Result: Mail saved");// 郵件保存成功

break;

case MFMailComposeResultSent:

NSLog(@"Result: Mail sent");// 郵件發送成功

break;

case MFMailComposeResultFailed:

NSLog(@"Result: Mail sending failed");// 郵件發送失敗

break;

default:

NSLog(@"Result: Mail not sent");

break;

}

[self dismissModalViewControllerAnimated:YES];

}

導入MessageUI.framework

.h文件中#import

#import

實現 MFMailComposeViewControllerDelegate, MFMessageComposeViewControllerDelegate

二、發送短信

//短信

-(void)showSMSPicker{

Class messageClass = (NSClassFromString(@"MFMessageComposeViewController"));

if (messageClass != nil) {

// Check whether the current device is configured for sending SMS messages

if ([messageClass canSendText]) {

[selfdisplaySMSComposerSheet];

}

else {

UIAlertView *alert=[[UIAlertView alloc] initWithTitle:@""message:@"設備不支持短信功能" delegate:selfcancelButtonTitle:@"確定" otherButtonTitles:nil];

[alert show];

[alert release];

}

}

else {

}

}

-(void)displaySMSComposerSheet

{

MFMessageComposeViewController *picker = [[MFMessageComposeViewControlleralloc]init];

picker.messageComposeDelegate =self;

NSString *smsBody =[NSStringstringWithFormat:@"我分享了文件給您,地址是%@",address] ;

picker.body=smsBody;

[selfpresentModalViewController:pickeranimated:YES];

[pickerrelease];

}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,362評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,013評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,346評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,421評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,146評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,534評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,585評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,767評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,318評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,074評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,258評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,828評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,486評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,916評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,156評論 1 290
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,993評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,234評論 2 375

推薦閱讀更多精彩內容