调用航班查询接口,用jsonp跨域时出现SyntaxError: missing ; before statement错误解决记录
来源:互联网 发布:网络不安全怎么解决 编辑:程序博客网 时间:2024/05/18 03:10
以前没有做过跨域,这几天算是比较懂了,记录一下。
遇到的这个问题,究其原因是,在用jsonp跨域时,返回的数据格式应该是形如 jsonp1({“name”:“CZ3869”}),而接口实际返回的数据是形如{“name”:“CZ3869”},控制台就会出现SyntaxError: missing ; before statement 这样的报错,而网络的状态码是200,表示成功,但是却拿不到数据,进入不了success的函数,在网络的响应里可以看到返回的数据,经过多方打听和查询,是对方返回数据时没有使用callback,不符合官网的标准导致。
如下是jsonp跨域关键代码:
var datas = {name:"ZC3869",date: "2017-09-08",key: "your_key",dtype:"json",format:true}; $.ajax({ async: false, type: "GET", dataType: "jsonp", url: "http://api.avatardata.cn/FlightDynamic/Query", data: datas, //timeout: 3000, contentType: "application/json;utf-8", success: function(resp) { console.log(resp); var flightInfoErrorCode = resp.error_code; //航班号不能为空 if (flightInfoErrorCode == 202001) { $.alert('航班号不能为空'); return; } //查询不到结果 if (flightInfoErrorCode == 202002) { $.alert('查询不到结果'); return; } //航班查询结果 if (flightInfoErrorCode == 0) { //成功操作 } console.log("航班查询结果",res); },error:function(res){console.log("error:"+res);} });
解决方法是使用代理服务器,由后端去拿数据,做一个接口,前端请求后端,后端把数据发给前端,前端做出相应的处理。
阅读全文
0 0
- 调用航班查询接口,用jsonp跨域时出现SyntaxError: missing ; before statement错误解决记录
- SyntaxError: missing ; before statement,SCRIPT1004: 缺少 ';'
- 航班查询接口调用介绍
- jquery ajax请求成功后eval(data)报错 SyntaxError: missing ; before statement
- Flex项目自动生成HTML报missing;before statement错误
- 航班查询接口接口
- 解决mysql,出现错误 ERROR 1820 (HY000): You must SET PASSWORD before executing this statement
- missing ';' before 'namesapce'错误的解决
- missing ';' before 'namesapce'错误的解决
- 解决VC中出现 " missing ')' before 'constant'"错误
- 航班查询接口
- 航班查询接口
- 航班查询接口
- 航班查询接口
- 航班查询接口
- 航班查询接口
- 航班查询接口
- 航班查询接口
- QTP封装接口属性和自身接口属性
- 覆盖,有序
- 了解浏览器cookie以及浏览器缓存
- java开发的23种设计模式(三)
- 连接
- 调用航班查询接口,用jsonp跨域时出现SyntaxError: missing ; before statement错误解决记录
- ios整合unity3d(xcode8.3.2 + Unity5.4.0 OC语言) Unity单独横屏处理
- JVM系列二:GC策略&内存申请、对象衰老
- 八种架构设计模式及其优缺点概述(上)
- web弹出层组件之js组件layer
- lvs-nat 模式
- ubuntu系统chrome代理问题
- gdb max-value-size
- 字符设备 和 input 设备--文件如何变成设备