H5 video跨域问题
事情是这样的,今天上午下班前,朋友发我一个js文件,说视频不播放,核心代码大概是这样子的:
var player = document.createElement('video');
var source = document.createElement('source');
player['id'] = 'videoplayer';
player['class'] = 'video-js vjs-default-skin ';
player['controls'] = ' ';
player['poster'] = vPng;
player['preload'] = 'auto';
player['data-setup'] = '{"fluid": true}';
player['muted'] = 'true';
player['autoplay'] = 'true';
source['type'] = 'video/mp4';
source['src'] = vUrl; document.body.appendChild(player);
document.getElementById("videoplayer").appendChild(source);
朋友说,在浏览器上播放正常,但是在android浏览器,app的webview里也不正常。
我这边看了一下,也是只有一个封面而已,mp4文件响应200,返回100K以内的数据,response headers里面的Connection:Close。
我是谁,Copying and Pasting from Internet 技能点满了的人,
于是,发动了我的技能:
第一个看到了吧,google的devtool 结合Chrome使用,但是这货色iMac结合Chrome的,所以用Google的这个不大合适,
然后荐了我之前用过的weinre。
与好奇心和责任心无关,本着八卦与无聊的精神,我追着问结果,
追问结果到下午,好友上线告诉我结果:webview没有报错,代码也正常,就是不报错。
这时候,我无意之中刷新了一下页面,我了个擦,居然有了。
怎么回事?莫非是缓存问题?
clear browser cache, clear cookie, restart nodejs server。(用的nodejs做的静态文件服务器,file:的话会有一些其他的问题)
问题又粗线了:只有一个封面,毛都播放不了。
直接访问mp4文件,播放正常。
这尼玛是不是一个跨域问题啊?
于是将跨域的资源统统下载到我的Nodejs静态服务器,
将video的src路径改为本地服务器的相对路径,
Bingo!
一切正常得不能再正常了。
至此,
可以确定是一个跨域所导致的加载问题,
给video添加crossOrigin = '*';
没啥卵用。
response headers里面Access Allow Origin根本就没有,
于是跟朋友讲需要去资源服务器里面加一下配置。
但是,
这个不是他们公司的维护范围;
叫他下载到他们的服务器里面去,
马蛋,不鸟我。
于是,
我又发挥了我的第二个满点技能,
走偏门。
有什么元素可以绕过跨域限制的呢?
似乎有个iframe可以用。
科科。
于是在上面那段代码前面加上:
var iframe = document.createElement('iframe');
iframe['src'] = vUrl;
iframe['width'] = 580;
iframe['height'] = 434;
document.body.appendChild(iframe);
return;
搞定,跨你妹个蛋的域哇。
咩哈哈!!!
虽然问题看起来是解决了,
但是我告诉他最终解决方案不是这个,
因为你这么嵌入页面的话是非常危险的。
同时也不推荐大家去随便嵌入别人的网页到自己的应用中,
因为很危险哪。
正式的解决方案还是要靠去资源服务器添加跨域访问限制的配置。
最后是一张正常访问和不正常访问的请求响应的对比图:
很充实有趣有记录意义的一次bug解决体验。
H5 video跨域问题的更多相关文章
- PHP解决h5页面跨域
前端h5 页面请求后端接口会出现跨域, PHP 只需三行代码即可解决 //解决前端跨域(h5页面) header("Access-Control-Allow-Origin:*"); ...
- uni-app h5端跨域问题解决
例如我现在的项目运行在 http://localhost:8080,而我有个接口是 https://service.picasso.adesk.com/v1/wallpaper/album,发起请求就 ...
- vue.js及H5常见跨域问题解决方案
一.原生H5跨域问题解决方案 1.live-server 代理解决 首先在有node.js环境下,打开命令行工具,输入 npm install live-server -g 全局安装全局安装 live ...
- h5请求跨域问题Access-Control-Allow-Origin解决跨域
访问后端接口报错:No 'Access-Control-Allow-Origin' header is present on the requested resource 解决: Access-Con ...
- Spring @CrossOrigin 通配符 解决跨域问题
@CrossOrigin 通配符 解决跨域问题 痛点: 对很多api接口需要 开放H5 Ajax跨域请求支持 由于环境多套域名不同,而CrossOrigin 原生只支持* 或者具体域名的跨域支持 所以 ...
- h5标签canvas关于getImageData跨域的问题
h5标签canvas关于getImageData跨域的问题 在学习h5的时候,canvas标签中getImageData()报错:security error! 具体代码如下(chrome浏览器): ...
- 在Angular.js中的H5页面调用Web api时跨域问题处理
/// <summary> /// 被请求时 /// 在Angular.js中的H5页面调用Web api时跨域问题处理 /// </summary> /// <para ...
- 【微信支付】分享一个失败的案例 跨域405(Method Not Allowed)问题 关于IM的一些思考与实践 基于WebSocketSharp 的IM 简单实现 【css3】旋转倒计时 【Html5】-- 塔台管制 H5情景意识 --飞机 谈谈转行
[微信支付]分享一个失败的案例 2018-06-04 08:24 by stoneniqiu, 2744 阅读, 29 评论, 收藏, 编辑 这个项目是去年做的,开始客户还在推广,几个月后发现服务器已 ...
- Thinkphp5.1允许uni-app的H5跨域请求接口解决方法
情景: uni-app使用vue框架开发混合APP,虽然APP或者小程序没有跨域,但希望就是写完这个既有H5,又有APP,小程序等,所以能通过后端解决跨域最好.但是不知道是vue的原因还是什么,在PH ...
随机推荐
- MFC消息机制
何谓消息.消息处理函数.消息映射?消息简单的说就是指通过输入设备向程序发出指令要执行某个操作.具体的某个操作是你的一系列代码.称为消息处理函数. 在SDK中消息其实非常容易理解,当窗口建立后便会有一个 ...
- 翻译-你必须知道的28个HTML5特征、窍门和技术
摘自by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wordpress/?p=1058 前端的发 ...
- RESTful架构2--架构详解
转自:RESTful架构详解 1. 什么是REST REST全称是Representational State Transfer,中文意思是表述(编者注:通常译为表征)性状态转移. 它首次出现在200 ...
- hdu_5742_It's All In The Mind
题目链接:hdu_5742_It's All In The Mind 题意: 有一个部分的数列,让你找一个满足他给的三个条件的数列,使前两个数的和除这个数列的sum最大 题解: xjb贪心一下就行了. ...
- http header cache-control (request和response区别)
摘要:(1)网络服务会根据 request的header中的 cache-control策略设置response的cache-control策略 1 response cache-control 和 ...
- uva 156 (map)
暑假培训习题 1.用vector<string>储存string类型的输入单词: 2.将vector中的元素逐一标准化后映射进map中,并给map值加一: 3.新建一个空的vector 4 ...
- 找最大重复次数的数和重复次数(C++ Pair)
Problem A: 第一集 你好,世界冠军 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 265 Solved: 50[Submit][Statu ...
- 新版iTunes如何设置手机铃声
iTunes版本:12.5.1 系统版本:macOS Sierra 10.12 1.下载音乐,添加到iTunes. 现在下载音乐也不是一件容易的事,毕竟尊重版权. 这里Mac版与Windows版操作不 ...
- 在CDockablePane中嵌入对话框
CDockablePane类可以用来创建停靠栏.可以将其他控件集成到CDockablePane的派生类中.下文描述如何将对话框集成到CDockablePane中. a) 创建单文档应用程序: ...
- 借助XShell,使用linux命令sz可以很方便的将服务器上的文件下载到本地,使用rz命令则是把本地文件上传到服务器。
rz 是将window文件传到linux服务器上,到执行rz命令的目录 sz 可以将linux文件发送到windows上,可以选择目录. https://www.google.com/ncr 登录一下 ...