- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Twilio基本电话流程说明
借助Twilio REST API,可以对电话和Twilio客户端发起呼叫。在一个Twilio Client 应用里有三个主要的参与方:
使用libTwilioClient.a库开发的iOS应用;
一个能授权客户端、提供TwiML和/或拨打Twilio REST API电话的服务器;
Twilio云服务,它来处理电话通讯,除此之外还处理TwiML和/或REST API呼叫。
客户端类
客户端应用连接Twilio服务主要的类是TCDevice。这个类负责Twilio的服务授权、检测呼入的连接、建立呼出的连接。可以通过如下方式生成该类实例:_device = [[TCDevice alloc] initWithCapabilityToken:capabilityToken delegate:self],其中capablityToken为代表该实例权限的能力令牌,如可以允许呼入、呼出等。
连接建立后,不管是呼入还是呼出的,都可以通过TCConnection类的实例可以获得建立的连接。
除此之外,实现了TCDeviceDelegate和TCConnectionDelegate协议的对象可以获得状态回调,如正在建立呼叫、呼叫成功建立等。若在某一个状态需要做什么处理可以在响应的代理方法里实现。
基于服务器的安全策略:能力令牌
Twilio客户端SDK通过使用一个能力令牌来授权客户端权限。这些令牌由你的服务器产生,它授权你的客户端应用能具有什么样的能力,例如是否允许接听来电,是否允许呼出电话等。为了防止滥用,这些能力令牌都有一个有效期。
下面以IOS为例对一个基本的呼叫做出详细说明。
通话建立示意图
建立通话流程图
运行IOS客户端程序登录Twilio服务器
向自己服务器发出HTTP请求capabilityToken
成功获取capabilityToken
N
Y
登录成功
N
Y
等待用户操作
N
Y 允许呼叫/接听通话
N
和Twilio服务器建立连接,Twilio服务器根据你账户配置的URL向你服务器发出请求,根据返回TwiML做进步一的处理
Y
挂机结束
登录失败
代码片段
capabilityToken授权文件auth.php
?php
// This php is to be put on your server, and change the URLs in BasicPhone.m
// to point to this files public location.
require Services/Twilio/Capability.php;
$accountSid = ACb207297ce69b775c368393c5f7ebe0b8; //用户名
$authToken = 8aa25fcff65cb34e35483ccbfee4a5f4;// 密码
// The app outbound connections will use:
$appSid = AP700672e29b0b42daa8969d;//Twilio服务器上生成的application的id
// The client name for inbound connections:
$client
文档评论(0)