techleeone/wechat-api

wechat api for php,微信公众平台接口

v1.0.6 2018-05-08 03:11 UTC

This package is not auto-updated.

Last update: 2024-12-16 08:59:16 UTC


README

微信公众平台技术文档

安装

composer require techleeone/wechat-api

使用

// 如果是使用支持composer自动加载的框架比如thinkphplaravel),则无需require
require_once dirname(__FILE__) . '/vendor/autoload.php';

// 配置
$config = [
    'app_id' => 'wxef3bbdf4ed9439c5', // 开发者ID(AppID)
    'secret' => '7294422104de6147d818a09f5b4587fa', // 开发者密码(AppSecret)
    'token' => '598T8YDF1N1AS5FF45H4F', // 令牌(Token)
    'debug' => true, // 是否为调试模式调试模式会记录日志
];

// 获取示例
$wechat = \TechOne\WechatApi\Wechat::init($config);

响应微信发送的Token验证

此处根据来自微信的请求类型,如为GET请求,会自动验证签名

若确认此次GET请求来自微信服务器,原样返回echostr参数内容,则接入生效,否则接入失败。

$wechat->access();

接收普通消息&接收事件推送

此处根据来自微信的请求类型,如为POST请求,则自动接收来自微信的普通消息或事件推送

返回类型为:

TechOne\WechatApi\Messages\EventMessage

TechOne\WechatApi\Messages\ImageMessage

TechOne\WechatApi\Messages\LinkMessage

TechOne\WechatApi\Messages\LocationMessage

TechOne\WechatApi\Messages\ShortVideoMessage

TechOne\WechatApi\Messages\TextMessage

TechOne\WechatApi\Messages\VideoMessage

TechOne\WechatApi\Messages\VoiceMessage

$message = $wechat->access();

被动回复用户消息

回复文本消息

如果是收到的文本消息,且回复文本消息,则可在收到的消息上直接回复

回复其他类型的消息,同理。

$message = $wechat->access();   
$message->content = '我收到你发的文本消息啦';
$message->response();

如果回复的消息类型和收到的消息类型不同,则需要初始化新的消息实例

$message = $wechat->access();  
$data = [
    'ToUserName' => $message->toUserName,
    'FromUserName' => $message->fromUserName,
    'MsgType' => 'text',
    'Content' => '这是回复的内容',
];
$messageResponse = \TechOne\WechatApi\Message::load($data);
$messageResponse->response();

回复图文消息

回复图片消息

回复语音消息

回复视频消息

回复图文消息

$message = $wechat->access();  
$data = [
    'ToUserName' => $message->toUserName,
    'FromUserName' => $message->fromUserName,
    'MsgType' => 'news',
    'Articles' => [
        [
            'title' => '快速上手——我用scrapy写爬虫(一)',
            'description' => 'python的爬虫框架也很多,诸如pyspider 和 scrapy',
            'pic_url' => 'http://www.tech1024.cn/uploads/images/scrapy354.png',
            'url' => 'http://www.tech1024.cn/original/2951.html',
        ],
        [
            'title' => '保存数据到MySql数据库——我用scrapy写爬虫(二)',
            'description' => '说了如何创建项目,并爬去网站内容,下面我们说一下如何保存爬去到的数据',
            'pic_url' => 'http://www.tech1024.cn/uploads/images/scrapy354.png',
            'url' => 'http://www.tech1024.cn/original/2959.html',
        ],
        [
            'title' => 'scrapy爬取慕课网全部免费课程——我用scrapy写爬虫(三)',
            'description' => '简单用scrapy写了一个小demo,本篇文章主要目标是完整用scrapy爬取,慕课网所有免费的课程、标题、图片、地址、学习人数、难度、方向、分类、时长、评分、评论数等。',
            'pic_url' => 'http://www.tech1024.cn/uploads/images/scrapy354.png',
            'url' => 'http://www.tech1024.cn/original/2965.html',
        ],
        [
            'title' => '利用Flask和ECharts进行数据可视化——我用scrapy写爬虫(四)',
            'description' => '我们对慕课网的课程进行了爬取,本文就对数据进行统计和可视化,让这些数据更直观的展现出来。',
            'pic_url' => 'http://www.tech1024.cn/uploads/images/scrapy354.png',
            'url' => 'http://www.tech1024.cn/original/2978.html',
        ],
    ],
];
$messageResponse = \TechOne\WechatApi\Message::load($data);
$messageResponse->response();

微信网页授权

如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑。

微信网页授权

// 该接口已经实现
// 第一步用户同意授权获取code
// 第二步通过code换取网页授权access_token
// 可直接拉取用户信息
$userinfo = $wechat->oauth2()->userinfo();

菜单管理

自定义菜单创建接口

$data = [
    "button" => [
        [
            "type" => "view",
            "name" => "百度一下",
            "url"  => "https://www.baidu.com/",
        ],
        [
            "type" => "view",
            "name" => "导航",
            "url"  => "http://hao.tech1024.cn/",
        ],
        [
            "type" => "view",
            "name" => "笔记",
            "url"  => "http://www.tech1024.cn/",
        ],
    ],
];
$wechat->menu()->create($data);

自定义菜单查询接口

$wechat->menu()->get();

自定义菜单删除接口

$wechat->menu()->delete();

用户管理

获取用户列表

$nextOpenid = 'oeuHrwSsNAUXvLemeusYduRMFGE0'; // 下一个openid不传从第一个开始
$result     = $wechat->user()->get($nextOpenid);

获取用户基本信息(UnionID机制)

$openid = 'oeuHrwSsNAUXvLemeusYduRMFGE0';
$result     = $wechat->user()->info($openid);

批量获取用户基本信息

$openids = [
    ["openid" => "oeuHrwSsNAUXvLemeusYduRMFGE0", "lang" => "zh_CN"],
    ["openid" => "oeuHrwTwAOT5GN6K1oPxJXyygwUU"],
];
$result = $wechat->user()->infoBatchget($openids, 'zh_CN');

设置用户备注名

$openid = 'oeuHrwSsNAUXvLemeusYduRMFGE0';
$remark = '二傻子1'; // 备注名
$result = $wechat->user()->updateremark($openid, $remark);

用户标签管理

创建标签

$tagName = '北京'; // 标签名
$result  = $wechat->tags()->create($tagName);

获取公众号已创建的标签

$result = $wechat->tags()->get();

编辑标签

$tagId = '101'; // 标签id
$tagName = '福建'; // 要修改为的标签名
$result     = $wechat->tags()->update($tagId, $tagName);

删除标签

$tagId = '101'; // 标签id
$result     = $wechat->tags()->delete($tagId);

获取标签下粉丝列表

$tagId      = '100'; // 标签id
$nextOpenid = 'oeuHrwSsNAUXvLemeusYduRMFGE0'; // 下一个openid 不传从第一个开始
$result     = $wechat->tags()->user($tagId);
$result     = $wechat->tags()->user($tagId, $nextOpenid);

批量为用户打标签

$tagId   = '102'; // 标签id
$openids = [
    "oeuHrwSsNAUXvLemeusYduRMFGE0",
    "oeuHrwTwAOT5GN6K1oPxJXyygwUU",
]; // 要修改标签的用户的openid
$result = $wechat->tags()->batchtagging($tagId, $openids);

批量为用户取消标签

$tagId   = '102'; // 标签id
$openids = [
    "oeuHrwSsNAUXvLemeusYduRMFGE0",
    "oeuHrwTwAOT5GN6K1oPxJXyygwUU",
]; // 要取消标签的用户的openid
$result = $wechat->tags()->batchuntagging($tagId, $openids);

获取用户身上的标签列表

$openid = "oeuHrwSsNAUXvLemeusYduRMFGE0";
$result = $wechat->tags()->idlist($openid);