·您当前的位置:首页 > 技术教程 > Rtmp技术 >

[RTMP]RTMP协议概述与连接

时间:2015-12-30 14:16酷播
RTMP协议是被Flash用于对象,视频,音频的传输.该协议建立在TCP协议或者轮询HTTP协议之上.

RTMP协议概述

介绍:

RTMP协议是被Flash用于对象,视频,音频的传输.该协议建立在TCP协议或者轮询HTTP协议之上.
RTMP协议就像一个用来装数据包的容器,这些数据可以是AMF格式的数据,也可以是FLV中的视/音频数据.一个单一的连接可以通过不同的通道传输多路网络流.这些通道中的包都是按照固定大小的包传输的.

网络连接(Connection)

一个Actionscrīpt连接并播放一个流的简单代码:
CODE:
var videoInstance:Video = your_video_instance;
var nc:NetConnection = new NetConnection();
var connected:Boolean = nc.connect("rtmp://www.cuplayer.com/myapp");
var ns:NetStream = new NetStream(nc);
videoInstance.attachVideo(ns);
ns.play("CuPlayer");

默认端口为1935

握手

Client → Server :向服务器发出握手请求.这不属于协议包一部分,该握手请求第一个字节为(0×03),其后跟着1536个字节.经管看上去这部分的内容对于RTMP协议来说并不是至关重要的,但也不可随意对待.
Server → Client :服务器向客户端回应握手请求.这部分的数据仍然不属于RTMP协议的部分.该回应的其实字节仍然为(0x03),但是后边跟着个长度为1536个字节 (一共为3072 )的包块.第一个1536块看上去似乎可以是任意内容,甚至好像可以是Null都没有关系.第二个1536的代码块,是上一步客户端向服务器端发送的握手 请求的内容.
Client→Server:把上一步服务器向客户端回应的第二块1536个字节的数据块.

至此客户端与服务器端的握手结束,下面将发送RTMP协议的包内容.

Client → Server :向服务器发送连接包.
Server → Client :服务器回应.

RTMP包结构

RTMP包 包含一个固定长度的包头和一个最长为128字节的包体.包头可以是下面4种长度的任意一种:12, 8, 4, or 1 byte(s).
第一个字节的前两个Bit很重要,它决定了包头的长度.它可以用掩码0xC0进行"与"计算.下面的表格罗列了可能的包头长度:

Bits Header Length
00 12 bytes
01 8 bytes
10 4 bytes
11 1 byte

我们在这里讨论关RTMP包结构的问题并不是非常的详细.我们在以后有时间会讨论关于AMF的问题(敬请期待...),其实RTMP包结构就是使用了AMF格式.



关于流的操作我们需要进一步研究,在论坛中的http://www.openred5.com/bbs/viewthread.php?tid=175&extra=page%3D1这篇文章研究的还是不错的,大家可以参考.不过下面可以列一个关于客户端向服务器端发送流的流程:

Client→Server :发送一个创建流的请求.
Server→Client :返回一个表示流的索引号.
Client→Server :开始发送.
Client→Server :发送视音频数据包(这些包在同一个频道(channel)并用流的索引号来唯一标识).

应用:与flash播放器的应用实例(支持极酷阳光播放器

极酷阳光播放器调用RTMP协议视频(点播代码范例):

  1. <script type="text/javascript" src="/player/images/swfobject.js"></script> 
  2. <div class="video" id="CuPlayer"> <b> <img src="/player/images/loading.gif" /> 网页视频播放器加载中,请稍后...</b> </div> 
  3. <script type="text/javascript"> 
  4. var so = new SWFObject("/player/player.swf","ply","980","460","9","#000000"); 
  5. so.addParam("allowfullscreen","true"); 
  6. so.addParam("allowscriptaccess","always"); 
  7. so.addParam("wmode","opaque"); 
  8. so.addParam("quality","high"); 
  9. so.addParam("salign","lt"); 
  10. so.addVariable("JcScpServer","rtmp://www.cuplauyer.com/vod"); //你的rtmp流媒体服务器地址 
  11. so.addVariable("JcScpVideoPath","mp4:test.mp4"); //文件地址 
  12. so.addVariable("JcScpImg","/player/Images/start.jpg"); 
  13. so.addVariable("JcScpFile","/player/CuSunV2Set.xml"); 
  14. so.write("CuPlayer"); 
  15. </script> 

极酷阳光播放器调用RTMP协议视频(直播代码范例):

  1. <script type="text/javascript" src="/player/images/swfobject.js"></script>  
  2. <div class="video" id="CuPlayer"> <b> <img src="/player/images/loading.gif" /> 网页视频播放器加载中,请稍后...</b> </div>  
  3. <script type="text/javascript">  
  4. var so = new SWFObject("/player/player.swf","ply","980","460","9","#000000");  
  5. so.addParam("allowfullscreen","true");  
  6. so.addParam("allowscriptaccess","always");  
  7. so.addParam("wmode","opaque");  
  8. so.addParam("quality","high");  
  9. so.addParam("salign","lt");  
  10. so.addVariable("JcScpServer","rtmp://www.cuplauyer.com/live"); //你的rtmp流媒体服务器地址  
  11. so.addVariable("JcScpVideoPath","livestream"); //流地址  
  12. so.addVariable("JcScpImg","/player/Images/start.jpg");  
  13. so.addVariable("JcScpFile","/player/CuSunV2Set.xml");  
  14. so.write("CuPlayer");  
  15. </script>  

效果图:

酷播跨平台演示PC终端、安卓Android终端、苹果iOS终端、Windows Phone终端等主流终端

酷播跨平台演示PC终端、安卓Android终端、苹果iOS终端、Windows Phone终端等主流终端

极酷阳光播放器下载 :http://www.cuplayer.com/CuSunPlayer/download.html

热门文章推荐

请稍候...

保利威视云平台-轻松实现点播直播视频应用

酷播云数据统计分析跨平台播放器