|
因为有一朋友问起这个问题,我找了下,今天就发出来看看吧,不知道说的对不对。 不过对于Mapbar这样处理的方法我个人觉得还是很值得学习的,至少不会给你明码的坐标。 不知道Mapbar的朋友看了会不会找我说我那,呵呵,不过没关系,最近想写篇文章给你们些个人的小小的建议,觉得说的不好也无妨。忙完这阵子就写。
下面是Mapbar中的加密和解密部分的JS,我做了简单说明了,什么36进制又16进制的,看的我也头晕。 实例的结果是这样的: IJSDSBWVJABFA解密后的值:121.46979,31.23245 31.23245,121.46979加密后的值:IJSDSBZVJABFA 当然你也可以用其他坐标来测试和检验。 友情提醒:Mapbar中的那个常量值可能已经变动了,用现在方法解出来的和百度的值是不一样的。 下面的代码复制后保存为网页形式就可以看到效果。
Mapbar中的加密和解密(JS) 复制代码 代码如下: <script language="javascript"> //一个常量但变动后加密解密的值会变动 var strLicenseKey = 699; //解密坐标 function jiemi(meT){ var W7pj=-1; var I524S=0; var qk_X=''; for(var i=0;i<meT.length;i++){var j86T=parseInt(meT.charAt(i),36)-10; if(j86T>=10)j86T=j86T-7;qk_X+=(j86T).toString(36); if(j86T>I524S){W7pj=i;I524S=j86T}}var U8T=parseInt(qk_X.substring(0,W7pj),16); var f9v8D=parseInt(qk_X.substring(W7pj+1),16); var H1433=new Array(); H1433[0]=(U8T+f9v8D-parseInt(strLicenseKey))/2; H1433[1]=(f9v8D-H1433[0])/100000.0; H1433[0]/=100000.0; return H1433}; //解密坐标的实例 document.write('这是IJSDSBWVJABFA解密后的值:<br>'+jiemi('IJSDSBWVJABFA')+'<br><br>'); //加密坐标 function jiami(e53,B92_) { var WVd94=parseInt(parseFloat(e53)*100000); var j7_2=parseInt(parseFloat(B92_)*100000); var rpB=(j7_2-WVd94+parseInt(strLicenseKey)).toString(16); var ie9=(j7_2+WVd94).toString(16); var H1433=''; for(var i=0;i<rpB.length;i++) { var k6A36=parseInt(rpB.charAt(i),16); H1433+=(((k6A36>=10)?(k6A36+7):k6A36)+10).toString(36) } H1433+='z'; for(var i=0;i<ie9.length;i++) { var k6A36=parseInt(ie9.charAt(i),16); H1433+=(((k6A36>=10)?(k6A36+7):k6A36)+10).toString(36) } return H1433.toUpperCase() } //加密实例 document.write('这是31.23245,121.46979加密后的值:<br>'+jiami('31.23245','121.46979')); </script>
|
|