网站中视频都转换成flv格式,奈何flv格式无法拖拽,此问题纠结了好久,最终得以解决。现将解决思路记录下来,大多数源于网上找到的。

视频拖拽满足要求

1.播放器要支持

2.flv视频要有关键帧和meta信息

3.服务器端要支持

总体而言分两步:

一、视频关键帧的处理;二、Nginx代理服务器

1. 问题的产生

Flash视频播放方案原理其实比较简单:网页端放置一个Flash编写的播放器,播放器通过http协议访问一个flv文件,通过Flash本身的视频解码功能进行视频播放。在播放过程中,为了视频的流畅播放器会对接下来要播放部分的数据做一些预读取。

具体来说,我们只需要把flv文件放在网站目录下,让播放器指向这个地址就可以播放了。

但是,这样制作好的播放器方案,在实际使用中会遇到一个问题:当用户拖动进度到还未缓冲的部分时,播放器会停止播放或者是回到视频的开始。这就是标题中的“对未缓冲进度条实现拖动”。

2. 原理与解决

设想一下,对于本地视频文件的拖动,播放器需要调用哪些接口才能实现呢?

  1. 通过某个API得知视频中某时刻对应的数据相对于文件头的偏移量;
  2. 通过某个API得到视频数据中指定偏移量以后的数据;
  3. 播放器本身要支持偏移访问和播放

对于网络是视频,同样需要这两个关键的接口。很遗憾的,默认状态下(上面说的把flv文件直接放在IIS host的目录下)这两个条件都不具备。

  1. Flv文件一般不包含keyframe和meta信息。keyframe就是关键帧,而meta是元数据,通过它们,我们才能知道视频时间所对应的文件偏移量。
  2. IIS不提供文件位置偏移访问接口。

如何是好呢?有条件要上,没有条件创造条件也要上!对于Flv文件,那当然是加上keyframe和meta就好,如何加法待会儿一一道来。对于文件偏移访问接口,有两个思路:

  1. 替换掉IIS,使用支持偏移访问的Flv嘛;
  2. 给IIS创造文件偏移访问的接口,iis extension、custom http handler和server side script都可以。

3. 实现

3.1 flv文件的meta生成

上面提到,flv需要有meta信息才能正确地被分析并根据时间获取偏移量。有两个工具可以补全meta信息:

两者都是命令行工具,也都有windows版本,下载了直接用就好。这里简单介绍一下用法:

flvtool2:

flvtool2 –U <input file> <output file>

  1. /// <summary>
  2. /// 处理flv实现添加matedata信息
  3. /// </summary>
  4. /// <param name="toolpath">toolpath="/FilesList/Exe/VideoTools/flvtool2.exe"</param>
  5. /// <param name="filepath">视频地址</param>
  6. public void flvtodrog(string toolpath, string filepath)
  7. {
  8. System.Diagnostics.ProcessStartInfo startInfo = new System.Diagnostics.ProcessStartInfo(toolpath);
  9. startInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;
  10. startInfo.UseShellExecute = false;
  11. startInfo.CreateNoWindow = false;
  12. startInfo.Arguments = " -U " + filepath;
  13. try
  14. {
  15. System.Diagnostics.Process.Start(startInfo);
  16. }
  17. catch (Exception e)
  18. {
  19. //
  20. }
  21. }

jamdi:

jamdi –i <input file> –o <output file>

如此,meta信息就补全了。

3.2 使用IIS作为Web服务器的方法

IIS是Windows默认Web服务器,在Windows下不用它很难(虽然不少装Apache的),而且尤其是当你的网站是ASP.net写成的话。上面说过,IIS默认是不支持文件偏移访问的,我们要创造条件让它能够支持。这里提供两种方法:

3.2.1 Custom Http Handler

给IIS置入一个Custom Http Handler,让它来处理所有对flv的请求,这就行了。简略的步骤是:

1、使用任何一种CLR语言编写一个Custom Http Handler,这个Handler接受两个参数,第一个是flv文件名,第二个是start为参数名的偏移量,返回这个偏移量到文件尾的所有数据。

2、将上面的Http Handler部署到IIS中。

3、在IIS中将所有对.flv文件的访问定向到这个Custom Http Handler上。

具体的步骤还是挺多,有人总结的很好,这里不再重复了。步骤和源代码在这里

3.2.1 PHP代理

当IIS已经配置好了PHP的时候,使用PHP代理也不失为一种简洁有效的方法了。这种方法的步骤非常简单:

1、编写一个php页面,这个页面接受两个参数,第一个是文件名,第二个是start为参数名得偏移量,php读取flv文件并返回从偏移量到文件尾的数据。

步骤相当简单,而且这个解决方案几乎是可以横跨所有Web Server和所有操作系统了,只要是能执行php的地方都可以应用。但是这种方法有两个缺点:

  • PHP的效率可能会有问题;
  • 对flv文件的位置有限制(这一点当你看了下面连接中的php代码以后就能了解)

具体的PHP代码见这里

3.3 使用其它Web服务器

其实下面这些服务器都可以通过插件实现这功能:

基本主流的Web Server都有支持了,不过基本也都要求在编译时通过开关把这部分包含进去。

经过我的试验,最新的Nginx 1.0 for windows这个版本默认已经开启了这个开关,我们直接下载使用就好。既然标题上说的是“Windows服务环境下”,这里就大概说一下如何配置:

  1. nginx服务器下载最新的nginx 1.0 for windows,解压以后放置在某个目录下。
  2. nginx目前还没有写成windows服务,而只是应用程序。但是我们可以用这篇文章的办法,将它转变为一个服务。
  3. 在配置文件conf/nginx.conf中,添加如下语句:

location ~ \.flv$ 

flv; 
}

这里要注意,上面关于Nginx的参考文献中,这个配置写错了,将“flv;”写成了“.flv;”。

3.4 播放器支持

上面描述了服务端和视频所要实现的部分,最后一步是要一个支持拖动的flv播放器。这里推荐两个很成熟的播放器吧,他们对于非商业应用都是免费开源,而商业应用的价格也不贵:

  1. FlowPlayer:http://flowplayer.org/index.html
  2. JW Player:download.csdn.net/detail/chenxiang199055/5795723

这两个播放器都有很详细的文档介绍如何支持所谓的流媒体(Flv streaming),也就是本文说的拖动。

4. 其它

本文介绍的解决方案,其实有很多种名字:

  • Flv(flash) Streaming
  • Pseudostreaming
  • Flv未缓冲视频拖动

从第二个名字看来,它是一种“假”的流媒体。但是这种方案比起假设真的流媒体服务器并不逊色,不用架设专业甚至昂贵的流媒体服务器。也算是一种DIY的收获吧。

其实FlowPlayer的网站上也有一篇非常详细的综述性质的文章,可以和本文互为参考。

另外,对于高清视频,H264有一个比较统一的解决方案(IIS、Nginx、Apache、Lighttpd全机种制霸了),不用像flv这么折腾,具体参考这里

5. nginx安装与配置

首先配置nginx服务支持flv模块功能

⑵安装支持flv模块的nginx服务器:

nginx下载地址http://download.csdn.net/detail/chenxiang199055/6204511

解压至c:\nginx,运行nginx.exe(即nginx -c conf\nginx.conf),默认使用80端口(建议修改,资源中默认端口为8055),日志见文件夹C:\nginx\logs

cd c:\
cd nginx
start nginx
nginx -s stop 快速退出
nginx -s quit 优雅退出
nginx -s reload 更换配置,启动新的工作进程,优雅的关闭以往的工作进程
nginx -s reopen 重新打开日志文件

打开http://127.0.0.1:端口号/ 可以看到nginx欢迎页,如果没有看到检查nginx配置

⑶nginx服务器配置(nginx.conf文件)

server

{

listen       80;   //此端口号如果被占用可以修改,建议修改

server_name  localhost;

charset utf-8;

location / {

root   html; //此处指flv视频所在文件夹,注意修改

index  index.php index.html index.htm;

}

location ~ \.flv {

flv;

limit_rate_after 10m;

limit_conn one 1;

limit_rate 85k;

}

}

使用location 将 .flv的文件指向flv模块即可。

以上使用了limit_rate 是为了限速,当 flv视频下载超过10M,则限速到85K,只允许用户开1个进程,也就是先快速缓存可以播放,后面的慢慢下载。

⑷安装支持flv拖放进度条的播放器

上面三步都是安装支持nginx服务支持flv功能的,现在需要支持flv拖放进度条的播放器.

你需要有一个能够播放Flv视频的播放器,很显然,它还需要能够嵌入到网页中。目前比较流行的,功能上也还比较完善的一个Flv播放器就是 JW FLV Media Player(也称为 jwplayer)。它的网址是:

http://www.longtailvideo.com/players/jw-flv-player/

这个播放器支持视频加入广告和视频节目单功能,

下载包里面有很全的实例和使用方式,

将包中的player.swf(如果是带有Viral插件的,就是player-viral.swf)放到你的网站内,这就是用来提供视频播放的播放器。至于包中其它的文件,都可以不要。

接下来,将播放器嵌入到你的视频播放网页中:

直接嵌入,使用Object/Embed代码嵌入:

<embed

type="application/x-shockwave-flash"

id="player2"

name="player2"

src="player.swf"

width="328"

height="200"

allowscriptaccess="always"

allowfullscreen="true"

flashvars="file=http://192.168.40.135/test.flv&image=http://192.168.40.135/preview.jpg&autostart=false&type=http&streamer=start"

>  </embed>

file:"video.flv", // FLV视频地址

type:"http",        // 数据类型,本文是基于http模式的,这个必须写滴

image:"preview.jpg",// 开始播放之前的预览图

autostart:"false",  // 是否自动播放

streamer:"start",   // 参数为 “start”,这个参数用于传递给服务器从特定的关键帧开始播放,nginx编译了 flv 模块 所以是支持的。。

⑸添加关键帧

如果一个Flv视频要能够被拖到特定点播放,该Flv需要在其metadata中有关键帧的信息。如果你的Flv视频制作的时候没有这些信息,也是不能拖放播放的。可以使用yamdi来为你的视频加上关键帧信息 :

安装:

1 [root@localhost ~]#wget http://sourceforge.net/projects/yamdi/files/yamdi/1.4/yamdi-1.4.tar.gz/download

2 [root@localhost ~]#tar zxvf yamdi-1.4.tar.gz

3 [root@localhost ~]#cd yamdi-1.4/

4 [root@localhost yamdi-1.4]#make && make install

使用方法:

yamdi -i source.flv -o dest.flv //原视频 输出视频

windows下flv视频网站进度条随意拖放[转]的更多相关文章

  1. ajax 异步上传视频带进度条并提取缩略图

    最近在做一个集富媒体功能于一身的项目.需要上传视频.这里我希望做成异步上传,并且有进度条,响应有状态码,视频连接,缩略图. 服务端响应 { "thumbnail": "/ ...

  2. MediaPlayer音乐播放器、上一首、下一首、播放、停止、自动下一首、进度条

    本文介绍MediaPlayer的使用.MediaPlayer可以播放音频和视频,另外也可以通过VideoView来播放视频,虽然VideoView比MediaPlayer简单易用,但定制性不如用Med ...

  3. VideoView视频缓冲进度条

    效果图: 需求: 刚进入视频播放页时,屏幕中间有加载进度条 视频播放过程中,视频界面不动了,正在缓冲时,屏幕中间有加载进度条 private ObjectAnimator rotate; ImageV ...

  4. 【原】Github系列之三:开源iOS下 渐变颜色的进度条WGradientProgress

    概述 今天我们来实现一个iOS平台上的进度条(progress bar or progress view).这种进度条比APPLE自带的更加漂亮,更加有“B格”.它拥有渐变的颜色,而且这种颜色是动态移 ...

  5. 《C/C++实现Console下的加载进度条模拟[美观版]》

    前言   有时候我们会遇到在CMD或DOS控制台上出现的加载进度条,虽然不是如网页和软件写的美观.但确确实实也有着自己的特色.而且,一个好看的加载进度条也能增加用户使用控制台程序的体验!所以,拿来研究 ...

  6. windows server 2008 R2开机进度条闪过后黑屏

    起因:想在2008中添加hyper-v角色 事件经过: 1.在服务器管理器中添加hyper-v角色,重启,一直配置失败. 2.在bios开启vt-x,重新添加hyper-v角色,重启,进度条闪一下之后 ...

  7. samba服务器共享开发【windows下开发linux网站】

    //@author:yuan<turing_zhy@163.com> //@date:2018-08-05 //注:码字不易转载请注明出处 //环境准备:ubuntu1~16.04.4 1 ...

  8. Windows下搭建Apache网站

    目录 Apache下载 Apache安装 httpd.conf文件格式说明 启动服务并测试 Apache下载 在Apache官网底部找到APACHE PROJECT LIST里的HTTP Server ...

  9. 支持n多视频网站的下载,推荐 you-get

    其实刚开始是想下载youtube视频, 网上找了下 其中之一:http://jingyan.baidu.com/article/39810a23d2deb2b637fda66c.html 访问一个在线 ...

随机推荐

  1. 初始Hibernate4

    Hibernate是一个ORM的轻量级框架,解决持久化操作,使得程序员可以从编写繁复的jdbc的工作中解放出来,专注与业务,提高我们的开发效率.移植性. 1.持久化    a) 侠义概念:数据存储在物 ...

  2. Angular Material Starter App

      介绍 Material Design反映了Google基于Android 5.0 Lollipop操作系统的原生应用UI开发理念,而AngularJS还发起了一个Angular Material ...

  3. 「Luogu4321」随机游走

    「Luogu4321」随机游走 题目描述 有一张 \(n\) 个点 \(m\) 条边的无向图,\(Q\) 组询问,每次询问给出一个出发点和一个点集 \(S\) ,求从出发点出发随机游走走遍这个点集的期 ...

  4. AtCoder Regular Contest 81

    链接 C.Make a Rectangle 给出一堆木棍的长度 从中选4根,询问在能围成矩形的情况下,矩形的最大面积 开个map统计一下就行 分正方形和矩形分别统计即可 复杂度$O(n \log n) ...

  5. luoguP4115 QTREE4 链分治

    具体看$qzc$论文吧......陈年老物了...... 主要注意每个链头一棵线段树而不是一棵全局线段树 修改操作写完就是正确的,反而是初始化调了好一会...... 跑的还是很快的,有些地方没优化常数 ...

  6. python爬取基础网页图片

    python基础爬虫总结 1.爬取信息原理 与浏览器客户端类似,向网站的服务器发送一个请求,该请求一般是url,也就是网址.之后服务器响应一个html页面给客户端,当然也有其他数据类型的信息,这些就是 ...

  7. 升级到php7和安装拓展(mac centos)

    Mac升级到php7 使用homebrew安装php7 brew update #更新源 brew search php #查找源中的php,发现有php7.1版本,安装最新的php7.1 brew ...

  8. python 用gensim进行文本相似度分析

    http://blog.csdn.net/chencheng126/article/details/50070021 参考于这个博主的博文. 原理 1.文本相似度计算的需求始于搜索引擎. 搜索引擎需要 ...

  9. hssworkbook 用法案例

    public ActionResult excelPrint() { HSSFWorkbook workbook = new HSSFWorkbook();// 创建一个Excel文件 HSSFShe ...

  10. PHP闭包--匿名函数

    匿名函数(Anonymous functions),也叫闭包函数(closures),允许 临时创建一个没有指定名称的函数.最经常用作回调函数(callback)参数的值.当然,也有其它应用的情况. ...