首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >No 'Access-Control-Allow-Origin':读取CSV、D3

No 'Access-Control-Allow-Origin':读取CSV、D3
EN

Stack Overflow用户
提问于 2019-03-05 06:22:17
回答 1查看 3.6K关注 0票数 0

我正在尝试从源https://stats.oecd.org/Index.aspx?DataSetCode=WILD_LIFE读取csv。

设x是上面的url。

代码语言:javascript
复制
 <script type="text/javascript">  
  var data_threatened = d3.csv(x)
   .then(function(data){
    console.log(data);
  })  
  </script>

但是,当我在本地主机上运行此脚本时,收到以下消息:

CORS策略阻止了对从源'http://localhost:8888‘获取'https://stats.oecd.org/Index.aspx?DataSetCode=WILD_LIFE’的

访问:请求的资源上不存在' Access -Control-Allow- origin‘标头。如果不透明的响应满足您的需求,请将请求的模式设置为'no- CORS‘,以便在禁用CORS的情况下获取资源。

未捕获(in promise) TypeError:无法获取

有绕过这条街的路吗?

EN

回答 1

Stack Overflow用户

发布于 2019-03-05 06:30:01

从脚本运行的同一来源获取文件并提供服务将是最简单的。例如:PHP不关心CORS (假设这个文件偶尔发生变化)。如果它没有改变,即使手动将它放在那里也足够了。

要让服务器端脚本获取文件,然后将其作为同源文件提供,而不对其进行缓存:

代码语言:javascript
复制
<?php
    $url = "https://stats.oecd.org/Index.aspx?DataSetCode=WILD_LIFE";
    header("Content-type: text/csv");
    echo file_get_contents($url);
?>

任何服务器端脚本语言都应该能够做到这一点;我使用PHP只是为了提供一个示例。可以使WILD_LIFE成为一个变量,这样它就可以用来获取任何数据集。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54992497

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档