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

--注意:微信测试号不具备这个功能


步骤一:绑定域名   注意不要加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请求

  1. var url = location.href.split('#')[0];
  2. $.ajax({
  3. type:"GET",
  4. url:"signature.action?url=" + url,
  5. dataType:"json",
  6. success:function(data){
  7. if (data){
  8. wx.config({
  9. debug: false,
  10. appId: data.appid,
  11. timestamp: data.timestamp,
  12. nonceStr: data.nonceStr,
  13. signature: data.signature,
  14. jsApiList: [// 这个必须要配置,不然会报权限不足的错误
  15. 'checkJsApi',
  16. 'getNetworkType',//网络状态接口
  17. 'openLocation',//使用微信内置地图查看地理位置接口
  18. 'getLocation', //获取地理位置接口
  19. 'startSearchBeacons',//开启扫描周边设备
  20. 'stopSearchBeacons'//停止扫描
  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. return SignatureUtil.sign(tokenService.getJsapi_ticket(), url);
  7. }
  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. str = "jsapi_ticket=" + jsapi_ticket +
  9. "&noncestr=" + nonce_str +
  10. "×tamp=" + timestamp +
  11. "&url=" + url;
  12. try
  13. {
  14. MessageDigest crypt = MessageDigest.getInstance("SHA-1");
  15. crypt.reset();
  16. crypt.update(str.getBytes("UTF-8"));
  17. signature = byteToHex(crypt.digest());
  18. }
  19. catch (NoSuchAlgorithmException e)
  20. {
  21. e.printStackTrace();
  22. }
  23. catch (UnsupportedEncodingException e)
  24. {
  25. e.printStackTrace();
  26. }
  27. ret.put("url", url);
  28. ret.put("jsapi_ticket", jsapi_ticket);
  29. ret.put("nonceStr", nonce_str);
  30. ret.put("timestamp", timestamp);
  31. ret.put("signature", signature);
  32. ret.put("appid", WeChatInfo.WX_APPID);
  33. return ret;
  34. }
  35. private static String byteToHex(final byte[] hash) {
  36. Formatter formatter = new Formatter();
  37. for (byte b : hash)
  38. {
  39. formatter.format("%02x", b);
  40. }
  41. String result = formatter.toString();
  42. formatter.close();
  43. return result;
  44. }
  45. private static String create_nonce_str() {
  46. return UUID.randomUUID().toString();
  47. }
  48. private static String create_timestamp() {
  49. return Long.toString(System.currentTimeMillis() / 1000);
  50. }

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


  1. wx.ready(function(){
  2. // 蓝牙扫描接口
  3. wx.startSearchBeacons({
  4. ticket:"",  //摇周边的业务ticket, 系统自动添加在摇出来的页面链接后面
  5. success: function(res){
  6. wx.onSearchBeacons({
  7. complete:function(data){
  8. alert(JSON.stringify(data));
  9. showBeacon(data.beacons);//处理返回的beacon数组
  10. }
  11. });
  12. },
  13. fail:function(res){
  14. var errmsg = JSON.stringify(res.errMsg);
  15. var arr = errmsg.split(':');
  16. var errmsgBody = arr[1];
  17. if(errmsgBody.substr(0, 9) == "bluetooth"){
  18. alert("蓝牙未打开,请打开后重试!");
  19. } else if(errmsgBody.substr(0, 8) == "location"){
  20. alert("手机位置未打开,请打开后重试!");
  21. }else{
  22. alert(JSON.stringify(res));
  23. }
  24. }
  25. });
  26. });
  1. wx.error(function(res){//验证错误时执行的函数
  2. alert(JSON.stringify(res));
  3. });

函数详解:

1.开启查找周边ibeacon设备接口

wx.startSearchBeacons({
   ticket:"",
   complete:function(argv){
   //回调函数
   }
});

返回参数说明

打开成功返回:“startSearchBeacons:ok”;

打开后未stop再次打开 :“startSearchBeacons:already started”;

蓝牙未打开返回 :“startSearchBeacons:bluetooth power off”;

地理位置服务未打开返回: “startSearchBeacons:location service disable”;

系统不支持返回 :“startSearchBeacons:system unsupported”。

2. 关闭查找周边ibeacon设备接口

wx.stopSearchBeacons({
   complete:function(res){
   //回调函数
   }
});
返回说明

关闭成功返回“stopSearchBeacons:ok”;

3.监听周边ibeacon设备接口(这个函数写在startSearchBeacons的回调函数里面)

wx.onSearchBeacons({
   complete:function(argv){
   //回调函数
   }
});

返回数据为数组

onSearchBeacons:
{
   "beacons":[
               {
               "major":10008,
               "minor":57686,
               "uuid":"FDA50693-A4E2-4FB1-AFCF-C6EB07647825",
               "accuracy":"0.235344",
               "rssi":"-66",
               "proximity":"1",
               "heading":"288.1355"
               },
               {
               "major":10008,
               "minor":57687,
               "uuid":"FDA50693-A4E2-4FB1-AFCF-C6EB07647825",
               "accuracy":"0.349124",
               "rssi":"-49",
               "proximity":"2",
               "heading":"288.1355"
               }
               ]
}
参数说明

参数 说明
UUID、major、minor UUID、major、minor
accuracy 距离,单位为米
proximity 精度,0:CLProximityUnknown, 1:CLProximityImmediate, 2:CLProximityNear, 3:CLProximityFar
rssi 接收信号的强度指示

heading 接收信号时设备的方向(安卓设备返回有此字段,iOS无);iOS设备若需要获取方向,可以利用HTML5标准API获取, 查看示例

文末福利:

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

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

【领取方法】

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

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

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



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

微信开发之八 页面获取周围beacon设备的更多相关文章

  1. 基于Jquery WeUI的微信开发H5页面控件的经验总结(1)

    在微信开发H5页面的时候,往往借助于WeUI或者Jquery WeUI等基础上进行界面效果的开发,由于本人喜欢在Asp.net的Web界面上使用JQuery,因此比较倾向于使用 jQuery WeUI ...

  2. 基于Jquery WeUI的微信开发H5页面控件的经验总结(2)

    在微信开发H5页面的时候,往往借助于WeUI或者Jquery WeUI等基础上进行界面效果的开发,由于本人喜欢在Asp.net的Web界面上使用JQuery,因此比较倾向于使用 jQuery WeUI ...

  3. Java开发微信公众号(五)---微信开发中如何获取access_token以及缓存access_token

    获取access_token是微信api最重要的一个部分,因为调用其他api很多都需要用到access_token.比如自定义菜单接口.客服接口.获取用户信息接口.用户分组接口.群发接口等在请求的时候 ...

  4. 微信开发笔记:获取用户openid,以及用户头像昵称等信息

    微信开发的时候有一个很便利的途径来进行一个用户的一步注册登录,就是使用用户的微信信息来直接进行登陆,可以省去很多不必要的麻烦.那具体这些信息是如何来获取的呢? 首先呢,我们需要对微信进行一个授权,让微 ...

  5. 微信小程序中获取高度及设备的方法

    由于js中可以采用操纵dom的方法来获取页面元素的高度,可是在微信小程序中不能操纵dom,经过查找之后发现仅仅只有以下几个方法可以获取到高度 wx.getSystemInfoSync().window ...

  6. 转:微信开发获取地理位置实例(java,非常详细,附工程源码)

    微信开发获取地理位置实例(java,非常详细,附工程源码)   在本篇博客之前,博主已经写了4篇关于微信相关文章,其中三篇是本文基础: 1.微信开发之入门教程,该文章详细讲解了企业号体验号免费申请与一 ...

  7. 微信开发获取地理位置实例(java,非常详细,附工程源码)

    在本篇博客之前,博主已经写了4篇关于微信相关文章,其中三篇是本文基础: 1.微信开发之入门教程,该文章详细讲解了企业号体验号免费申请与一些必要的配置,以及如何调用微信接口. 2.微信开发之通过代理调试 ...

  8. 微信测试号开发之九 微信网页授权:页面获取用户openid

    原文链接:https://blog.csdn.net/qq_37936542/article/details/78981369 一:配置接口 注意:这里填写的是域名(是一个字符串),而不是URL,因此 ...

  9. [麦先生]TP3.2之微信开发那点事[基础篇](获取access_token)

    在微信文档中一共提供了两个access_token:一个是伪全局配置的Access_token;一个是在微信网页授权时的小Access_token 很多刚刚接触微信开发的人经常会混淆这两个的作用: 我 ...

随机推荐

  1. File Upload with Jersey

    package com.toic.rest; import java.io.File; import java.io.FileOutputStream; import java.io.IOExcept ...

  2. XML Pull

    java [android]xml  new parse tool XML parsing with XML Pull import org.xmlpull.v1.XmlPullParser;

  3. js全选反选按钮实现

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  4. JS/CSS 在屏幕底部弹出消息

    <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title> ...

  5. C#操作SQLite方法实例详解

    用 C# 访问 SQLite 入门(1) CC++C#SQLiteFirefox  用 C# 访问 SQLite 入门 (1) SQLite 在 VS C# 环境下的开发,网上已经有很多教程.我也是从 ...

  6. Mybaits中session的应用一

    获取一级缓存session SqlSession session = this.yangchebaoDbManagerImpl.getSqlSessionFactory().openSession(f ...

  7. Servlet 规范笔记—servlet概念及结构

     Servlet, 这个词对java程序员并不陌生,我想几乎每个java程序员在学习J2EE知识时,首先学习的就是servlet,这是一种正确的学习方式,在我看来Servlet是J2EE的基础,要熟练 ...

  8. mysql 多实例案例实战

    其实Mysql多实例就是在一个 mysql 服务上面启动三个实例,相当于三个分离开来的数据库,至于为什么要做这个,你也可以选择分别安装三个MySQL,只是过于麻烦,多实例中只需要一个配置档my.cnf ...

  9. mySQL函数根据经纬度计算两点距离 复制代码

    http://www.cnblogs.com/lujiulong/p/6185041.html https://my.oschina.net/u/2273085/blog/505172?p={{pag ...

  10. COGS——T 1265. [NOIP2012] 同余方程

    http://cogs.pro/cogs/problem/problem.php?pid=1265 ★☆   输入文件:mod.in   输出文件:mod.out   简单对比时间限制:1 s   内 ...