CORS 跨域描述

Cross-Origin Resource Sharing (CORS)跨域资源共享。所谓跨域指A页面想获取B页面资源,如果两者的协议、域名、端口或者子域名不同,如A是ip地址,B是域名之间的访问行动都是跨域。浏览器基于安全问题通常会限制跨域访问,不允许跨域请求资源。

问题描述

当跨域调用时Chrome浏览器出现Uncaught ReferenceError: ok is not defined,A域www.abc.com B域 192.168.1.100。B应用一切正常,返回信息dial: ok,819,8008613542189232,A应用无法获得B域的返回信息,从而无法解析。

当B没有返回任何信息时,也会出现如上错误,这属于正常。比如当B时一个CallCenter,A调用B拨打电话,但是A拨通后,没有人工拿起电话,B同样没有任何返回。

同样的场景在edge瀏覽器下也出现如上错误,在獵豹瀏覽器下正常。
Chrome版本 83.0.4103.116 下没有如上错误,预计在版本91之前都不存在如上错误。

解决方法

方法1 客户端,通过注册表禁止preflight策略解决

此方法仅限于Chrome版本在91-101之间,101之后将强制preflight策略。请参考Chrome在版本91后,preflight验证请求造成两次请求的问题。

方法2 服务端,通过Jsonp请求,以及Server header设置

## 这一点很重要,可以把私有网络做一个域名,这样更方便使用。
Again, say bar.example resolves to 192.168.1.1.

Modern browsers will not block cross-domain requests outright. If Site A requests a page from Site B, the browser will actually fetch the requested page on the network level and check if the response headers list Site A as a permitted requester domain. If Site B has not indicated that Site A is allowed to access this page, the browser will trigger the XMLHttpRequest’s error event and deny the response data to the requesting JavaScript code.1

被访问的website B,必须返回Access-Control-Allow-Origin: http://siteA.com,siteA是发起请求的website。

方法三设置SameSite by default cookies、Cookies without SameSite must be secure

–disable-features=SameSiteByDefaultCookies,CookiesWithoutSameSiteMustBeSecure

在chrome的快捷方式右击–>属性
在目标输入框最后面加一个空格,然后粘贴以下内容,应用保存就可以了。

方法四Insecure origins treated as secure

chrome://flags/

方法五通过Nginx代理服务器的方式解决

需要搭建一台Nginx服务,其它同仁有成熟的解决方案,这边不再说明。

一个具有注脚的文本。1


  1. How does the ‘Access-Control-Allow-Origin’ header work? ↩︎ ↩︎

CORS Uncaught ReferenceError: is not defined相关推荐

  1. 引入JQuery提示:Uncaught ReferenceError: $ is not defined

    在使用jQuery的时候,发现有如下报错: Uncaught ReferenceError: $ is not defined  (anonymous function) 出现这个报错的原因: 1.j ...

  2. Uncaught ReferenceError: is not defined at HTMLAnchorElement.onclick

    原因: 字符串没有添加引号造成的 Uncaught ReferenceError: is not defined at HTMLAnchorElement.onclick var msg= " ...

  3. Emulator: emulator: INFO: QtLogger.cpp:68: Critical: Uncaught ReferenceError: $ is not defined (qrc:

    今天用android studio在模拟器上运行程序总是出错,模拟器能起来,但程序一直安装运行不了,查看错误日志发现如下错误: 10:49 Emulator: [5228:9620:0808/1049 ...

  4. jQuery报错:Uncaught ReferenceError: $ is not defined在使用jQuery的时候,发现有如下报错:...

    Uncaught ReferenceError: $ is not defined  (anonymous function) 出现这个报错的原因: 1.jQuery库文件的路径不对,检查文件路径是否 ...

  5. net::ERR_CONNECTION_REFUS拒绝连接错误和Uncaught ReferenceError: $ is not defined记录

    错误信息 Uncaught ReferenceError: $ is not defined 进不去ajax的方法 解决: 尝试了换ip,改路径.改参数头等方法,后面发现是有些文件没被编译到, tar ...

  6. 解决Uncaught ReferenceError: $ is not defined报错

    最可能的是引用的各个js的调用顺序有误,重新调整其引用顺序看看能否解决? 或者在你引用js时,路径出错,不是你项目中正确的文件路径. 还有一个原因是你的js中有某些值是不存在的. 除了以上这个具体的错 ...

  7. 错误 uncaught referenceerror is not defined 已经解决

    React项目场景: 解决前: package.json "dependencies": {"@babel/runtime": "^7.13.7&qu ...

  8. 报错Uncaught ReferenceError: *** is not defined at HTMLTableRowElement.onc

    问题:html标签中onclick事件引用的函数报错 原因:onclick引用的不是全局方法(可能是方法写在了其他方法中:闭包) 看到有人说: 错误写法: js:function row_click( ...

  9. 解决报错Uncaught ReferenceError: $ is not defined at index.html

    出现此情况的原因 (一), jquery.js放在自定义的或者bootstrap.js 前面,因为js依赖JQuery. (二),jquery库加载不成功,检查下引用的路径是否正确 (三),检查引用的 ...

最新文章

  1. jQuery Form Plugin (jquery表单插件)
  2. spring batch (四) Job的配置及配置文件说明介绍
  3. python储存与读取图片_Python下opencv使用笔记(一)(图像简单读取、显示与储存)...
  4. 简历中该怎么写自己了解html,我用HTML写简历
  5. frontend-maven-plugin插件问题解决
  6. 启动tomcat报错,Failed to start component
  7. checkbox-复选框
  8. 【w3cschool】正则表达式基础语法
  9. ip头ttl_TCP/IP协议详解内容总结,看完恍然大悟
  10. H5动效的常见制作手法
  11. 计算机病毒手动查杀,如何手动查杀计算机病毒
  12. AES加密 C++调用Crypto++加密库 例子
  13. 你可能不知道的JavaScript 遍历DOM的几种方法
  14. html写大学课程表
  15. 高并发、高性能下的 会员系统[同程艺龙] — 高可用架构设计实践
  16. 电脑锁定屏幕网络就断开的解决方案
  17. 字符串截取的常用方法
  18. 买了一台云服务器能干嘛
  19. “张一鸣”为何突袭“王兴”
  20. Jetpack Compose - Box

热门文章

  1. java pdfbox 解析报错_关于 PDFBox 解析器
  2. 从备用情况分析中国六大电网电力过剩情况
  3. Java实现对分法解方程_解方程——对分法
  4. 计算机叫醒服务英语,关于叫醒服务的英语对话
  5. 你U盘的速度为何那么慢?(节选)
  6. ARM 汇编指令对应的机器码和条件码
  7. Microsoft Office365 DevDays - 6th
  8. 有关于路由的基础使用(一级路由和二级路由)
  9. 业余挣点零花钱,分享一些 Python 赚钱的门路
  10. i7 12700参数 i712700怎么样