zoukankan      html  css  js  c++  java
  • 微信测试号开发之七 获取用户地理位置

    原文链接:https://blog.csdn.net/qq_37936542/article/details/78732365

    步骤一:绑定域名   注意不要加http://




    步骤二:引入js文件

    --在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.2.0.js

    1. <script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>  

    步骤三:通过ajax获取参数,完成config接口注入权限验证配置


    --ajax请求

    [javascript] view plain copy
    1. $(function() {  
    2.       
    3.     // 获取本页面的url  
    4.     var url = location.href.split('#')[0];  
    5.     $.ajax({  
    6.         type : "GET",  
    7.         url : "signature.action?url=" + url,  
    8.         dataType:"json",  
    9.         success : function(data) {  
    10.             wx.config({  
    11.                 debug : true// 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。  
    12.                 appId: data.appid, // 必填,公众号的唯一标识  
    13.                                 timestamp: data.timestamp,  // 必填,生成签名的时间戳  
    14.                                 nonceStr: data.nonceStr,  // 必填,生成签名的随机串  
    15.                                 signature: data.signature,   // 必填,签名,见附录1  
    16.                 jsApiList : [   
    17.                                 'checkJsApi',  
    18.                         'openLocation',// 使用微信内置地图查看地理位置接口  
    19.                         'getLocation' // 获取地理位置接口  
    20.                 ]  // 必填,需要使用的JS接口列表  
    21.             });  
    22.         }  
    23.     });  
    24.       
    25.     });  

    --后台代码


    注:jsapi-ticket的获取在前一节中讲过,这里就带过


    1. @RequestMapping(value = "signature"method = RequestMethod.GET)  
    2.     @ResponseBody   
    3.     public Map<String, String> createSignature(@RequestParam String url)   
    4.     {  
    5.       System.out.println("RestFul of createSignature parameters url:"+url);  
    6.         
    7.       return SignatureUtil.sign(tokenService.getJsapi_ticket(), url);  
    8.     }  




    1. public static Map<String, String> sign(String jsapi_ticket, String url) {  
    2.             Map<String, String> ret = new HashMap<String, String>();  
    3.             String nonce_str = create_nonce_str();  
    4.             String timestamp = create_timestamp();  
    5.             String str;  
    6.             String signature = "";  
    7.        
    8.             //注意这里参数名必须全部小写,且必须有序  
    9.             str = "jsapi_ticket=" + jsapi_ticket +  
    10.                       "&noncestr=" + nonce_str +  
    11.                       "×tamp=" + timestamp +  
    12.                       "&url=" + url;  
    13.        
    14.             try  
    15.             {  
    16.                 MessageDigest crypt = MessageDigest.getInstance("SHA-1");  
    17.                 crypt.reset();  
    18.                 crypt.update(str.getBytes("UTF-8"));  
    19.                 signature = byteToHex(crypt.digest());  
    20.             }  
    21.             catch (NoSuchAlgorithmException e)  
    22.             {  
    23.                 e.printStackTrace();  
    24.             }  
    25.             catch (UnsupportedEncodingException e)  
    26.             {  
    27.                 e.printStackTrace();  
    28.             }  
    29.        
    30.             ret.put("url", url);  
    31.             ret.put("jsapi_ticket", jsapi_ticket);  
    32.             ret.put("nonceStr", nonce_str);  
    33.             ret.put("timestamp", timestamp);  
    34.             ret.put("signature", signature);  
    35.             ret.put("appid", WeChatInfo.WX_APPID);  
    36.        
    37.             return ret;  
    38.         }  
    39.           
    40.         private static String byteToHex(final byte[] hash) {  
    41.             Formatter formatter = new Formatter();  
    42.             for (byte b : hash)  
    43.             {  
    44.                 formatter.format("%02x", b);  
    45.             }  
    46.             String result = formatter.toString();  
    47.             formatter.close();  
    48.             return result;  
    49.         }  
    50.        
    51.         private static String create_nonce_str() {  
    52.             return UUID.randomUUID().toString();  
    53.         }  
    54.        
    55.         private static String create_timestamp() {  
    56.             return Long.toString(System.currentTimeMillis() / 1000);  
    57.         }  
    58.            
    59.         //获取当前系统时间 用来判断access_token是否过期  
    60.         public static String getTime(){  
    61.             Date dt=new Date();  
    62.             SimpleDateFormat sdf =new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
    63.             return sdf.format(dt);  
    64.         }  

    步骤四:通过ready接口处理成功验证

    [javascript] view plain copy
    1. wx.ready(function() {  
    2.         // 获取用户位置  
    3.         wx.getLocation({  
    4.             success : function(res) {  
    5.                 var latitude = res.latitude; // 纬度,浮点数,范围为90 ~ -90  
    6.                             var longitude = res.longitude; // 经度,浮点数,范围为180 ~ -180。  
    7.                             var speed = res.speed; // 速度,以米/每秒计  
    8.                             var accuracy = res.accuracy; // 位置精度  
    9.             },  
    10.             fail : function(res) {  
    11.                 alert("获取位置失败");  
    12.             }  
    13.         });  
    14.     });  

    步骤五:通过error接口处理失败验证
    1. wx.error(function(res) {  
    2.     alert("获取凭据失败");  
    3. });   

    文末福利:

    福利一:前端,Java,产品经理,微信小程序,Python等10G资源合集大放送:jianshu.com/p/e8197d4d9

    福利二:微信小程序入门与实战全套详细视频教程。


    【领取方法】

    关注 【编程微刊】微信公众号:

    回复【小程序demo】一键领取130个微信小程序源码demo资源。

    回复【领取资源】一键领取前端,Java,产品经理,微信小程序,Python等资源合集10G资源大放送。





    原文作者:祈澈姑娘
    原文链接:jianshu.com/u/05f416aef
    创作不易,转载请告知

    90后前端妹子,爱编程,爱运营,爱折腾。
    坚持总结工作中遇到的技术问题,坚持记录工作中所所思所见,欢迎大家一起探讨交流。


  • 相关阅读:
    kata rootfs 文件系统
    crt task
    如何在不到1个月内过四级?
    Android Studio软件技术基础 —Android项目描述---1-类的概念-android studio 组件属性-+标志-Android Studio 连接真机不识别其他途径
    如何把Eclipse项目迁移到AndroidStudio(如何把项目导入安卓)--这我很困惑
    设置Git--在Git中设置您的用户名--创建一个回购--Fork A Repo--社会化
    JavaScript代码笔记重点:
    Android编程权威指南笔记3:Android Fragment讲解与Android Studio中的依赖关系,如何添加依赖关系
    Android编程权威指南笔记2:解决R文件爆红问题和SDK概念
    Java代码题目:计算奖金和完全平方数
  • 原文地址:https://www.cnblogs.com/ting6/p/9725608.html
Copyright © 2011-2022 走看看