javascript - 调用数据接口被拦截,显示同源策略禁止读取数据,怎么解决?

查看:126
本文介绍了javascript - 调用数据接口被拦截,显示同源策略禁止读取数据,怎么解决?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题


var set = {
    type: "GET",
    url: 'http://japi.juhe.cn/health_knowledge/categoryList?key=ba4fbbe97404cc',
    dataType: "json",
    success: function(data) {
        console.log(data);
    }
}
$.ajax(set);

显示错误:

已拦截跨源请求:同源策略禁止读取位于
http://japi.juhe.cn/health_kn...
的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。

我调用的是聚合数据上的API,怎么解决这个问题呢?
追加一下,使用JSONP格式调用成功,但是会报错:

SyntaxError: missing ; before statement
"error_code" : 0 , "reason" : "Success!" , "result" : [ { "id" : 11 ,
"na categ...

但是返回数据显示"reason" : "Success!", 明显是成功的,好想知道解决方法。

解决方案

同源策略是互联网安全的需求,所以也许有绕过该策略的方法,但是慢慢也会被封杀的,除非是服务器自己愿意(在头部设置Access-Control-Allow-Origin)或者使用其它协议,如WebSocket,那也是要你请求的服务器支持才行,个人观点。

所以如果是想要调用聚合数据上的API,请将数据发送到你的后台,然后由你的后台调用,得到的数据再返回你的前端。

报的错是语法错误,检查下你的代码?

这篇关于javascript - 调用数据接口被拦截,显示同源策略禁止读取数据,怎么解决?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆