JS调用百度地图API接口,get请求成功返回数据,但控制台显示状态码为failed

项目场景:

前端JS请求百度地图API接口

问题描述:

get请求发出后,能在控制台看到返回的数据,但无法进入回调函数,而进入了failed对应的函数

原出错代码为


    $.get(
        "http://api.map.baidu.com/reverse_geocoding/v3/",
        {ak:'你的ak',output:'json',coordtype:'wgs84ll',location:'21.683533108387'+','+'110.92324182065'},
        function (data) {
            alert('成功')
        },
        "jsonp"

    ).fail(function(data){
            alert("有毛病了");
        });

在这里插入图片描述
能够看到响应回来的数据
在这里插入图片描述


出错原因
由于百度的一些安全策略,以及对用户的保护,对于跨域请求则需要使用Jsonp返回体格式

关于Jsonp

服务端会给客户端的请求返回一段JavaScript代码
通过客户端请求时指定的回调函数去运行得到数据,

解决方案:

将get的返回参数格式设置为jsonp,则get请求不会报failed

dataType: 'jsonp'

结合了网上关于前端跨域请求jsonp的实现的一些文章
修改代码,配合注释应该能看得懂

<script>
    loc='21.683533108387'+','+'110.92324182065'
    $.ajax({
        //设置请求类型
        type:"get",
        //请求超时时间
        timeout:5000,
        //设置请求地址
        url: 'http://api.map.baidu.com/reverse_geocoding/v3/',
        //设置需要发送的数据
        data: {ak:'你的ak', output:'json', coordtype:'wgs84ll', location:loc},
        //定义此请求为跨域请求
        dataType: 'jsonp',
        //定义回调函数
        jsonpCallback:"callbackUser",
        success: function (data) {
            console.log("成功");
        },
        error: function (data) {
           console.log(data)
        }
    })

function callbackUser(data){

    alert(data.result.formatted_address);

}

</script>

其实在百度地图官方操作文档中也有对于jsonp相关的要求,由于非必须,被我忽略了
在这里插入图片描述
大家也可以去尝试修改

最终我成功运行并alert出数据
在这里插入图片描述
2020.12.4

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Java 中调用 API 接口,可以使用 Java 的网络编程库,如 HttpURLConnection 或 HttpClient。以下是一个使用 HttpURLConnection 的示例代码: ```java import java.net.HttpURLConnection; import java.net.URL; import java.io.BufferedReader; import java.io.InputStreamReader; public class APITest { public static void main(String[] args) { try { URL url = new URL("https://api.example.com/data"); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("GET"); conn.setRequestProperty("Accept", "application/json"); if (conn.getResponseCode() != 200) { throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode()); } BufferedReader br = new BufferedReader(new InputStreamReader((conn.getInputStream()))); String output; while ((output = br.readLine()) != null) { System.out.println(output); } conn.disconnect(); } catch (Exception e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们使用 HttpURLConnection 来构建 HTTP 请求并发送它。我们首先创建一个 URL 对象,表示 API 的地址。然后,我们使用 openConnection() 方法打开一个连接,并设置请求方法为 GET。我们还设置了 Accept 头,表示我们期望响应的内容类型为 JSON。 然后,我们检查响应状态码是否为 200。如果不是,则抛出异常。如果是 200,我们使用 BufferedReader 读取响应内容并将其输出到控制台。最后,我们断开连接并关闭 BufferedReader。 您需要更改示例代码中的 URL 和 Accept 头以适应您的 API

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值