网站建设资讯

NEWS

网站建设资讯

zblog播放m3u8 zblogphp

android有什么控件(如MediaPlayer)可以直接播放m3u8格式的视频吗?求大神给个dome或思路啊!

PC端我一直用的VLC media player

创新互联建站主营淮南网站建设的网络公司,主营网站建设方案,手机APP定制开发,淮南h5小程序定制开发搭建,淮南网站营销推广欢迎淮南等地区企业咨询

android上没注意有没有类似APP 我在项目中用的是这两个东西

// 视频流

api 'com.qiniu:happy-dns:0.2.13'

api files('libs/pldroid-player-1.5.1.jar')

android 判断m3u8 流是直播还是点播

简单来说:android是在sdk4.0以后才开始支持m3u8的播放,

sdk4.0以后可以使用VideoView来直接播放m3u8文件,但它只支持视频的在线播放,

如果你的app需要支持视频的离线下载,然后在没有网络的情况下用VideoView播放本地下载好的m3u8文件 那么思路很简单 就是使用socket实现一个本地代理服务来处理视频数据.

zblog图片地址变了

前段时间为了优化企业的一个网站,就在这个网站里嵌套了一个zblog,没到设置伪静态后,上传图片后,图片地址显示是404,研究了很久才找到原因。下面将解决方法介绍给大家:

一开始我以为是服务器问题,于是就各种调试IIS,最后差点把服务器搞坏了。好在功夫不负有心人,最后发现原来是图片权限问题,只要将上传的图片的权限加一个everyone权限,这样问题就自然解决了。

还有一种方法就是不适用伪静态,直接使用动态,这样图片也会正常显示。

下一篇: 如何使用关键词规划师在搭建账户之前就屏蔽掉无效词 上一篇:什么是URL标准化,URL标准化设置

相关文章

什么是404错误代码

虚拟主机怎么设置404页面?

网站为什么不要轻易改版,频繁改版对网站SEO有哪些伤害

zblog程序IIS环境下上传视频为什么不能显示,播放不了

zblog应用中心无法升级怎么办

zblog标签与后台功能访问500错误问题

zblog如何搬家?

详细介绍zblogphp如何调用热门、随机等文章列表

著名的经典网站开源程序xiuno与大家说再见

如何使用requests模拟登陆zblog

评论

提交评论

访客回复

2019-08-21 22:07:01

谢谢分享,这个问题一直困扰了我很久

备案号:浙ICP备12040699号-2网站地图Powered By Zblog 博主:启明SEO 专注互联网营销

rtsp流浏览器播放方案

rtsp流在主流浏览器并不支持直接播放。比如大华的视频流:rtsp://admin:123456@

192.168.10.129/cam/realmonitor?channel=1subtype=0,用vlc可以直接播放。但在浏览器会报ERR_UNKNOWN_URL_SCHEME。那如何在浏览器中播放呢。

以下列出几种方案。

1、安装插件(chrome最新版基本都不支持)

类如:kurento,vlc插件(谷歌浏览器版本41以下),vgx插件(不支持高版本,chrome72.0版本可用)等。

2、安装软件(中间件,基本都付费)

类如:Appemit(调用vlc插件播放rtsp),可以免安装的,目前只能windows,免费版会有提示。

猿大师中间件(底层调用VLC的ActiveX控件,实现在主流浏览器网页中内嵌播放多路RTSP的实时视频流),中间件收费的。

PluginOK(牛插)中间件。底层调用ActiveX控件VlcOcx.dll。(商业用途需付费使用)

3、服务器拉流转发及协议转换

示意图如下所示:

推流--------------服务器转发--------------拉流

方法一览:

a,vlc软件串流到http协议 ,网页显示几个视频需启动几个vlc,只适合应急场景。

b,html5 + websocket_rtsp_proxy 实现视频流直播 ,基于MSE(Media Source Extensions,W3C),扩展H5的功能。

步骤:服务器安装streamedian服务器,客户端通过video标签播放。

原型图:

价格:

c.基于nginx的rsmp转发

基于nginx实现rtmp转化,用flash实现播放。由于flash目前大多浏览器默认禁用,不推荐此方式。

步骤:安装ffmpeg工具,安装nginx。

另外nginx-rtmp-module也支持HLS协议,可以搭建基于hls的直播服务器。

d.rtsp转hls播放,通过ffmpeg转码

步骤:安装ffmpeg工具,ffmpeg转码。

形如:

ffmpeg -i "rtsp://admin:123456@192.168.10.129/cam/realmonitor?channel=1subtype=0" -c copy -f hls -hls_time 2.0 -hls_list_size 0 -hls_wrap 15 "D:/hls/test.m3u8"

缺点是直播流延时很大,对实时要求比较高的不满足要求。

案例:基于EasyDarwin拾建转码服务器。参考地址:

通过存储的m3u8去读取。

e.websocket代理推送,FFMPEG转码

此方法与a,b类似。但更实用。

以下提供两种方案:

(1)Gin+WebSocket+FFMPEG实现rtsp转码,参考:

通过FFMPEG把rstp转成http,ginrtsp作为转发服务器,但需要自己写相应接口,需要了解go语言。

(2)node + ffmpeg + websocket + flv.js,参考:

步骤:在node服务中建立websocket;通过fluent-ffmpeg转码,将RTSP 流转为flv格式;通过flv.js连接websocket,并对获取的flv格式视频数据进行渲染播放。

import WebSocket from 'ws'import webSocketStream from 'websocket-stream/stream'import ffmpeg from 'fluent-ffmpeg'// 建立WebSocket服务const wss = new WebSocket.Server({ port: 8888, perMessageDeflate: false })// 监听连接wss.on('connection', handleConnection)// 连接时触发事件function handleConnection (ws, req) {  // 获取前端请求的流地址(前端websocket连接时后面带上流地址)  const url = req.url.slice(1)  // 传入连接的ws客户端 实例化一个流  const stream = webSocketStream(ws, { binary: true })  // 通过ffmpeg命令 对实时流进行格式转换 输出flv格式  const ffmpegCommand = ffmpeg(url)    .addInputOption('-analyzeduration', '100000', '-max_delay', '1000000')    .on('start', function () { console.log('Stream started.') })    .on('codecData', function () { console.log('Stream codecData.') })    .on('error', function (err) {      console.log('An error occured: ', err.message)      stream.end()    })    .on('end', function () {      console.log('Stream end!')      stream.end()    })    .outputFormat('flv').videoCodec('copy').noAudio()  stream.on('close', function () {    ffmpegCommand.kill('SIGKILL')  })  try {    // 执行命令 传输到实例流中返回给客户端    ffmpegCommand.pipe(stream)  } catch (error) {    console.log(error)  }}

优点全部基于js。前端即可搞定。

参考:


文章名称:zblog播放m3u8 zblogphp
网页URL:http://cdweb.net/article/dddhssh.html