基于微信的HTML5直播

2016-07-21  本文已影响2115人  syncwt

基础温习

大家可以先看一下我原来的一篇博文Red5-server流媒体服务器搭建及转HLS格式这样就很好理解我接下来的直播环境搭建了。

功能模块概述

通过obs客户端推流到nginx流媒体服务器上,对流媒体用ffmpeg将流剪切为若干段ts流文件并保存到临时目录中,通过访问m3u8格式拼接ts流文件段来观看直播。

推流端

采用开源工具OBS客户端进行推流

回到主界面,右键来源,选择添加视频捕捉设备或获取窗口等(相关设置默认即可),点击开始串流,便可开始直播。

添加场景

图为添加视频捕捉设备后的直播画面:

直播中

流媒体服务器

rtmp_auto_push on;
rtmp {
    server {
        listen 1935; 
application hls {
            live on; 
            hls on; 
            hls_path /tmp/hls; 
            on_publish http://公网ip的项目地址/liveOnPublish; 
            on_publish_done http://公网ip的项目地址/liveOnDone; 
            notify_method get;
        }
}
}

配上我在word上的注解

注解1
http {
server {
        listen  80; 
        server_name  localhost;
   location /hls  {
            secure_link $arg_st,$arg_e;
            secure_link_md5 key$arg_e; 
            subs_filter .ts '.ts?st=$arg_st&e=$arg_e&clentip=$remote_addr';
            subs_filter_types application/vnd.apple.mpegurl; 
            if ($secure_link = "") {
                 return 402;
            } 
            if ($secure_link = "0") {
                 return 403;
            } 
            # Serve HLS fragments
            types {
                application/vnd.apple.mpegurl m3u8;
                video/mp2t ts;
            }
            root /tmp; 
            add_header Cache-Control no-cache;
        }
}
}
注解2

项目部署服务器

流媒体服务器不通过项目服务器,整个直播过程的推流和处理流都在流媒体服务器上进行。项目服务器主要进行直播地址加密处理意见推流开始和结束触发的方法(liveOnPublish(),liveOnDone())已及对直播地址加密.

播放端

直接通过HTML5中的<video>标签设置src来播放直播流。如:

<video src="http://127.0.0.1/pro/live.m3u8?st=UM/L8jdfTlY2b1j1F6XSxA==&e=1468548530
" controls="controls"></video>

存在的问题

上一篇 下一篇

猜你喜欢

热点阅读