Safari 不能播放Video ,Chrome等可以 问题解决。
1 原因分析
https://www.zhihu.com/question/41818719
2 代码实现
1 注意点: 请求时 : header中 range 请求多少长度 代码要返回相应的长度 比如Byte 0-1
/// <summary>
/// 返回mp4 兼容苹果
/// </summary>
/// <param name="context"></param>
/// <param name="filePath"></param>
private void CreateVideoResponse(HttpContext context, string filePath)
{
var reqRange = context.Request.Headers["Range"];
string[] reqBlockRange = null;
if (!string.IsNullOrEmpty(reqRange))
{
reqBlockRange = reqRange.Replace("bytes=", "").Split(new[] { "-"},StringSplitOptions.RemoveEmptyEntries);
context.Response.StatusCode = ;
context.Response.AddHeader("status", "");
}
using (var stream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))
using (var reader = new BinaryReader(stream))
{
long fileSize = stream.Length; long startPosition = ;
long partialSize = fileSize;
if (reqBlockRange != null)
{
//safari
startPosition = Convert.ToInt64(reqBlockRange[]);
if(reqBlockRange.Length > )
{
long endPosition = fileSize;
if (long.TryParse(reqBlockRange[], out endPosition))
{
partialSize = endPosition - startPosition + ;
}
}else
{
// chrome 等
partialSize = fileSize - startPosition;
}
} byte[] buffer = new byte[(int)partialSize];
reader.BaseStream.Seek(startPosition, SeekOrigin.Begin);
reader.Read(buffer, , (int)partialSize); context.Response.AddHeader("accept-ranges", "bytes");
context.Response.AddHeader("access-control-allow-methods", "HEAD, GET, OPTIONS");
context.Response.AddHeader("cache-control", "public, max-age=30726563");
context.Response.ContentType = "video/mp4";
context.Response.Cache.SetLastModified(DateTime.Now);
context.Response.AddHeader("Connection", "keep-alive");
context.Response.AddHeader("content-range", $"bytes {startPosition}-{startPosition + partialSize-1 }/{fileSize}");
context.Response.AddHeader("Content-Length", $"{partialSize}");
context.Response.BinaryWrite(buffer);
} }
Safari 不能播放Video ,Chrome等可以 问题解决。的更多相关文章
- Animator 动画第一次播放正常,之后播放都不正常的问题解决
		
Animator 动画第一次播放正常,之后播放都不正常的问题解决 问题描述 第一次点击图片动画播放正常,在点击文字之后,图片没有显示出来,点击空白,播放动画,显示文字. 写了一个卡片翻转的动画,代码如 ...
 - html5 点击播放video的方法
		
html5 点击播放video的方法<pre> <video videosrc="{$vo.shipinurl}" controls="" x ...
 - Video标签播放视频?谷歌浏览器?safari??  谷歌浏览器播放不了mp4格式的视频的原因
		
webm格式和mp4格式,判断了浏览器能否支持的视频类型后,给了一个if判断,如果是支持mp4格式,就返回视频后缀mp4,如果是webm,就返回后缀webm.结果,在谷歌浏览器中播放不了,为什么我指定 ...
 - 【转】Android HTML5 Video视频标签自动播放与自动全屏问题解决
		
为了解决 HTML5Video视频标签自动播放与全屏问题,在网上找了很多相关资料,网上也很多关于此问题解决方法,但几乎都不能解决问题,特别对各大视频网站传回来的html5网页视频自动播放与全屏问题,我 ...
 - safari坑之 video
		
博客地址: https://www.seyana.life/post/19 本来是打算给博客左上角的gif做个优化, 把gif换成webm,以video的形式自动播放,能从180k降到50k, 现在浏 ...
 - google无法播放mp4 chrome无法播放h264
		
写在前面 我在chrome上无法播放h264+Acc的mp4,在firefox.ie都可以播放,而且此mp4在vlc终可以正常播放. 视频链接:http://106.14.221.185:7001/p ...
 - CSS Hack技术详解,支持IE 6-11、Chrome、FireFox、Safari、Opera 6-11、Chrome、FireFox、Safari、Opera6-11、Chrome、FireFox、Safari、Opera6-11、Chrome、FireFox、Safari、Opera
		
转自: http://www.365mini.com/page/css-hack-ie-chrome-firefox-safari-opera.htm 当前网络时代,各种各样的网页向我们展示着丰富多彩 ...
 - 【实战问题】【3】iPhone无法播放video标签中的视频
		
问题:视频都是MP4格式,视频可以在手机上正常播放.video标签中的视频在安卓点击可以播放,但在iPhone无法播放 解决方案: 1,视频编码格式问题,具体iPhone手机支持的是哪些格式可见官方的 ...
 - [完美]原生JS获取浏览器版本判断--支持Edge,IE,Chrome,Firefox,Opera,Safari,以及各种使用Chrome和IE混合内核的浏览器
		
截至自2017-08-11,支持现世已出的几乎所有PC端浏览器版本判断. 受支持的PC端浏览器列表: Edge IE Chrome Firefox Opera Safari QQ浏览器 360系列浏览 ...
 
随机推荐
- [z]hadoop生态系统
			
http://developer.51cto.com/art/201311/415639_all.htm
 - Golang之fmt格式“占位符”
			
golang的fmt包实现了格式化I/O函数: package main import "fmt" type Human struct { Name string } func m ...
 - MySQL中触发器
			
触发器是与某个事件相关的特殊存储过程,与存储过程不同的是,存储过程需要用 call 调用而出发器不需要使用call调用调用. 也就是自己预先定义好了,当某个事件发生时,就会自动出发触发器进行相关的操作 ...
 - io.fabric8.kubernetes对pv和pvc的增删查改
			
1.新建maven项目k8stest,pom.xml如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns: ...
 - linux nkf 日文编码转换命令[转载]
			
对于日语的编码 windows : Shift-JIS Linux : 2.4内核使用EUC编码,2.6内核中使用UTF8编码 检查文件编码 nkf -g filename 通常处理字符编码都使用i ...
 - Activity ViewPager Fragment框架的生命周期
			
1.Fragment的生命周期函数 onAttach.onCreate.onCreateView.onViewCreated.onActivityCreated.onStart.onResume.on ...
 - handsontable-developer guide-cell editor
			
单元格编辑 cell editor renderer:展示数据:editor:改变数据:renderer用一个函数表示:后者有一系列的操作,需要用class来表示: EditorManager han ...
 - 深水划水队项目---七天冲刺之day5
			
站立式会议: 因为今天有成员回家,不能进行线下站立式会议,只能线上进行语音聊天 工作进度: 昨天完成的任务: 游戏功能的基本实现 商讨出如何实现游戏中的难度选择功能与道具功能 商讨出站立式会议能线下 ...
 - JavaScript中的垃圾回收和内存泄漏
			
摘要: JS内存管理. 作者:浪里行舟 Fundebug经授权转载,版权归原作者所有. 前言 程序的运行需要内存.只要程序提出要求,操作系统或者运行时就必须供给内存.所谓的内存泄漏简单来说是不再用到的 ...
 - 45 Useful JavaScript Tips, Tricks and Best Practices
			
<45 Useful JavaScript Tips, Tricks and Best Practices> http://flippinawesome.org/2013/12/23/45 ...