前端显示
rtmp视频流仅能在pc端使用,所以我们在手机端使用hls的m3u8的流
假设你已经有自己的视频流了(没有也没事,博客下半部分会教你咋整)
先运行npm下载依赖video-js和vue-video-player
之后在vue中,直接运行下方代码(小白福利:直接新建vue项目将下方代码替换到新建项目自带的helloworld.vue里即可),将stream_video变量更改为自己的视频流,即可使用
ps:如果你有现成直接可用的rtmp和hls协议的流,你粘贴搬运完代码以后应该就可以使用了,如果你没有可供测试的流,请你继续往下看下面的步骤。
<template>
<section class="video-box">
<videoPlayer ref="videoPlayer" :options="videoOptions" class="vjs-custom-skin videoPlayer" :playsinline="true" />
</section>
</template>
<script>
import 'video.js/dist/video-js.css'
import 'vue-video-player/src/custom-theme.css'
import { videoPlayer } from 'vue-video-player'
import 'videojs-flash'
import 'videojs-contrib-hls' //引入才能播放m3u8文件
export default {
data() {
// var type_video = 'rtmp/hls';
// var stream_video = 'rtmp://39.102.46.223:1935/hls/test';
//pc
var type_video = 'rtmp/hls';
var stream_video = 'rtmp://192.168.110.141:1260/livehls/test';
//phone
if (this._isMobile()) {
type_video = 'application/x-mpegURL';
stream_video = 'http://192.168.110.141/livehls/test.m3u8';
}
return {
videoSrc: '',
// 视频播放
videoOptions: {
playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
autoplay: false, //如果true,浏览器准备好时开始回放。
muted: false, // 默认情况下将会消除任何音频。
loop: false, // 导致视频一结束就重新开始。
preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
language: 'zh-CN',
aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")
techOrder: ['html5', 'flash'], // 兼容顺序
sources: [{ // 流配置,数组形式,会根据兼容顺序自动切换
type: type_video,
src: stream_video
}, ],
poster: "", //你的封面地址
// width: document.documentElement.clientWidth,
notSupportedMessage: '此视频暂无法播放,请稍后再试', // 允许覆盖Video.js无法播放媒体源时显示的默认信息。
controlBar: {
timeDivider: true,
durationDisplay: true,
remainingTimeDisplay: false,
fullscreenToggle: true //全屏按钮
}
}
}
},
components: {
videoPlayer
},
methods: {
// 判断移动端还是pc端
_isMobile() {
let flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)
return flag;
},
qw() {
console.log(tt);
}
},
mounted: function() {
}
}
</script>
<style scoped>
.video-box {
width: 1000px;
padding: 20px;
}
</style>
如果没有可供测试的流:
你需要这些文件,请看下方链接下载
https://sunbossrs.coding.net/p/ws-data/d/ws-data/git/raw/master/res/rtmpobswin.txt
并附上视频教程:
来自B站 永恒的耀光SunbossRS 大佬
https://www.bilibili.com/video/BV1x54y1d7ZA?t=173
假设你已经安装完了并且已经按照他的操作做完了
那么恭喜你现在应该已经可以畅行无阻的看来自你本地的rtmp格式的流了
我们目前难点是在手机上播放的hls协议流的解决方案:
首先请您关闭nginx服务和obs推流软件,关闭完以后请继续下方操作
(1)打开你的 \nginx 1.7.11.3 Gryphon\conf\下的nginx-win.conf文件,在21行开始,修改成如下rtmp对象的样子
#大佬,下方是方便您复制的↓
rtmp{
server{
listen 1260;
chunk_size 4000;
application livehls {
live on;
hls on;
hls_path ./live;
hls_fragment 3s;
}
}
}
(2)下方从90行开始,修改成如下图所示
#大佬,下方是方便您复制的↓
#creates the http-location for our full-resolution (desktop) HLS stream - "http://my-ip/hls/my-stream-key/index.m3u8"
location /livehls {
types {
application/vnd.apple.mpegurl m3u8;
video/mp2t ts;
}
alias ./live;
add_header Cache-Control no-cache;
}
(3)可以打开您的obs推流软件了
画面啥也没有你就自己随便在软件中的“来源”那拽点吧,这就不多bb了
点击设置
按照下方填写
点击确定,然后点击开始推流
注:如果推流过程中提示
你需要在进到设置->输出 中,将编码器改为除了硬件(NVENC)之外的其他的
然后点击确定,再次点击开始推流,看到下方绿了,诶,就完事了,然后先别急,在网页上看之前,最好先拿VLC看一下,啥?你跟我说你不知道啥是VLC?
VLC啊!看各种视频接各种流都ok的,半人半鱼的美人鱼啊!(请自行百度下载,蟹蟹)
点击左上角的媒体,选中打开网络串流,然后输入我们最上方程序中的那两行中的某一个(如下,127.0.0.1可以换成你的ip,两个都试试昂,一个电脑的一个手机的,别跟虎逼是的试了一个另一个不管了)
rtmp://127.0.0.1:1260/livehls/test
http://127.0.0.1/livehls/test.m3u8
然后点击播放!然后坐等几秒!
PC端:(延时2秒左右)
手机端:(延时在20秒左右,请忽略我pc和手机的时间为啥差这么多,脑瓜子不好使,开始忘截手机上的图了)
奥利给兄弟们!