谷歌浏览器中video播放视频进度条无法拖动,一点击进度条就回到0重新播放

本文主要是介绍谷歌浏览器中video播放视频进度条无法拖动,一点击进度条就回到0重新播放,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题:一个.mp4视频进度条无法拖动,只在谷歌浏览器中有问题,火狐中没有问题,console也不报错。

初步排查到的bug原因:与Video标签适配的请求响应有问题。

无法拖动的视频响应截图如下:

能正常拖动的视频响应截图如下:

如何去解决:

1.Chrome浏览器默认请求会在 Header 添加一个Range如下:服务器要做的就是响应这个Header

Range:             bytes=0-

 2.服务器接收到这个Header以后,响应的Header如下,同时需要设置状态码为206:

Accept-Ranges: bytesContent-Length: 2097152Content-Range: bytes 0-2097151/38696534

3.百度了个服务端设置响应的代码,如下(我不太懂后台代码,仅供参考,有更好的解决方案,欢迎大家留言哈~):

    public ActionResult Video(Guid id){//数据库存储的文件路径var archive = ManagerFactory.ArchiveManager.GetVideoArchive(id);//物理绝对路径var path = Server.MapPath("~/" + archive.Path);//设置响应头HttpContext.Response.Headers.Add("Accept-Ranges", "bytes");//判定是否响应Chrome中的Range请求var rangeQuery = HttpContext.Request.Headers["Range"];if (rangeQuery.IsNotNullAndNotEmpty()){//startIndex 与 endIndex 是索引值,是0开始的,注意在与 Length 比较的时候 Length 要 -1var startIndex= 0;//视频每节长度为2MBvar length = 2 * 1024 * 1024;var range = rangeQuery.Split('=')[1].Split('-');startIndex= range[0].ParseToInt();var endIndex = startIndex + length - 1;var fileLength = (int)archive.Length;//是否指定了索引终结点if (range[1].IsNotNullAndNotEmpty()){endIndex = range[1].ParseToInt();}if (endIndex <= startIndex ){endIndex = startIndex + length - 1;}if (endIndex > fileLength - 1){endIndex = fileLength - 1;}//关键设置HttpContext.Response.Headers.Add("Content-Range", $"bytes {startIndex}-{endIndex}/{archive.Length}");//关键设置HttpContext.Response.StatusCode = 206;//按照索引读取文件流using (var fs = System.IO.File.OpenRead(path)){var buffer = new byte[endIndex - startIndex + 1];fs.Position = startIndex ;fs.Read(buffer, 0, buffer.Length);return File(buffer, archive.ContentType);}}//如果未设置则返回整个文件return File(path, archive.ContentType);}

 

这篇关于谷歌浏览器中video播放视频进度条无法拖动,一点击进度条就回到0重新播放的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/933133

相关文章

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

如何在Mac上彻底删除Edge账户? 手动卸载Edge浏览器并清理残留文件技巧

《如何在Mac上彻底删除Edge账户?手动卸载Edge浏览器并清理残留文件技巧》Mac上的Edge账户里存了不少网站密码和个人信息,结果同事一不小心打开了,简直尴尬到爆炸,想要卸载edge浏览器并清... 如果你遇到 Microsoft Edge 浏览器运行迟缓、频繁崩溃或网页加载异常等问题,可以尝试多种方

Python如何将OpenCV摄像头视频流通过浏览器播放

《Python如何将OpenCV摄像头视频流通过浏览器播放》:本文主要介绍Python如何将OpenCV摄像头视频流通过浏览器播放的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完... 目录方法1:使用Flask + MJPEG流实现代码使用方法优点缺点方法2:使用WebSocket传输视

CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)

《CSSAnchorPositioning重新定义锚点定位的时代来临(最新推荐)》CSSAnchorPositioning是一项仍在草案中的新特性,由Chrome125开始提供原生支持需... 目录 css Anchor Positioning:重新定义「锚定定位」的时代来了! 什么是 Anchor Pos

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地

VS配置好Qt环境之后但无法打开ui界面的问题解决

《VS配置好Qt环境之后但无法打开ui界面的问题解决》本文主要介绍了VS配置好Qt环境之后但无法打开ui界面的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目UKeLvb录找到Qt安装目录中designer.UKeLvBexe的路径找到vs中的解决方案资源