测试使用 tp5自定义命令 来执行以往的公众号用户存入数据库
因为之前老的程序上一个人是完全复制粘贴的另一个公众号的,数据也是,只是更换了appid和secret,完全没法用,suoyi
在app\command里添加
return [
'app\home\command\Test',
];
然后在app\home\创建一个Test.php文件
<?php
namespace app\home\command;
use think\console\Command;
use think\console\Input;
use think\console\input\Option;
use think\console\Output;
use think\Db;
use EasyWeChat\Factory;
use think\Log;
class Test extends Command
{
private $config = [
'app_id' => '你的',
'secret' => '你的',
// 指定 API 调用返回结果的类型:array(default)/collection/object/raw/自定义类名
'response_type' => 'array',
'oauth' => [
'scopes' => ['snsapi_userinfo'],
'callback' => '/api/index/callback',
],
];
protected $subscribe_scene = [
'ADD_SCENE_SEARCH' => '公众号搜索',
'ADD_SCENE_ACCOUNT_MIGRATION' => '公众号迁移',
'ADD_SCENE_PROFILE_CARD' => '名片分享',
'ADD_SCENE_QR_CODE'=>'扫描二维码',
'ADD_SCENE_PROFILE_LINK'=>'图文页内名称点击',
'ADD_SCENE_PROFILE_ITEM'=>'图文页右上角菜单',
'ADD_SCENE_PAID'=>'支付后关注',
'ADD_SCENE_WECHAT_ADVERTISEMENT'=>'微信广告',
'ADD_SCENE_REPRINT'=>'他人转载',
'ADD_SCENE_LIVESTREAM'=>'视频号直播',
'ADD_SCENE_CHANNELS'=>'视频号',
'ADD_SCENE_OTHERS'=>'其他',
];
protected function configure()
{
$this->setName('test');
}
protected function execute(Input $input, Output $output)
{
$app = Factory::officialAccount($this->config);
// 获取所有用户
$user = $app->user->list();
$useropenid[] = $user['data']['openid'];
// 使用array_chunk() 函数把一个数组分割为新的数组块。
// 因为微信一次只能获取100个用户的数据,所以一次请求100个
$useropenid_array = array_chunk($useropenid[0],100);
foreach ($useropenid_array as $key => $value){
// 批量获取用户信息
$userdetail = $app->user->select($value);
foreach ($userdetail['user_info_list'] as $k => $v){
// 改值
$v['subscribe_scene'] = $this->subscribe_scene[$v['subscribe_scene']];
$one_detil = [
"source" => 2,
"subscribestatus" => $v['subscribe'], // 0为关注,1关注,
"openid" => $v['openid'],
"nickName" => $v['nickname'], // 名称
"gender" => $v['sex'], // 性别
"city" => $v['city'], // 城市
"province" => $v['province'], // 省份
"avatarUrlimage" => $v['headimgurl'], // 头像
"subscribe_time" => $v['subscribe_time'], // 关注时间
"unionid" => $v['unionid'], // 开放平台统一uid
"remark" => $v['remark'], // 公众号运营者对粉丝的备注
"groupid" => $v['groupid'], // 用户所在的分组ID
"tagid_list" => $v['tagid_list'], // 用户被打上的标签ID列表
"subscribe_scene" => $v['subscribe_scene'], // 返回用户关注的渠道来源
"qr_scene" => $v['qr_scene'], // 二维码扫码场景(开发者自定义)
"qr_scene_str" => $v['qr_scene_str'], // 二维码扫码场景描述(开发者自定义)
];
// 创建数据
//Membermodel::create($one_detil);
}
}
}
}
线上运行测试 ,我是在宝塔运行的,所以直接在文件
打开终端,输入php think
然后再输入 php think test
就能看到输出 hello world 了
遇到的问题:
1.我配置了redis,输出的时候显示未安装redis扩展,然后就去对应的php版本安装redis扩展
2.Redis::connect(): php_network_getaddresses: getaddrinfo failed: Name or service not known
这个问题最后发现时因为没有删除putenv函数
3.项目php版本选择的7.4,但是实际使用的确实7.2版本,用php -v 查看版本, php -m 查看redis扩展是否安装