https://www.cnblogs.com/fireicesion/p/10777033.html 原文地址:https://blog.csdn.net/stacy06/article/details/82626363 最近项目部署到了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修改了一下,呼呼。。最后问题终于解决了。 主要修改map.html中的内容罗如下: map.htm地址为:/ueditor/dialogs/map/map.html 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=your_ak&s=1"></script> 3、修改1.1到2.0升级的部分api: 1)在Ueditor包的map组件的map.html中
2)在Ueditor包的map组件的show.html中 修改js引用方式
最后,大功告成啦
map.html <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title></title> <script type="text/javascript" src="../internal.js"></script> <!--<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=百度密匙&s=1"></script> <style type="text/css"> .content { width: 530px; height: 350px; margin: 10px auto; } .content table { width: 100% } .content table td { vertical-align: middle; } #city, #address { height: 21px; background: #FFF; border: 1px solid #d7d7d7; line-height: 21px; } #city { width: 60px } #address { width: 130px } #is_dynamic_label span { vertical-align: middle; margin: 3px 0px 3px 3px; } #is_dynamic_label input { vertical-align: middle; margin: 3px 3px 3px 50px; } </style> </head> <body> <div class="content"> <table> <tr> <td><var id="lang_city"></var>:</td> <td><input id="city" type="text" /></td> <td><var id="lang_address"></var>:</td> <td><input id="address" type="text" value="" /></td> <td><a href="javascript:doSearch()" class="button"><var id="lang_search"></var></a></td> <td><label id="is_dynamic_label" for="is_dynamic"><input id="is_dynamic" type="checkbox" name="is_dynamic" /><span><var id="lang_dynamicmap"></var></span></label></td> </tr> </table> <div style="width:100%;height:340px;margin:5px auto;border:1px solid gray" id="container"></div> </div> <script type="text/javascript"> var map = new BMap.Map("container"),marker,point,styleStr; map.enableScrollWheelZoom(); map.enableContinuousZoom(); function doSearch(){ if (!document.getElementById('city').value) { alert(lang.cityMsg); return; } var search = new BMap.LocalSearch(document.getElementById('city').value, { onSearchComplete: function (results){ if (results && results.getNumPois()) { var points = []; for (var i=0; i<results.getCurrentNumPois(); i++) { points.push(results.getPoi(i).point); } if (points.length > 1) { map.setViewport(points); } else { map.centerAndZoom(points[0], 13); } point = map.getCenter(); marker.setPosition(point); } else { alert(lang.errorMsg); } } }); search.search(document.getElementById('address').value || document.getElementById('city').value); } //获得参数 function getPars(str,par){ var reg = new RegExp(par+"=((\\d+|[.,])*)","g"); return reg.exec(str)[1]; } function init(){ var mapNode = editor.selection.getRange().getClosedNode(), isMapImg = mapNode && /api[.]map[.]baidu[.]com/ig.test(mapNode.getAttribute("src")), isMapIframe = mapNode && domUtils.hasClass(mapNode, 'ueditor_baidumap'); if(isMapImg || isMapIframe){ var url, centerPos, markerPos; if(isMapIframe) { url = decodeURIComponent(mapNode.getAttribute("src")); $G('is_dynamic').checked = true; styleStr = mapNode.style.cssText; } else { url = mapNode.getAttribute("src"); styleStr = mapNode.style.cssText; } centerPos = getPars(url,"center").split(","); markerPos = getPars(url, "markers").split(","); point = new BMap.Point(Number(centerPos[0]),Number(centerPos[1])); marker = new BMap.Marker(new BMap.Point(Number(markerPos[0]), Number(markerPos[1]))); map.addControl(new BMap.NavigationControl()); map.centerAndZoom(point, Number(getPars(url,"zoom"))); }else{ point = new BMap.Point(116.404, 39.915); // 创建点坐标 marker = new BMap.Marker(point); map.addControl(new BMap.NavigationControl()); map.centerAndZoom(point, 10); // 初始化地图,设置中心点坐标和地图级别。 } marker.enableDragging(); map.addOverlay(marker); } init(); document.getElementById('address').onkeydown = function (evt){ evt = evt || event; if (evt.keyCode == 13) { doSearch(); } }; dialog.onok = function (){ var center = map.getCenter(); var zoom = map.getZoom(); var size = map.getSize(); var mapWidth = size.width; var mapHeight = size.height; var point = marker.getPosition(); if($G('is_dynamic').checked) { var URL = editor.options.UEDITOR_HOME_URL, url = [URL + (/\/$/.test(URL) ? '':'/') + "dialogs/map/show.html" + '#center=' + center.lng + ',' + center.lat, '&zoom=' + zoom, '&width=' + mapWidth, '&height=' + mapHeight, '&markers=' + point.lng + ',' + point.lat, '&markerStyles=' + 'l,A'].join(''); editor.execCommand('inserthtml', '<iframe class="ueditor_baidumap" src="' + url + '"' + (styleStr ? ' style="' + styleStr + '"' :'') + ' frameborder="0" width="' + (mapWidth+4) + '" height="' + (mapHeight+4) + '"></iframe>'); } else { var url = "https://api.map.baidu.com/staticimage?s=1¢er=" + center.lng + ',' + center.lat + "&zoom=" + zoom + "&width=" + size.width + '&height=' + size.height + "&markers=" + point.lng + ',' + point.lat; editor.execCommand('inserthtml', '<img width="'+ size.width +'"height="'+ size.height +'" src="' + url + '"' + (styleStr ? ' style="' + styleStr + '"' :'') + '/>'); } }; document.getElementById("address").focus(); </script> </body> </html> |
|