找回密码
 立即注册

QQ登录

只需一步,快速开始

Lenka.Guo 讲师达人认证 悬赏达人认证
超级版主   /  发表于:2021-6-28 10:51  /   查看:2698  /  回复:0
很多单页应用,仅仅简单的HTML 页面时需要访问同一路径下的JSON 数据文件,会报到跨域问题。无法获取到本地JSON 文件。

1. 为什么会遇到跨域问题呢?
跨域,即浏览器有一个安全机制,叫做 同源策略(CROS),不同域的客户端脚本在无明确授权的情况下,是不能读取对方资源的。它保证了一个域的脚本只能读写本域内的资源,而无法访问其他域的资源。简单理解:可以说跨域就是不同源。

域: 协议、域名、端口这三者相同,视为同一个域。

但是并不是所有浏览器都有CROS 策略,火狐和Edge IE 是允许跨域的。



2. 为什么无法直接打开html 页面来访问 ActiveReportsJS 报表的json文件呢

ActiveReportsJS 设计的报表文件后缀是 .rdlx-json , 但本质上也是 json文件,似乎直接用html 页面访问同一路径下的json文件,似乎是同一个域名,端口。 但其实是协议不同,访问 ActiveReportsJS 报表文件,本质是 file协议,而 Chrome 跨源请求仅支持协议方案 :http, data, chrome, chrome-extension, https.








3. 如何解决

1. 纯前端方式: 采用JSONP
JSONP是一种非正式传输协议,目的就是便于客户端使用数据。 要注意区分json 和 jsonp两个概念:
  • json : 是一种数据格式。
  • jsonp: 是一种数据调用方式。
JSONP方式具有一定的局限性:
  • 仅适用于GET请求;
  • 读取本地json文件的话,json文件里的数据要包含在一个函数名里


解决方法:


1. 使用Visual Studio Code 打开报表文件,并在前面加入  
var template=


2. 并将报表文件的后缀改为.js
3. 在html 页面的<script>标签中引入  .js 文件


4. viewer.open(template);





2.  部署到服务器上,注意部署也选择 Localhost, 不能选择IP 或者域名,如果部署为IP 或者域名就会检测部署授权,如果您有部署授权可直接部署,如果没有就需要在网站上申请,部署到服务器上就相当于同源了,不属于跨域问题。 注意部署到服务器上时候,要注册MIME 类型同JSON
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration>
  3.     <system.webServer>
  4.         <staticContent>
  5.             <mimeMap fileExtension=".rdlx-json" mimeType="application/json" />
  6.         </staticContent>
  7.     </system.webServer>
  8. </configuration>
复制代码



本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

0 个回复

您需要登录后才可以回帖 登录 | 立即注册
返回顶部