摇一摇周边

摇一摇周边是微信在线下的全新功能, 为线下商户提供近距离连接用户的能力, 并支持线下商户向周边用户提供个性化营销、互动及信息推荐等服务。

获取实例

  1. <?php
  2. use EasyWeChat\Foundation\Application;
  3. // ...
  4. $app = new Application($options);
  5. $shakearound = $app->shakearound;

API

特别提醒:1、下述所有的接口调用的方法参数都要严格按照方法参数前的类型传入相应类型的实参,否则可能会得到非预期的结果。2、涉及需要传入设备id($deviceIdentifier)的参数时,该参数是一个以 device_id 或包含 uuid major minor 为key的关联数组。3、涉及需要传入设备id列表($deviceIdentifiers)的参数时,该参数是一个二维数组,第一层为索引类型,第二层为关联类型($deviceIdentifier)。

  1. // 参数$deviceIdentifier的实参形式:
  2. ['device_id' => 10097]
  3. // 或
  4. [
  5. 'uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  6. 'major' => 10001,
  7. 'minor' => 12102,
  8. ]
  9. // 参数$deviceIdentifiers的实参形式:
  10. [
  11. ['device_id' => 10097],
  12. ['device_id' => 10098],
  13. ]
  14. // 或
  15. [
  16. [
  17. 'uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  18. 'major' => 10001,
  19. 'minor' => 12102,
  20. ],
  21. [
  22. 'uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  23. 'major' => 10001,
  24. 'minor' => 12103,
  25. ]
  26. ]

开通摇一摇周边

提示:若不是做 公众号第三方平台 开发,建议直接在微信管理后台申请开通摇一摇周边功能。

申请开通

申请开通摇一摇周边功能。成功提交申请请求后,工作人员会在三个工作日内完成审核。若审核不通过,可以重新提交申请请求。若是审核中,请耐心等待工作人员审核,在审核中状态不能再提交申请请求。

方法

$shakearound->register(string $name, string $tel, string $email, string $industryId, array $certUrls [, $reason = ‘’])

参数

$name 联系人姓名,不超过20汉字或40个英文字母$tel 联系人电话$email 联系人邮箱$industryId 平台定义的行业代号,具体请查看链接 行业代号$certUrls 相关资质文件的图片url,图片需先上传至微信侧服务器,用“素材管理-上传图片素材”接口上传图片,返回的图片URL再配置在此处;当不需要资质文件时,请传入空数组$reason 可选,申请理由,不超过250汉字或500个英文字母

注意:1、相关资质文件的图片是使用本页面下方的素材管理的接口上传的,切勿和另一个 素材管理 接口混淆。2、行业代码请务必传入字符串类型的实参,否则以数字0开头的行业代码将会被当成八进制数处理(将转换为十进制数),这可能不是期望的。

示例

  1. $result = $shakearound->register('zhang_san', '13512345678', 'weixin123@qq.com', '0118', [], 'test');
  2. /* 返回结果
  3. {
  4. "data": {
  5. },
  6. "errcode": 0,
  7. "errmsg": "success."
  8. }
  9. */
  10. var_dump($result->data) // 空数组
  11. var_dump($result->errcode) // 0
  12. var_dump($result->errmsg) // success.

查询审核状态

查询已经提交的开通摇一摇周边功能申请的审核状态。在申请提交后,工作人员会在三个工作日内完成审核。

方法

$shakearound->getStatus()

参数

示例

  1. $result = $shakearound->getStatus();
  2. /* 返回结果
  3. {
  4. "data": {
  5. "apply_time": 1432026025,
  6. "audit_comment": "test",
  7. "audit_status": 1,
  8. "audit_time": 0
  9. },
  10. "errcode": 0,
  11. "errmsg": "success."
  12. }
  13. */
  14. var_dump($result->data['audit_comment']) // test

获取摇一摇的设备及用户信息

获取设备信息,包括UUID、major、minor,以及距离、openID等信息。

方法

$shakearound->getShakeInfo(string $ticket [, int $needPoi = null])

参数

$ticket 摇周边业务的ticket,可在摇到的URL中得到,ticket生效时间为30分钟,每一次摇都会重新生成新的ticket$needPoi 可选,是否需要返回门店poi_id,传1则返回,否则不返回

示例

  1. $result = $shakearound->getShakeInfo('6ab3d8465166598a5f4e8c1b44f44645', 1);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "page_id ": 14211,
  6. "beacon_info": {
  7. "distance": 55.00620700469034,
  8. "major": 10001,
  9. "minor": 19007,
  10. "uuid": "FDA50693-A4E2-4FB1-AFCF-C6EB07647825"
  11. },
  12. "openid": "oVDmXjp7y8aG2AlBuRpMZTb1-cmA",
  13. "poi_id":1234
  14. },
  15. "errcode": 0,
  16. "errmsg": "success."
  17. }
  18. */
  19. var_dump($result->data['page_id']) // 14211
  20. var_dump($result->data['beacon_info']['distance']) // 55.00620700469034

设备管理

申请设备ID

申请配置设备所需的UUID、Major、Minor。申请成功后返回批次ID,可用返回的批次ID通过“查询设备ID申请状态”接口查询目前申请的审核状态。一个公众账号最多可申请100000个设备ID,如需申请的设备ID数超过最大限额,请邮件至zhoubian@tencent.com,邮件格式如下:

标题:申请提升设备ID额度内容:1、公众账号名称及appid(wx开头的字符串,在mp平台可查看)2、用途3、预估需要多少设备ID

方法

$shakearound->device()->apply(int $quantity, string $reason [, string $comment = ‘’ [, int $poiId = null]])

参数

$quantity 申请的设备ID的数量,单次新增设备超过500个,需走人工审核流程$reason 申请理由,不超过100个汉字或200个英文字母$comment 可选,备注,不超过15个汉字或30个英文字母$poiId 可选,设备关联的门店ID,关联门店后,在门店1KM的范围内有优先摇出信息的机会

示例

  1. $result = $shakearound->device()->apply(3, '测试', '测试专用', 1234);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "apply_id": 123,
  6. "audit_status": 1,
  7. "audit_comment": "审核中"
  8. },
  9. "errcode": 0,
  10. "errmsg": "success."
  11. }
  12. */
  13. var_dump($result->data['apply_id']) // 123

查询设备ID申请审核状态

查询设备ID申请的审核状态。若单次申请的设备ID数量小于等于500个,系统会进行快速审核;若单次申请的设备ID数量大于500个,则在三个工作日内完成审核。

方法

$shakearound->device()->getStatus(int $applyId)

参数

$applyId 批次ID,申请设备ID时所返回的批次ID

示例

  1. $result = $shakearound->device()->getStatus(123);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "apply_time": 1432026025,
  6. "audit_comment": "test",
  7. "audit_status": 1,
  8. "audit_time": 0
  9. },
  10. "errcode": 0,
  11. "errmsg": "success."
  12. }
  13. */
  14. var_dump($result->data['audit_status']) // 1

编辑设备信息

仅能修改设备的备注信息。

方法

$shakearound->device()->update(array $deviceIdentifier, string $comment)

参数

$deviceIdentifier 设备id,设备编号device_id或UUID、major、minor的关联数组,若二者都填,则以设备编号为优先$comment 设备的备注信息,不超过15个汉字或30个英文字母

示例

  1. $result = $shakearound->device()->update(['device_id' => 10011], 'test');
  2. // 或
  3. $result = $shakearound->device()->update(['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  4. 'major' => 1002,
  5. 'minor' => 1223,
  6. ], 'test');
  7. /* 返回结果
  8. {
  9. "data": {
  10. },
  11. "errcode": 0,
  12. "errmsg": "success."
  13. }
  14. */
  15. var_dump($result->errcode) // 0

配置设备与门店/其他公众账号门店的关联关系

关联本公众账号门店时,支持创建门店后直接关联在设备上,无需为审核通过状态,摇周边后台自动更新门店的最新信息和状态。关联其他公众账号门店时,支持设备关联其他公众账号的门店,门店需为审核通过状态。

因为第三方门店不归属本公众账号,所以未保存到设备详情中,查询设备列表接口与获取摇周边的设备及用户信息接口不会返回第三方门店。

方法

$shakearound->device()->bindLocation(array $deviceIdentifier, $poiId [, $type = 1 [, $poiAppid = null]])

参数

$deviceIdentifier 设备id,设备编号device_id或UUID、major、minor的关联数组,若二者都填,则以设备编号为优先$poiId 设备关联的门店ID,关联门店后,在门店1KM的范围内有优先摇出信息的机会。当值为0时,将清除设备已关联的门店ID$type 可选,为1时,关联的门店和设备归属于同一公众账号;为2时,关联的门店为其他公众账号的门店$poiAppid 可选,当$type为1时该参数为必填

示例

  1. // 关联本公众账号门店
  2. $result = $shakearound->device()->bindLocation(['device_id' => 10011], 1231);
  3. // 或
  4. $result = $shakearound->device()->bindLocation(['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  5. 'major' => 1002,
  6. 'minor' => 1223,
  7. ], 1231);
  8. // 关联其他公众账号门店
  9. // wxappid为关联门店所归属的公众账号的APPID
  10. $result = $shakearound->device()->bindLocation(['device_id' => 10011], 1231, 2, 'wxappid');
  11. // 或
  12. $result = $shakearound->device()->bindLocation(['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  13. 'major' => 1002,
  14. 'minor' => 1223,
  15. ], 1231, 2, 'wxappid');
  16. /* 返回结果
  17. {
  18. "data": {
  19. },
  20. "errcode": 0,
  21. "errmsg": "success."
  22. }
  23. */
  24. var_dump($result->errcode) // 0

查询设备列表

查询已有的设备ID、UUID、Major、Minor、激活状态、备注信息、关联门店、关联页面等信息。

根据设备id批量取回设备数据

方法

$shakearound->device()->fetchByIds(array $deviceIdentifiers)

参数

$deviceIdentifiers 设备id列表

示例

  1. $result = $shakearound->device()->fetchByIds([
  2. ['device_id' => 10097],
  3. ['device_id' => 10098],
  4. ]);
  5. // 或
  6. $result = $shakearound->device()->fetchByIds([
  7. ['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  8. 'major' => 10001,
  9. 'minor' => 12102,],
  10. ['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  11. 'major' => 10001,
  12. 'minor' => 12103,]
  13. ]);
  14. /* 返回结果
  15. {
  16. "data": {
  17. "devices": [
  18. {
  19. "comment": "",
  20. "device_id": 10097,
  21. "major": 10001,
  22. "minor": 12102,
  23. "status": 1,
  24. "last_active_time":1437276018,
  25. "poi_id": 0,
  26. "uuid": "FDA50693-A4E2-4FB1-AFCF-C6EB07647825"
  27. },
  28. {
  29. "comment": "",
  30. "device_id": 10098,
  31. "major": 10001,
  32. "minor": 12103,
  33. "status": 1,
  34. "last_active_time":1437276018,
  35. "poi_appid":"wxe3813f5d8c546fc7"
  36. "poi_id": 123,
  37. "uuid": "FDA50693-A4E2-4FB1-AFCF-C6EB07647825"
  38. }
  39. ],
  40. "total_count": 151
  41. },
  42. "errcode": 0,
  43. "errmsg": "success."
  44. }
  45. */
  46. var_dump($result->data['devices'][0][device_id]) // 10097
  47. var_dump($result->data['total_count']) // 151
分页批量取回设备数据

方法

$shakearound->device()->pagination(int $lastSeen, int $count)

参数

$lastSeen 前一次查询列表末尾的设备编号device_id,第一次查询last_seen为0$count 待查询的设备数量,不能超过50个

示例

  1. $result = $shakearound->device()->pagination(10097, 3);
  2. // 返回结果同上
根据申请时的批次ID分页批量取回设备数据

方法

$shakearound->device()->fetchByApplyId(int $applyId, int $lastSeen, int $count)

参数

$applyId 批次ID,申请设备ID时所返回的批次ID$lastSeen 前一次查询列表末尾的设备编号device_id,第一次查询lastSeen为0$count 待查询的设备数量,不能超过50个

示例

  1. $result = $shakearound->device()->fetchByApplyId(1231, 10097, 3);
  2. // 返回结果同上

页面管理

新增页面

新增摇一摇出来的页面信息,包括在摇一摇页面出现的主标题、副标题、图片和点击进去的超链接。其中,图片必须为用素材管理接口上传至微信侧服务器后返回的链接。

注意:图片是使用本页面下方的素材管理的接口上传的,切勿和另一个 素材管理 接口混淆。

方法

$shakearound->page()->add(string $title, string $description, strig $pageUrl, string $iconUrl [, string $comment = ‘’])

参数

$title 在摇一摇页面展示的主标题,不超过6个汉字或12个英文字母$description 在摇一摇页面展示的副标题,不超过7个汉字或14个英文字母$pageUrl 点击进去的超链接$iconUrl 在摇一摇页面展示的图片。图片需先上传至微信侧服务器,用“素材管理-上传图片素材”接口上传图片,返回的图片URL再配置在此处$comment 可选,页面的备注信息,不超过15个汉字或30个英文字母

示例

  1. $result = $shakearound->page()->add('主标题', '副标题', 'https://zb.weixin.qq.com', 'http://3gimg.qq.com/shake_nearby/dy/icon', 'test');
  2. /* 返回结果
  3. {
  4. "data": {
  5. "page_id": 28840
  6. }
  7. "errcode": 0,
  8. "errmsg": "success."
  9. }
  10. */
  11. var_dump($result->data['page_id']) // 28840

编辑页面信息

编辑摇一摇出来的页面信息,包括在摇一摇页面出现的主标题、副标题、图片和点击进去的超链接。

方法

$shakearound->page()->update(int $pageId, string $title, string $description, string $pageUrl, string $iconUrl [, string $comment = ‘’])

参数

$pageId 摇周边页面唯一ID$title 在摇一摇页面展示的主标题,不超过6个汉字或12个英文字母$description 在摇一摇页面展示的副标题,不超过7个汉字或14个英文字母$pageUrl 点击进去的超链接$iconUrl 在摇一摇页面展示的图片。图片需先上传至微信侧服务器,用“素材管理-上传图片素材”接口上传图片,返回的图片URL再配置在此处$comment 可选,页面的备注信息,不超过15个汉字或30个英文字母

示例

  1. $result = $shakearound->page()->add(28840, '主标题', '副标题', 'https://zb.weixin.qq.com', 'http://3gimg.qq.com/shake_nearby/dy/icon', 'test');
  2. /* 返回结果
  3. {
  4. "data": {
  5. },
  6. "errcode": 0,
  7. "errmsg": "success."
  8. }
  9. */
  10. var_dump($result->errcode) // 0

查询页面列表

查询已有的页面,包括在摇一摇页面出现的主标题、副标题、图片和点击进去的超链接。

根据页面id批量取回页面数据

方法

$shakearound->page()->fetchByIds(array $pageIds)

参数

$pageIds 页面的id列表,索引数组

示例

  1. $result = $shakearound->page()->fetchByIds([28840, 28842]);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "pages": [
  6. {
  7. "comment": "just for test",
  8. "description": "test",
  9. "icon_url": "https://www.baidu.com/img/bd_logo1",
  10. "page_id": 28840,
  11. "page_url": "http://xw.qq.com/testapi1",
  12. "title": "测试1"
  13. },
  14. {
  15. "comment": "just for test",
  16. "description": "test",
  17. "icon_url": "https://www.baidu.com/img/bd_logo1",
  18. "page_id": 28842,
  19. "page_url": "http://xw.qq.com/testapi2",
  20. "title": "测试2"
  21. }
  22. ],
  23. "total_count": 2
  24. },
  25. "errcode": 0,
  26. "errmsg": "success."
  27. }
  28. */
  29. var_dump($result->data['pages'][0]['title']) // 测试1
  30. var_dump($result->data['total_count']) // 2
分页批量取回页面数据

方法

$shakearound->page()->pagination(int $begin, int $count)

参数

$begin 页面列表的起始索引值$count 待查询的页面数量,不能超过50个

示例

  1. $result = $shakearound->page()->pagination(0,2);
  2. // 返回结果同上

删除页面

删除已有的页面,包括在摇一摇页面出现的主标题、副标题、图片和点击进去的超链接。

注意:只有页面与设备没有关联关系时,才可被删除。

方法

$shakearound->page()->delete(int $pageId)

参数

$pageId 页面的id

示例

  1. $result = $shakearound->page()->delete(34567);
  2. /* 返回结果
  3. {
  4. "data": {
  5. },
  6. "errcode": 0,
  7. "errmsg": "success."
  8. }
  9. */
  10. var_dump($result->errcode) // 0

素材管理

上传在摇一摇功能中需使用到的图片素材,素材保存在微信侧服务器上。图片格式限定为:jpg,jpeg,png,gif。若图片为在摇一摇页面展示的图片,则其素材为 icon 类型的图片,图片大小建议 120px*120 px ,限制不超过 200 px *200 px ,图片需为 正方形 。若图片为申请开通摇一摇周边功能需要上传的资质文件图片,则其素材为 license 类型的图片,图片的文件大小不超过 2MB ,尺寸不限,形状不限。

方法

$shakearound->material()->uploadImage(string $path [, string $type = ‘icon’])

参数

$path 图片所在路径$type 可选,值为icon或license

示例

  1. $result = $shakearound->material()->uploadImage(__DIR__ . '/stubs/image.jpg');
  2. /* 返回结果
  3. {
  4. "data": {
  5. "pic_url": http://shp.qpic.cn/wechat_shakearound_pic/0/1428377032e9dd2797018cad79186e03e8c5aec8dc/120"
  6. },
  7. "errcode": 0,
  8. "errmsg": "success."
  9. }
  10. */
  11. var_dump($result->data['pic_url']) // http://shp.qpic.cn/wechat_shakearound_pic/0/1428377032e9dd2797018cad79186e03e8c5aec8dc/120

管理设备与页面的关系

通过接口申请的设备ID,需先配置页面,若未配置页面,则摇不出页面信息。

配置设备与页面的关联关系

配置完成后,在此设备的信号范围内,即可摇出关联的页面信息。若设备配置多个页面,则随机出现页面信息。一个设备最多可配置30个关联页面。

注意:1、配置时传入该设备需要关联的页面的id列表,该设备原有的关联关系将被直接清除。2、页面的id列表允许为空(传入空数组),当页面的id列表为空时则会清除该设备的所有关联关系。

方法

$shakearound->relation()->bindPage(array $deviceIdentifier, array $pageIds)

参数

$deviceIdentifier 设备id,设备编号device_id或UUID、major、minor的关联数组,若二者都填,则以设备编号为优先$pageIds 页面的id列表,索引数组

示例

  1. $result = $shakearound->relation()->bindPage(['device_id' => 10011], [12345, 23456, 334567]);
  2. // 或
  3. $result = $shakearound->relation()->bindPage(['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  4. 'major' => 1002,
  5. 'minor' => 1223,
  6. ], [12345, 23456, 334567]);
  7. /* 返回结果
  8. {
  9. "data": {
  10. },
  11. "errcode": 0,
  12. "errmsg": "success."
  13. }
  14. */
  15. var_dump($result->errcode) // 0

查询设备与页面的关联关系

查询指定设备所关联的页面

根据设备ID或完整的UUID、Major、Minor查询该设备所关联的所有页面信息

方法

$shakearound->relation()->getPageByDeviceId(array $deviceIdentifier [, boolean $raw = false])

注意:该方法默认对返回的数据进行处理后返回一个包含页面id的索引数组。若要返回和 getDeviceByPageId 方法类似的数据,请传入 true 作为第二个参数。

参数

$deviceIdentifier 设备id,设备编号device_id或UUID、major、minor的关联数组,若二者都填,则以设备编号为优先$raw 可选,当为true时,返回值和getDeviceByPageId方法类似,否则返回页面的id列表(索引数组,无关联时为空数组)

示例

  1. $result = $shakearound->relation()->getPageByDeviceId(['device_id' => 10011]);
  2. // 或
  3. $result = $shakearound->relation()->getPageByDeviceId(['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  4. 'major' => 1002,
  5. 'minor' => 1223,
  6. ]);
  7. // 返回结果
  8. var_dump($result) // [50054,50055]
查询指定页面所关联的设备

指定页面ID分页查询该页面所关联的所有的设备信息

方法

$shakearound->relation()->getDeviceByPageId(int $pageId, int $begin, int $count)

参数

$pageId 指定的页面id$begin 关联关系列表的起始索引值$count 待查询的关联关系数量,不能超过50个

示例

  1. $result = $shakearound->relation()->getDeviceByPageId(50054, 0, 3);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "relations": [
  6. {
  7. "device_id": 797994,
  8. "major": 10001,
  9. "minor": 10023,
  10. "page_id": 50054,
  11. "uuid": "FDA50693-A4E2-4FB1-AFCF-C6EB07647825"
  12. },
  13. {
  14. "device_id": 797995,
  15. "major": 10001,
  16. "minor": 10024,
  17. "page_id": 50054,
  18. "uuid": "FDA50693-A4E2-4FB1-AFCF-C6EB07647825"
  19. }
  20. ],
  21. "total_count": 2
  22. },
  23. "errcode": 0,
  24. "errmsg": "success."
  25. }
  26. */
  27. var_dump($result->data['relations'][0]['device_id']) // 797994
  28. var_dump($result->data['total_count']) // 2

摇一摇数据统计

此接口无法获取当天的数据,最早只能获取前一天的数据。由于系统在凌晨处理前一天的数据,太早调用此接口可能获取不到数据,建议在早上8:00之后调用此接口。

以设备为维度的数据统计

查询单个设备进行摇周边操作的人数、次数,点击摇周边消息的人数、次数。

注意:查询的最长时间跨度为30天。只能查询最近90天的数据。

方法

$shakearound->stats()->deviceSummary(array $deviceIdentifier, int $beginDate, int $endDate)

参数

$deviceIdentifier 设备id,设备编号device_id或UUID、major、minor的关联数组,若二者都填,则以设备编号为优先$beginDate 起始日期时间戳,最长时间跨度为30天,单位为秒$endDate 结束日期时间戳,最长时间跨度为30天,单位为秒

示例

  1. $result = $shakearound->stats()->deviceSummary(['device_id' => 10011], 1425052800, 1425139200);
  2. // 或
  3. $result = $shakearound->stats()->deviceSummary(['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  4. 'major' => 1002,
  5. 'minor' => 1223,
  6. ], 1425052800, 1425139200);
  7. /* 返回结果
  8. {
  9. "data": [
  10. {
  11. "click_pv": 0,
  12. "click_uv": 0,
  13. "ftime": 1425052800,
  14. "shake_pv": 0,
  15. "shake_uv": 0
  16. },
  17. {
  18. "click_pv": 0,
  19. "click_uv": 0,
  20. "ftime": 1425139200,
  21. "shake_pv": 0,
  22. "shake_uv": 0
  23. }
  24. ],
  25. "errcode": 0,
  26. "errmsg": "success."
  27. }
  28. */
  29. var_dump($result->data[0]['ftime']) // 1425052800

批量查询设备统计数据

查询指定时间商家帐号下的每个设备进行摇周边操作的人数、次数,点击摇周边消息的人数、次数。

只能查询最近90天内的数据,且一次只能查询一天。

注意:对于摇周边人数、摇周边次数、点击摇周边消息的人数、点击摇周边消息的次数都为0的设备,不在结果列表中返回。

方法

$shakearound->stats()->batchDeviceSummary(int $timestamp, int $pageIndex)

参数

$timestamp 指定查询日期时间戳,单位为秒$pageIndex 指定查询的结果页序号,返回结果按摇周边人数降序排序,每50条记录为一页

示例

  1. $result = $shakearound->stats()->batchDeviceSummary(1435075200, 1);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "devices": [
  6. {
  7. "device_id": 10097,
  8. "major": 10001,
  9. "minor": 12102,
  10. "uuid": "FDA50693-A4E2-4FB1-AFCF-C6EB07647825"
  11. "shake_pv": 1
  12. "shake_uv": 2
  13. "click_pv": 3
  14. "click_uv": 4
  15. },
  16. {
  17. "device_id": 10098,
  18. "major": 10001,
  19. "minor": 12103,
  20. "uuid": "FDA50693-A4E2-4FB1-AFCF-C6EB07647825"
  21. "shake_pv": 1
  22. "shake_uv": 2
  23. "click_pv": 3
  24. "click_uv": 4
  25. }
  26. ],
  27. },
  28. "date":1435075200
  29. "total_count": 151
  30. "page_index":1
  31. "errcode": 0,
  32. "errmsg": "success."
  33. }
  34. */
  35. var_dump($result->data['devices'][0]['device_id']) // 10097
  36. var_dump($result->total_count) // 151

以页面为维度的数据统计

查询单个页面通过摇周边摇出来的人数、次数,点击摇周边页面的人数、次数

注意:查询的最长时间跨度为30天。只能查询最近90天的数据。

方法

$shakearound->stats()->pageSummary(int $pageId, int $beginDate, int $endDate);

参数

$pageId 指定页面的页面ID$beginDate 起始日期时间戳,最长时间跨度为30天,单位为秒$endDate 结束日期时间戳,最长时间跨度为30天,单位为秒

示例

  1. $result = $shakearound->stats()->pageSummary(12345, 1425052800, 1425139200);
  2. /* 返回结果
  3. {
  4. "data": [
  5. {
  6. "click_pv": 0,
  7. "click_uv": 0,
  8. "ftime": 1425052800,
  9. "shake_pv": 0,
  10. "shake_uv": 0
  11. },
  12. {
  13. "click_pv": 0,
  14. "click_uv": 0,
  15. "ftime": 1425139200,
  16. "shake_pv": 0,
  17. "shake_uv": 0
  18. }
  19. ],
  20. "errcode": 0,
  21. "errmsg": "success."
  22. }
  23. */
  24. var_dump($result->data[1]['ftime']) // 1425139200

批量查询页面统计数据

查询指定时间商家帐号下的每个页面进行摇周边操作的人数、次数,点击摇周边消息的人数、次数。

注意:对于摇周边人数、摇周边次数、点击摇周边消息的人数、点击摇周边消息的次数都为0的页面,不在结果列表中返回。

方法

$shakearound->stats()->batchPageSummary(int $timestamp, int $pageIndex);

参数

$timestamp 指定查询日期时间戳,单位为秒$pageIndex 指定查询的结果页序号,返回结果按摇周边人数降序排序,每50条记录为一页

示例

  1. $result = $shakearound->stats()->batchPageSummary(1435075200, 1);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "pages": [
  6. {
  7. "page_id":1234
  8. "click_pv": 1,
  9. "click_uv": 3,
  10. "shake_pv": 0,
  11. "shake_uv": 0
  12. },
  13. {
  14. "page_id":5678
  15. "click_pv": 1,
  16. "click_uv": 2,
  17. "shake_pv": 0,
  18. "shake_uv": 0
  19. },
  20. ],
  21. },
  22. "date":1435075200
  23. "total_count": 151
  24. "page_index":1
  25. "errcode": 0,
  26. "errmsg": "success."
  27. }
  28. */
  29. var_dump($result->data['pages'][0]['click_uv']) // 3
  30. var_dump($result->total_count) // 151

设备分组管理

调用H5页面获取设备信息 JS API接口,需要先把设备分组,微信客户端只会返回已在分组中的设备信息。

新增分组

新建设备分组,每个帐号下最多只有1000个分组。

方法

$shakearound->group()->add(string $name)

参数

$name 分组名称,不超过100汉字或200个英文字母

示例

  1. $result = $shakearound->group()->add('test');
  2. /* 返回结果
  3. {
  4. "data": {
  5. "group_id" : 123,
  6. "group_name" : "test"
  7. },
  8. "errcode": 0,
  9. "errmsg": "success."
  10. }
  11. */
  12. var_dump($result->data['group_id']) // 123
  13. var_dump($result->data['group_name']) // test

编辑分组信息

编辑设备分组信息,目前只能修改分组名。

方法

$shakearound->group()->update(int $groupId, string $name)

参数

$groupId 分组唯一标识,全局唯一$name 分组名称,不超过100汉字或200个英文字母

示例

  1. $result = $shakearound->group()->update(123, 'newName');
  2. /* 返回结果
  3. {
  4. "data": {
  5. },
  6. "errcode": 0,
  7. "errmsg": "success."
  8. }
  9. */
  10. var_dump($result->errcode) // 0

删除分组

删除设备分组,若分组中还存在设备,则不能删除成功。需把设备移除以后,才能删除。

在执行删除前,最好先使用 getDetails 方法查询分组详情,若分组内有设备,先使用 removeDevice 方法移除。

方法

$shakearound->group()->delete(int $groupId)

参数

$groupId 分组唯一标识,全局唯一

示例

  1. $result = $shakearound->group()->delete(123);
  2. /* 返回结果
  3. {
  4. "data": {
  5. },
  6. "errcode": 0,
  7. "errmsg": "success."
  8. }
  9. */
  10. var_dump($result->errcode) // 0

查询分组列表

查询账号下所有的分组。

方法

$shakearound->group()->lists(int $begin, int $count)

参数

$begin 分组列表的起始索引值$count 待查询的分组数量,不能超过1000个

示例

  1. $result = $shakearound->group()->lists(0, 2);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "groups":[
  6. {
  7. "group_id" : 123,
  8. "group_name" : "test1"
  9. },
  10. {
  11. "group_id" : 124,
  12. "group_name" : "test2"
  13. }
  14. ],
  15. "total_count": 100
  16. },
  17. "errcode": 0,
  18. "errmsg": "success."
  19. }
  20. */
  21. var_dump($result->data['groups'][1]['group_name']) // test2
  22. var_dump($result->data['total_count']) // 100

查询分组详情

查询分组详情,包括分组名,分组id,分组里的设备列表。

方法

$shakearound->group()->getDetails(int $groupId, int $begin, int $count)

参数

$groupId 分组唯一标识,全局唯一$begin 分组里设备的起始索引值$count 待查询的分组里设备的数量,不能超过1000个

示例

  1. $result = $shakearound->group()->getDetails(123, 0, 2);
  2. /* 返回结果
  3. {
  4. "data": {
  5. "group_id" : 123,
  6. "group_name" : "test",
  7. "total_count": 100,
  8. "devices" :[
  9. {
  10. "device_id" : 123456,
  11. "uuid" : "FDA50693-A4E2-4FB1-AFCF-C6EB07647825",
  12. "major" : 10001,
  13. "minor" : 10001,
  14. "comment" : "test device1",
  15. "poi_id" : 12345,
  16. },
  17. {
  18. "device_id" : 123457,
  19. "uuid" : "FDA50693-A4E2-4FB1-AFCF-C6EB07647825",
  20. "major" : 10001,
  21. "minor" : 10002,
  22. "comment" : "test device2",
  23. "poi_id" : 12345,
  24. }
  25. ]
  26. },
  27. "errcode": 0,
  28. "errmsg": "success."
  29. }
  30. */
  31. var_dump($result->data['devices'][0]['comment']) // test device1
  32. var_dump($result->data['total_count']) // 100

添加设备到分组

添加设备到分组,每个分组能够持有的设备上限为10000,并且每次添加操作的添加上限为1000。

只有在摇周边申请的设备才能添加到分组。

方法

$shakearound->group()->addDevice(int $groupId, array $deviceIdentifiers)

参数

$groupId 分组唯一标识,全局唯一$deviceIdentifiers 设备id列表

示例

  1. $result = $shakearound->group()->addDevice(123, [
  2. ['device_id' => 10097],
  3. ['device_id' => 10098],
  4. ]);
  5. // 或
  6. $result = $shakearound->group()->addDevice(123, [
  7. ['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  8. 'major' => 10001,
  9. 'minor' => 12102,],
  10. ['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  11. 'major' => 10001,
  12. 'minor' => 12103,]
  13. ]);
  14. /* 返回结果
  15. {
  16. "data": {
  17. },
  18. "errcode": 0,
  19. "errmsg": "success."
  20. }
  21. */
  22. var_dump($result->errcode) // 0

从分组中移除设备

从分组中移除设备,每次删除操作的上限为1000。

方法

$shakearound->group()->removeDevice(int $groupId, array $deviceIdentifiers)

参数

$groupId 分组唯一标识,全局唯一$deviceIdentifiers 设备id列表

示例

  1. $result = $shakearound->group()->removeDevice(123, [
  2. ['device_id' => 10097],
  3. ['device_id' => 10098],
  4. ]);
  5. // 或
  6. $result = $shakearound->group()->removeDevice(123, [
  7. ['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  8. 'major' => 10001,
  9. 'minor' => 12102,],
  10. ['uuid' => 'FDA50693-A4E2-4FB1-AFCF-C6EB07647825',
  11. 'major' => 10001,
  12. 'minor' => 12103,]
  13. ]);
  14. /* 返回结果
  15. {
  16. "data": {
  17. },
  18. "errcode": 0,
  19. "errmsg": "success."
  20. }
  21. */
  22. var_dump($result->errcode) // 0

摇一摇红包

微信官方目前暂停了摇红包接口,该接口可能会有所调整,故而暂时不提供该接口的封装。

官方公告详情请至: 关于摇红包接口暂停的公告

摇一摇事件通知

用户进入摇一摇界面,在“周边”页卡下摇一摇时,微信会把这个事件推送到开发者填写的URL(登录公众平台进入开发者中心设置)。推送内容包含摇一摇时“周边”页卡展示出来的页面所对应的设备信息,以及附近最多五个属于该公众账号的设备的信息。当摇出列表时,此事件不推送。

摇一摇事件的事件类型:ShakearoundUserShake关于事件的处理请移步: 事件

摇一摇周边错误码

摇周边错误码请移步: 错误码

有关摇一摇周边接口信息的更多细节请参考微信官方文档相应条目: 微信官方文档