热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

TSINGSEE青犀视频流媒体平台为什么会存在跨域问题?

在EasyNVR、EasyGBS、EasyDSS这一类视频平台中,经常会碰到用户问我们跨域相关的问题,在视频流的传输上,某些项目需要将视频流嵌入第三方平台或者app进行直播,这时极

在EasyNVR、EasyGBS、EasyDSS这一类视频平台中,经常会碰到用户问我们跨域相关的问题,在视频流的传输上,某些项目需要将视频流嵌入第三方平台或者app进行直播,这时极大可能会产生跨域相关的问题,这并不是传输上的问题,而是浏览器自身就有的机制。

我们来探寻一下跨域发生的原因。一般在网络访问中,请求的url地址必须与浏览器上的url地址处于同域上,也就是域名、端口、协议相同。假如在本地上的域名是A,请求另外一个域名B的一段数据,这时浏览器就会产生报错,该报错就是同源策略的保护,也就是我们本文讲的跨域出现的原因。简单来说,就是前端调用的后端接口不属于同一个域(域名或端口不同),就会产生跨域问题。

《TSINGSEE青犀视频流媒体平台为什么会存在跨域问题?》

部分网友会使用反向代理的方法来解决遇见的跨域问题,跨域只是浏览器向服务器发送请求的时候,浏览器的限制,而服务器和服务器之间是没有跨域的限制的,反向代理是利用代理服务器接收到请求之后,转发给真正的服务器,并把结果返回到浏览器上。但在我们的流媒体平台内采用了其他方法。

理论上,解决跨域问题有三种思路:

1、客户端浏览器解除跨域限制,但该思路由于浏览器存在安全检查机制而难以实现;
2、发送JSONP请求替代XHR请求,该方法只支持 GET 方法请求,不能适应所有的请求方式;
3、修改服务端,目前该方式是比较可行的方式。

《TSINGSEE青犀视频流媒体平台为什么会存在跨域问题?》

我们拿EasyNVR来举例,解决跨域分别进行了服务端和客户端两个部分的处理:

服务端:主动写 token 到 COOKIE,配置同时允许跨域访问设置,并且携带COOKIE,注销登陆时,服务端主动将 token 从 COOKIE 清理。

客户端:不必显示保存 token 到 COOKIE,所有和 EasyNVR 的交互接口都需要添加跨域配置。

此外,我们也遇到过很多客户在使用EasyGBS时集成第三方系统时的跨域问题,不进行鉴权登录,则显示401错误,在EasyGBS的解决方法也同样在客户端上,所有和EasyGBS的交互接口需要添加跨域配置xhrFields: { withCredentials: true } 和 crossDomain: true。

EasyNVR、EasyGBS等平台通过COOKIE会话都可能会遭遇恶意攻击或者访问,正因为如此,我们才对平台的跨域问题格外重视,经过多年的开发经验积累,EasyNVR、EasyGBS平台的安全性已经得到了多方项目的验证,如果大家还想了解更多关于EasyNVR相关的内容,欢迎自行下载EasyNVR试用版本进行测试。

《TSINGSEE青犀视频流媒体平台为什么会存在跨域问题?》


推荐阅读
author-avatar
只想活得快乐的魔羯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有