jsonp实现跨域调用百度地图接口

jsonp实现跨域调用百度地图接口

分享下自己在使用百度地图 IP定位API 时解决浏览器跨域问题的心得


JSONP

Jsonp(JSON with Padding) 是 json 的一种”使用模式”,可以让网页从别的域名(网站)那获取资料,即跨域读取数据。为什么我们从不同的域(网站)访问数据需要一个特殊的技术(JSONP )呢?这是因为同源策略。

同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,现在所有支持JavaScript 的浏览器都会使用这个策略。

json想必大家都听过或已经使用过,它就是一种轻量级的数据交换格式,而 jsonp 其实就是给 json 套上了一个函数名,例如:

// json 
{
    "province": "广东省",
    "city": "珠海市"
}

// jsonp
funName(
    {
        "province": "广东省",
        "city": "珠海市"
    }
)

使用 jsonp 解决跨域

刚刚我们简单的了解了下什么是 jsonp , 那我们现在就开始实际代码操作下,用 jsonp 解决浏览器跨域问题。

百度地图 IP定位AIP

URL: http://api.map.baidu.com/location/ip?ak=请输入您的AK

AK 就是你申请的密钥

直接把 url 往浏览器里输入,回车,服务器返回的 json 数据是这样的:

{
  "address": "CN|广东|珠海|None|CHINANET|0|0",
  "content": {
    "address_detail": {
      "province": "广东省",
      "city": "珠海市",
      "district": "",
      "street": "",
      "street_number": "",
      "city_code": 140
    },
    "address": "广东省珠海市",
    "point": {
      "y": "2526069.55",
      "x": "12641851.33"
    }
  },
  "status": 0
}

如果我们还是按照平常去写ajax请求,那么肯定会报错,因为你的程序和百度,是跨域的访问。但是不用着急,百度已经想到了会有这个问题,它留了一手,有个callback参数。这个参数就能将返回来的 json带上一个函数名,这个函数名是自己定的。

所以,我们现在需要做的是把这个 json 数据包在一个函数名里面,让它变成 jsonp 的形式,于是我定义了一个函数名 showLocation , 然后让 callback 回调函数等于 showLocation

代码如下:
<script type="text/javascript">
    /**
     * 定位用户所在城市
     * @author will
     * @date 2016-09-22
     * 
     */

    // 页面加载完自动执行
    $(function() {
        location ();
    })

    /**
     * callback 自定义的回调函数
     * @param  {[json]} data [请求返回的json数据]
     * 
     */
    function showLocation(data) {
        // 定位的地址信息 根据需要写入对象属性
        var locationInfo = {
            // 省份
            province: data.content.address_detail.province,
            // 城市
            city: data.content.address_detail.city
        }
        alert("检查到您的IP地址为" + locationInfo.province + locationInfo.city);
    }
    function location() {
        var url = "http://api.map.baidu.com/location/ip?ak=你的密钥"
        + "&callback=showLocation";
        $.getScript(url);
    }

    </script>
运行结果

这里写图片描述

以上就是我的分享,因为js代码中我用了jquery的语法,所以页面里还需要引入jquery文件。


咳咳,还是那句话

还是要不断学习,因为你还很年轻

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 11
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值