百度UEditor控件中的map组件不支持https使用的问题解决

最近项目部署到了https环境下,使用的UEditor富文本编辑器中的map组件出现了问题,控制台报了一堆错误,主要是mixed content.. ,就连百度的官网上也同样是有这些问题,汗。。

没有办法,只能四处搜索解决问题的答案。。。

第一点收获:

https是安全传输协议,在这个协议下传输的网页不允许包含http协议这类不安全的内容。

HTTPS页面里动态的引入HTTP资源,比如引入一个js文件,会被浏览器直接block掉的.在HTTPS页面里通过AJAX的方式请求HTTP资源,也会被直接block掉的。也就是报mixed content,

解决方法:页面的head中加入以下代码

<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">

意思是自动将http的不安全请求升级为https

第二点收获:

上面设置完成之后页面上的内容被自动从http协议改成了https协议,但是百度地图的应用还是有问题,百度地图的瓦片加载不出来,发现这些瓦片被自动改成https之后是不存在的。。也就是说这些地图瓦片是只部署在http下的,这可怎么办,难道百度地图不支持https吗。。这不应该啊

又一通查找搜索之后。。。。找到百度地图切换https协议的方案:

将地图的js引用稍加修改,http-->https,后面参数加上&s=1,如此就支持https了

第三点:

但是还是没有完全解决,最后查看我用的Ueditor中用的百度地图的版本太低了。。v=1.1的,改成2.0的试试吧,https的相关问题终于没有了,但是有一些百度地图的api没有了。。。

应该是2.0相比于1.1的api还是有些变化的吧,再查看百度地图的官方文档,把功能类似的api修改了一下,呼呼。。最后问题终于解决了。

主要修改内容罗列如下,以备自己总结备忘:

1、页面的head中加入以下代码

<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">

2、修改百度地图js引用方式:

修改前:

<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.1&services=true"></script>

修改后:

<script type="text/javascript" src="https://api.map.baidu.com/api?v=2.0&ak=你的AK&s=1"></script>

获取AK的方法:http://lbsyun.baidu.com/apiconsole/key

3、修改1.1到2.0升级的部分api:

1)在Ueditor包的map组件的map.html中

2)在Ueditor包的map组件的show.html中

修改js引用方式

最后,大功告成啦

--------------------- 作者:小牛1213 来源:CSDN 原文:https://blog.csdn.net/stacy06/article/details/82626363?utm_source=copy 版权声明:本文为博主原创文章,转载请附上博文链接!

猜你喜欢

转载自blog.csdn.net/xiao_hu520/article/details/82999656
今日推荐