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

前端之家收集整理的这篇文章主要介绍了jsonp实现跨域调用百度地图接口前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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


JSONP

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

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

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

  1. // json
  2. {
  3. "province": "广东省","city": "珠海市"
  4. }
  5.  
  6. // jsonp
  7. funName(
  8. {
  9. "province": "广东省","city": "珠海市"
  10. }
  11. )

使用 jsonp 解决跨域

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

百度地图 IP定位AIP

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

AK 就是你申请的密钥

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

  1. {
  2. "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

代码如下:

  1. <script type="text/javascript">
  2. /** * 定位用户所在城市 * @author will * @date 2016-09-22 * */
  3.  
  4. // 页面加载完自动执行
  5. $(function() {
  6. location ();
  7. })
  8.  
  9. /** * callback 自定义的回调函数 * @param {[json]} data [请求返回的json数据] * */
  10. function showLocation(data) {
  11. // 定位的地址信息 根据需要写入对象属性
  12. var locationInfo = {
  13. // 省份
  14. province: data.content.address_detail.province,// 城市
  15. city: data.content.address_detail.city
  16. }
  17. alert("检查到您的IP地址为" + locationInfo.province + locationInfo.city);
  18. }
  19. function location() {
  20. var url = "http://api.map.baidu.com/location/ip?ak=你的密钥"
  21. + "&callback=showLocation";
  22. $.getScript(url);
  23. }
  24.  
  25. </script>

运行结果

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


咳咳,还是那句话

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

猜你在找的Json相关文章