happyxp 发表于 2021-1-19 17:59:57

网站升级https后百度地图不显示解决方法

昨天给网站升级了https,今天发现打开公司介绍页面百度地图不显示了。错误提示:


Mixed Content: The page at ‘https://www.******.com/public/admin/index/index.html
’ was loaded over HTTPS, but requested an insecure script ‘http://api.map.baidu.com/api?v=1.4
‘. This request has been blocked; the content must be served over HTTPS.
VM255 addshopview.html:381 Uncaught ReferenceError: BMap is not defined.

这个问题是因为在百度的JavaScript API V2.0版本才支持https,而原来的是不支持的。

配置方法:

1. 如果使用JavaScript API ,需要加一个特殊字段 (s=1):
https://api.map.baidu.com/api?v=2.0&ak=你的密钥&s=1;
2. 对于Web API 无需加特殊字段,直接使用 HTTPS协议访问即可,如Geocoding:
https://api.map.baidu.com/geocoder/v2/?ak=你的秘钥&callback=renderReverse&location=39.983424,116.322987&output=xml&pois=1
3. 如果对数据安全要求高,建议使用 POST请求,避免把请求参数放到 URI中敏感信息被泄露;


非常欢快的用第一种方法复制替换之后,发现在使用百度地图API的时候,运行在浏览器上出现:

百度未授权使用地图API,可能是因为您提供的密钥不是有效的百度LBS开放平台密钥,或此密钥未对本应用的百度地图JavaScriptAPI授权。您可以访问如下网址了解如何获取有效的密钥:http://lbsyun.baidu.com/apiconsole/key#。
错误提示,检查之后发现需要一个百度地图的AK密钥,这个密钥目前是免费申请的,网址就是提示的这个网址:http://lbsyun.baidu.com/apiconsole/key#

登陆之后,第一个选项就是创建AK的。
点击创建应用


应用名称 自己填一个
应用类型 浏览器端(这个一定要填浏览器端,刚开始直接默认的第一个,死活也不好使,后来才发现是选错了……)
启用服务 默认全选就可以
Referer白名单 按照说明要求填写,最好是你用的哪个网站调用,就写对应的域名规则,尽量不要全放开。
然后把密钥替换到https://api.map.baidu.com/api?v=2.0&ak=你的密钥&s=1中你的密钥的位置,然后替换掉原来的JavaScript API 即可。

刷新页面,地图又回来了。


页: [1]
查看完整版本: 网站升级https后百度地图不显示解决方法