1. 准备工作:导入信息UI库 #import <MessageUI/MessageUI.h>
2. Call Phone
  方式一: 拼接字符串 注意开头是tel: 这种方式打电话回不到原来应用中,会停留在通讯录里,而且是直接拨打电话 没有任何弹窗提示
  NSString *str = [NSString stringWithFormat:@"tel:%@",self.phoneTextField.text];
  首先得到应用的单例对象 然后调用openURL:这个方法 参数是url对象
  [[UIApplication sharedApplication] openURL:[NSURL URLWithString:str]];
  方式二: 这种方式有弹窗提示,并且能回到原来应用中 推荐这种
  NSString *str1 = [[NSString alloc] initWithFormat:@"tel:%@",self.phoneTextField.text];
  创建UIWebView对象
  UIWebView *callWebView = [[UIWebView alloc] init];
  加载一个请求对象 这个请求对象通过url对象创建 url对象又通过str1字符串获得
  [callWebView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:str1]]];
  加入到self.view上
  [self.view addSubview:callWebView];
  方式三:这种方式 也可以有弹窗提示 并且也能回到原来的应用中 也推荐这种
  NSString *str2 = [NSString stringWithFormat:@"telprompt:%@",self.phoneTextField.text];
  [[UIApplication sharedApplication] openURL:[NSURL URLWithString:str2]];
3. Web 打开网址 注意:打开的网址注意是http:// 或是https://
  NSString *str = [NSString stringWithFormat:@"https://%@",self.webTextField.text];
  [[UIApplication sharedApplication] openURL:[NSURL URLWithString:str]];

4. SMS
  方式一:这种方式没法回到应用中,但是注意不要写中文等特殊字符 否则无法跳到发短信界面
  优点:简单 缺点:不能指定发送内容,只能指定发送人,而且不能回到应用中
  NSString *str = [NSString stringWithFormat:@"sms://%@",self.smsTextField.text];
  NSURL *url = [NSURL URLWithString:str];
  [[UIApplication sharedApplication] openURL:url];
  方式二:推荐这种
  优点:1.从应用出来并且能回到应用中
  2.可以发送多人
  3.可以用代码自定义消息
  4.如果手机开通了iMessage功能,会走网络通道,不走运营商通道

  判断用户设备是否能发送短信
  if (![MFMessageComposeViewController canSendText]) {
  NSLog(@"不能发送内容");

  return ;
  }

  1.创建一个短信控制器对象
  MFMessageComposeViewController *controller = [[MFMessageComposeViewController alloc] init];

  2.设置短信内容
  (1)收件人
  controller.recipients = @[@"10086",@"10010"];
  (2)短信内容
  controller.body = @"你好啊 你俩";
  (3)设置短信代理 (要遵守代理协议MFMessageComposeViewControllerDelegate)
  controller.messageComposeDelegate = self;

  3.显示短信控制器

  [self presentViewController:controller animated:YES completion:^{
  NSLog(@"显示短信控制器完成代码块");
  }];

#pragma mark - 短信控制器代理方法
- (void)messageComposeViewController:(MFMessageComposeViewController *)controller didFinishWithResult:(MessageComposeResult)result {

  /*
  MessageComposeResultCancelled, 取消
  MessageComposeResultSent, 发送
  MessageComposeResultFailed 失败

  result枚举
*/
  NSLog(@"%d",result);

  //注:别忘了回到应用中
  [controller dismissViewControllerAnimated:YES completion:^{
  NSLog(@"短信控制器消失完成后代码块");
  }];

  }

5. Email
  方式一:
  NSString *str = [NSString stringWithFormat:@"mailto://%@",self.emailTextField.text];
  [[UIApplication sharedApplication] openURL:[NSURL URLWithString:str]];
  方式二:
  判断是否能发送邮件
  if (![MFMailComposeViewController canSendMail]) {
  NSLog(@"不能发送邮件");
  return;
  }
  创建mail控制器对象
  MFMailComposeViewController *vc = [[MFMailComposeViewController alloc] init];
  设置邮件主题
  [vc setSubject:@"第一天 第二次发送"];
  设置邮件发送内容 第二个参数支持HTML格式
  [vc setMessageBody:@"今天主要讲了CoreData 和基本的电话、邮件、web已经短信" isHTML:YES];
  设置收件人列表
  [vc setToRecipients:@[@"56483826@qq.com"]];
  设置抄送人列表
  [vc setCcRecipients:@[@"383822222@qq.com",@"45454@163.com"]];
  设置邮件代理(要遵守邮件代理MFMailComposeViewControllerDelegate)
  vc.mailComposeDelegate = self;
  显示邮件控制器
  [self presentViewController:vc animated:YES completion:^{
  NSLog(@"跳转完成后执行代码块");
  }];

#pragma mark - 邮件代理方法
- (void)mailComposeController:(MFMailComposeViewController *)controller didFinishWithResult:(MFMailComposeResult)result error:(NSError *)error {

  /*
  result枚举类型
  MFMailComposeResultCancelled,    取消
  MFMailComposeResultSaved,     保存
  MFMailComposeResultSent,      发送
  MFMailComposeResultFailed     失败
  */
  NSLog(@"%d",result);

  [controller dismissViewControllerAnimated:YES completion:^{
  NSLog(@"邮箱控制器消失完成后代码块");
  }];

  }

网络之Call Phone、Web、SMS、Email的更多相关文章

  1. 20155324《网络对抗技术》web安全基础实践

    20155324<网络对抗技术>web安全基础实践 实验内容 使用webgoat进行XSS攻击.CSRF攻击.SQL注入 实验问答 SQL注入攻击原理,如何防御 ①SQL注入攻击是攻击者在 ...

  2. 20145215《网络对抗》Exp9 Web安全基础实践

    20145215<网络对抗>Exp9 Web安全基础实践 基础问题回答 SQL注入攻击原理,如何防御? SQL注入攻击就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符 ...

  3. 20145208 蔡野 《网络对抗》Exp9 web安全基础实践

    20145208 蔡野 <网络对抗>Exp9 web安全基础实践 本实践的目标理解常用网络攻击技术的基本原理.Webgoat实践下相关实验. 实验后回答问题 (1)SQL注入攻击原理,如何 ...

  4. 20145311王亦徐 《网络对抗技术》 Web安全基础实践

    2014531王亦徐 <网络对抗技术> Web安全基础实践 实验内容 利用WebGoat平台尝试了一些XSS.CSRF.SQL注入攻击 基础问题回答 1.SQL注入攻击原理,如何防御原理: ...

  5. 20145325张梓靖 《网络对抗技术》 Web安全基础实践

    20145325张梓靖 <网络对抗技术> Web安全基础实践 实验内容 使用webgoat进行XSS攻击.CSRF攻击.SQL注入 XSS攻击:Stored XSS Attacks.Ref ...

  6. 20155202《网络对抗》Exp9 web安全基础实践

    20155202<网络对抗>Exp9 web安全基础实践 实验前回答问题 (1)SQL注入攻击原理,如何防御 SQL注入产生的原因,和栈溢出.XSS等很多其他的攻击方法类似,就是未经检查或 ...

  7. 20155204《网络对抗》Exp9 Web安全基础实践

    20155204<网络对抗>Exp9 Web安全基础实践 一.基础问题回答 SQL注入攻击原理,如何防御? 原理: SQL注入即是指web应用程序对用户输入数据的合法性没有判断,攻击者可以 ...

  8. 20155207 《网络对抗》 Exp9 Web安全基础

    20155207 <网络对抗> Exp9 Web安全基础 实验内容 关于WebGoat Cross-Site Scripting(XSS)练习 Injection Flaws练习 CSRF ...

  9. 20155217《网络对抗》Exp09 Web安全基础实践

    20155217<网络对抗>Exp09 Web安全基础实践 实践内容 关于webgoat:询问了很多人在安装webgoat时出现了错误,安装失败,因此直接通过同学copy了老师的虚拟机进行 ...

  10. 20155227《网络对抗》Exp9 Web安全基础实践

    20155227<网络对抗>Exp9 Web安全基础实践 实验内容 关于WebGoat Cross-Site Scripting(XSS)练习 Injection Flaws练习 CSRF ...

随机推荐

  1. ThreadLocal 示例

    ThreadLocal, 从字面意思上看是本地线程. 但实际上它是一个线程本地变量.它的功能就是为每一个使用该变量的线程都提供一个变量值的副本, 从而使得不会与其他线程的副本冲突. 与使用synchr ...

  2. C++中的默认成员函数

    一般而言,对于一个用户自定义的类类型,以下四个函数在用户没有自定义的情形下,会由编译器自动生成: 1.default constructor 2.copy constructor Someclass: ...

  3. Python(调用函数、定义函数)

    函数的返回值: return 值:只能返回一次,只要执行return函数就终止 返回值:没有类型限制,也没有个数限制 没有return:None 返回一个值 返回多个值:元组 先定义,后使用,定义阶段 ...

  4. 再谈WinIO初始化异常

    再谈WinIO初始化异常     前段时间WinIO在我的新项目中总是初始化失败,有时候又是好好的,很让人费解.修改了源代码显示了很多调试信息后,也没有什么太多的收获.由于我们的工控卡必须要用这个库, ...

  5. Uber中国在地方城市的人员架构是怎样的?

    http://www.thepaper.cn/newsDetail_forward_1390516 澎湃新闻:Uber中国在地方城市的人员架构是怎样的?   柳甄:一般是3人组成的小团队作战.一名城市 ...

  6. redis的一些命令

    字符串操作 EX在设置值的时候设置过期时间,ttl查看过期时间 expire能单独设置过期时间 查看所有的key key * 列表操作 lpush从列表左边添加值,rpush从列表右边添加值 lran ...

  7. MAC 终端颜色设置

    在bash中,可以通过更改PS1环境变量的值来设置提示行.通常的提示符颜色单调,用户可以通过在PS1中添加颜色代码序列来设置提示符中不同信息以不同颜色显示. 添加颜色相当容易:第一步是设计不带颜色的提 ...

  8. jquery扩展鼠标mousewheel事件

    最近项目中要有个鼠标在图片上滚动实现图片放大和缩小的得到功能,隐约的记得好像记得有个 mousewheel 事件,可以实现需求,于是乎,开始在网上查找这一方法,但是,出乎意料的结果,各浏览器对此方法有 ...

  9. 阿里云服务器: centos7 ftp安装

    阿里云服务器: centos7 ftp安装 ftp需要您参考下面链接和附件开放安全组20.21.1024-65535 后查看是否正常. 配置步骤如下, 1, 如果没有安装ftp,需要先安装 yum - ...

  10. var和let/const的区别

    let和const是 ES6 新增的命令,用于声明变量,这两个命令跟 ES5 的var有许多不同,并且let和const也有一些细微的不同,再认真阅读了阮一峰老师的文档后,发现还是有一些不知道的细节. ...