用户

用户信息的获取是微信开发中比较常用的一个功能了,以下所有的用户信息的获取与更新,都是基于微信的 openid 的,并且是已关注当前账号的,其它情况可能无法正常使用。

获取用户信息

获取单个:

  1. $user = $app->user->get($openId);

获取多个:

  1. $users = $app->user->select([$openId1, $openId2, ...]);

获取用户列表

  1. $app->user->list($nextOpenId = null); // $nextOpenId 可选

示例:

  1. $users = $app->user->list();
  2. // result
  3. {
  4. "total": 2,
  5. "count": 2,
  6. "data": {
  7. "openid": [
  8. "OPENID1",
  9. "OPENID2"
  10. ]
  11. },
  12. "next_openid": "NEXT_OPENID"
  13. }

修改用户备注

  1. $app->user->remark($openId, $remark); // 成功返回boolean

示例:

  1. $app->user->remark($openId, "僵尸粉");

拉黑用户

  1. $app->user->block('openidxxxxx');
  2. // 或者多个用户
  3. $app->user->block(['openid1', 'openid2', 'openid3', ...]);

取消拉黑用户

  1. $app->user->unblock('openidxxxxx');
  2. // 或者多个用户
  3. $app->user->unblock(['openid1', 'openid2', 'openid3', ...]);

获取黑名单

  1. $app->user->blacklist($beginOpenid = null); // $beginOpenid 可选

账号迁移 openid 转换

账号迁移请从这里了解:https://kf.qq.com/product/weixinmp.html#hid=2488

微信用户关注不同的公众号,对应的 OpenID 是不一样的,迁移成功后,粉丝的 OpenID 以目标帐号(即新公众号)对应的 OpenID 为准。但开发者可以通过开发接口转换 OpenID,开发文档可以参考:提供一个 openid 转换的 API 接口,当帐号迁移后,可以通过该接口:

  1. 将原帐号粉丝的 openid 转换为新帐号的 openid。
  2. 将有授权关系用户的 openid 转换为新帐号的 openid。
  3. 将卡券关联用户的 openid 转换为新帐号的 openid。
  • 原帐号:准备要迁移的帐号,当审核完成且管理员确认后即被回收。
  • 新帐号:用来接纳粉丝的帐号。新帐号在整个流程中均能正常使用。

一定要按照下面的步骤来操作。

  1. 一定要在原帐号被冻结之前,最好是准备提交审核前,获取原帐号的用户列表。如果没有原帐号的用户列表,用不了转换工具。如果原账号被回收,这时候也没办法调用接口获取用户列表。

  2. 转换 openid 的 API 接口如下,可在帐号迁移审核完成后开始调用,并最多保留15天。若帐号迁移没完成,调用时无返回结果或报错。帐号迁移15天后,该转换接口将会失效、无法拉取到数据。

{info} 如何获取用户列表见这里:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140840

  1. $app->user->changeOpenid($oldAppId, $openidList);

返回值样例:

  1. {
  2. "errcode":0,
  3. "errmsg":"ok",
  4. "result_list":[
  5. {
  6. "ori_openid":"oEmYbwN-n24jxvk4Sox81qedINkQ",
  7. "new_openid":"o2FwqwI9xCsVadFah_HtpPfaR-X4",
  8. "err_msg":"ok"
  9. },
  10. {
  11. "ori_openid":"oEmYbwH9uVd4RKJk7ZZg6SzL6tTo",
  12. "err_msg":"ori_openid error"
  13. }
  14. ]
  15. }