Net微信网页开发之使用微信JS-SDK获取当前地理位置

Posted can-daydayup

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Net微信网页开发之使用微信JS-SDK获取当前地理位置相关的知识,希望对你有一定的参考价值。

前言:

  前段时间有一个关于通过获取用户当前经纬度坐标,计算出该用户距离某指定地点之间的距离。因为做这个项目需要能够获取到比较精确的经纬度坐标,刚开始使用的是百度地图结果发现百度地图地位不太准确(有时候相差的比较的大,后来了解到了百度获取用户经纬度与用户当前使用的网络有很大的关系),后来换成了高德地图结果还是一样。最后我想刚好做的是个微信网站项目,为什么不使用微信自带接口呢?所以最后使用了微信JS-SDK来获取用户当前地理位置的接口。

微信JS-SDK的使用步骤,配置信息的生成获取讲解:

  关于JS-SDK的使用步骤和timestamp(时间戳),nonceStr(随机串),signature(签名),access_token(接口调用凭据)生成获取的详细说明在此:https://www.cnblogs.com/Can-daydayup/p/11124092.html

前往微信公众平台查看是否开通获取用户地理位置接口权限:

技术图片

技术图片

 

 

调用微信JS-SDK获取地理位置接口,获取用户当前准确经纬度坐标:

微信官方文档使用说明:https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html#35

<script type="text/javascript">
//通过config接口注入权限验证配置
wx.config(
debug:false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId:‘your AppId‘, // 必填,公众号的唯一标识
timestamp:‘your timestamp‘, // 必填,生成签名的时间戳
nonceStr:‘your nonceStr‘, // 必填,生成签名的随机串
signature:‘your signature‘,// 必填,签名
jsApiList: [‘getLocation‘] // 必填,需要使用的JS接口列表
);

 
//注意,我们的经纬度坐标是要在页面加载完成后立即获取,不需要触发获取,因此需要把获取地理位置的接口放在ready(function());里面
wx.ready(function ()

try 
wx.getLocation(
type: ‘wgs84‘, // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入‘gcj02‘
success: function (res)  

var latitude = res.latitude; // 纬度,浮点数,范围为90 ~ -90
var longitude = res.longitude; // 经度,浮点数,范围为180 ~ -180。
var speed = res.speed; // 速度,以米/每秒计
var accuracy = res.accuracy; // 位置精度
$("#Longitude").val(longitude);
$("#Latitude").val(latitude);
alert("微信经纬度获取结果:" + latitude + "经度" + longitude);

);

catch (e) 

console.log(e);

);
</script>

 授权公众号,获取当前地理位置:

技术图片

 

以上是关于Net微信网页开发之使用微信JS-SDK获取当前地理位置的主要内容,如果未能解决你的问题,请参考以下文章

夺命雷公狗---微信开发54----微信js-sdk接口开发之快速入门

企业微信系列之JSSDK文件预览对接

企业微信系列之JSSDK文件预览对接

微信支付jssdk是做啥用的

微信JS-SDK说明文档

微信公众平台--6.JS-SDK 微信内网页开发工具包