Skip to content

Latest commit

 

History

History
184 lines (137 loc) · 5.06 KB

IOS live接入文档.md

File metadata and controls

184 lines (137 loc) · 5.06 KB

[TOC]

腾讯云 X-P2P Live IOS SDK 接入文档

一、介绍

腾讯云X-P2P解决方案,可帮助用户直接使用经过大规模验证的直播、点播、文件分发服务,通过经商用验证的P2P服务大幅节省带宽成本,提供更优质的用户体验。开发者可通过SDK中简洁的接口快速同自有应用集成,实现IOS设备上的P2P加速功能。

传统CDN加速服务中,客户端向CDN发送HTTP请求获取数据。在腾讯云X-P2P服务中,SDK可以视为下载代理模块,客户端应用将HTTP请求发送至SDK,SDK从CDN或其他P2P节点获取数据,并将数据返回至上层应用。SDK通过互相分享数据降低CDN流量,并通过CDN的参与,确保了下载的可靠性。

SDK支持多实例,即支持同时开启多个直播p2p。

二、接入SDK

1.通过CocoaPods接入SDK

  • 在项目根目录创建Podfile文件
platform :ios, '9.0'
target 'RTMPiOSDemo' do #这里需要修改成自己的target工程
  use_frameworks!
  pod 'xnet', :git => 'https://github.com/tencentyun/xnet-ios-sdk.git', :tag => "0.0.1"
end
  • 在Terminal中执行以下命令
pod install
  • 如果您是更新版本请执行
pod update
  • 打开workspace
open RTMPiOSDemo.xcworkspace #您需要打卡自己的xcworkspace

2.应用配置

腾讯云对接人员会提供iOS项目的Bundle identifier,并索取App ID、App Key、App Secret Key,如以下形式:

Bundle identifier:com.qcloud.helloworld
NSString *appID = @"5919174f79883b4648a90bdd";
NSString *key = @"3qRcwO0Zn1Gm8t2O";
NSString *secret = @"Ayg29EDt1AbCXJ9t6HoQNbZUf6cPuV5J";

3.具体步骤

  • 解压解压TencentXP2P.zip并得到TencentXP2P.framework,并在项目中引用

  • 在App启动时初始化XP2PModule

首先需要初始化p2p sdk,最好在app启动后就作初始化。

// Example: 程序的入口AppDelegate.m
#import "AppDelegate.h"
#import <TencentXP2P/TencentXP2P.h>
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    // do something other...

    //下面的接口调用可以开启SDK log的打印,不调用该接口,log打印默认不开启
    [XNet enableDebug]

    NSString *appID = @"";
    NSString *key = @"";
    NSString *secret = @"";
    bool ok = [XNet initWith:appID appKey:key appSecretKey:secret];

    return YES;
}

- (void)onLogPrint:(NSString*)msg {
    //这里能够收到SDK输出的日志
}

@end
  • 加载一个频道
- (int)startPlay:(NSString*)url
{
    // 将resource之前的 域名/路径 内容替换为 [XP2PModule host] 即可
    NSString* p2pUrl = [XNet.HTTP_PROXY stringByAppendingString:@"${yourResoruce.ext}"];
    // 直接播放此url即可
    [_player startPlay:p2pUrl];
    return EXIT_SUCCESS;
}
  • 卸载一个频道
- (int)stopPlay
{
    // 播放器链接断开以后 SDK内部会自动释放频道相关的资源, 直接关闭播放器即可
    [_player stopPlay];
    return EXIT_SUCCESS;
}
  • 恢复前台显示时,需要调用resume
    bool ok = [XNet resume];

三、API

SDK接口除初始化接口, 其余接口均由http实现, 请求格式为http:://${host}/${func}?${param}, 其中${host}为本地代理服务器, 通过XNet.HTTP_PROXY获取


1.统计

  • 描述: 请求对应频道的统计数据

  • 方法: GET

  • 路径: /stat?channel=${resource}

  • 请求参数:

参数名称 必选 类型 说明
channel string 默认为url中的resource, 否则为频道请求中的channel值
  • 返回参数:
返回码 说明
200 查询成功
404 查询失败, 频道不存在
参数名称 类型
---- ----
flow.p2pBytes num
flow.cdnBytes num
  • 请求样例

http://127.0.0.1:16080/live.p2p.com/stat?channel=xxx

*注:*channel 即 http://127.0.0.1:16080/live.p2p.com/resoruce.ext 中的 resource

  • 返回样例
"{"flow":{"p2pBytes":0,"cdnBytes":0}}"

2.设置上下行

  • 描述: 请求设置p2p上行与下行, 0为开启, 1为关闭

  • 方法: GET

  • 路径: /feature?download=${0or1}&upload=${0or1}

参数名称 必选 类型 说明
download num 0为关闭; 1为默认值, 开启
upload num 0为关闭; 1为默认值, 开启
  • 请求样例

http://127.0.0.1:16080/live.p2p.com/feature?download=1&upload=0

*注:*一般情况下移动网络需要关闭上传

  • 返回参数: JSON, 格式如下
参数名称 必选 类型 说明
ret num 0表示正常
msg string 相关信息, 调试使用
upload bool 1表示开启, 0表示关闭
download bool 1表示开启, 0表示关闭
  • 返回样例
"{"ret":0, "msg":"ok", "download":0,"upload":0}}"

四、ios当前支持的架构

armv7 armv7s arm64