百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>Ecshop教程> 基于gps定位给ecshop手机端增加自动城市插件
分享文章到:

基于gps定位给ecshop手机端增加自动城市插件

发布时间:12/03 来源: 浏览: 关键词:

以前曾看到有人说php能获取手机的ip,可是,在没有用WiFi并且手机是3G或者4G的卡时,根本无法获取手机的ip,所以在看到许多手机app都在用gps定位后,最模板也去研究了一下,经测试,确实可以获取所在城市。下面,最模板来总结一下最模板的实现方法:

这里要先说明一下,如果手机端是ecshop自带的,那么html代码就写在/mobile/templates/order.dwt中,php代码写在 /mobile/order.php中,如果是独立的手机端,那么html代码就写在/mobile/themes/default/flow.dwt 中,php代码写在/mobile/flow.php中。

第一步,如果是ecshop自带的手机端,在/mobile/templates/order.dwt中,写入如下js代码:

<script>

onload = function() { 

var position_option = {
                enableHighAccuracy: true,
                maximumAge: 30000,
                timeout: 20000
            };
navigator.geolocation.getCurrentPosition(getPositionSuccess, getPositionError, position_option);


          }
function getPositionSuccess( position ){
        var lat = position.coords.latitude;
        var lng = position.coords.longitude;
        document.getElementById("latitude").value=lat;
document.getElementById("longitude").value=lng;
}
function getPositionError(error) {
    switch (error.code) {
        case error.TIMEOUT:
            alert("连接超时,请重试");
            break;
        case error.PERMISSION_DENIED:
            alert("您拒绝了使用位置共享服务,查询已取消");
            break;
        case error.POSITION_UNAVAILABLE:
            alert("获取位置信息失败");
            break;
    }
}
</script>

并找到<input class="ddbtn" type="submit" name="Submit" value="提交订单" />,在前面写入代码:

<input type="hidden" id="latitude" name="latitude" value="" />
      <input type="hidden" id="longitude" name="longitude" value="" />

如果是独立的手机端,找到onload = function() ;在方法内写入代码:

enableHighAccuracy: true,
                maximumAge: 30000,
                timeout: 20000
            };
navigator.geolocation.getCurrentPosition(getPositionSuccess, getPositionError, position_option);

在方法外面写入代码:

function getPositionSuccess( position ){
        var lat = position.coords.latitude;
        var lng = position.coords.longitude;
        document.getElementById("latitude").value=lat;
document.getElementById("longitude").value=lng;
}
function getPositionError(error) {
    switch (error.code) {
        case error.TIMEOUT:
            alert("连接超时,请重试");
            break;
        case error.PERMISSION_DENIED:
            alert("您拒绝了使用位置共享服务,查询已取消");
            break;
        case error.POSITION_UNAVAILABLE:
            alert("获取位置信息失败");
            break;
    }
}

并找到代码:<input type="submit" name="submit" value="提交订单" class="c-btn3"/>,在前面写入代码:

<input type="hidden" id="latitude" name="latitude" value="" />
      <input type="hidden" id="longitude" name="longitude" value="" />

这样手机所在位置的经纬度就传到了相应的php文件中。

第二步,两种手机wap网站端都是一样的操作,先找到代码:$GLOBALS['db']->autoExecute($GLOBALS['ecs']->table('order_info'), $order, 'INSERT');

在前面写入代码:

$wei=$_POST['latitude'];
$jing=$_POST['longitude'];

$local_city=getRealyAddress($wei,$jing);
$order['order_city']=$local_city;

并在文件末尾写入代码:

function getRealyAddress($wei,$jing){
$place_url='http://api.map.baidu.com/geocoder?output=json&location='.$wei.','.$jing.'&key=ccea36ece20a7a6eb0666bc726957e85';
$json_place=file_get_contents($place_url);
$place_arr=json_decode($json_place,true);
$address=$place_arr['result']['addressComponent']['city'];
return $address;
}

如此,便大功告成了!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

相关文章

共有11人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板