PHP实现企业微信 会话存档功能

想要实现企微会话存档的功能,但企微官方提供的SDK,只有C++和JAVA的版本。要使用PHP实现该功能,就要借助民间大佬的智慧。

PHP版本的SDK

  • github上的大佬 @majiameng, 实现了php会话存档SDK,下面是github地址:

https://github.com/majiameng/wework-finance-sdk-php

一、使用要求:

  • 需要用到php扩展 ext-wxwork_finance_sdk 或者 ext-ffi,二选一即可。

我这里使用的是 wxwork_finance_sdk扩展。

1.1 安装php7-wxwork-finance-sdk

扩展地址:https://github.com/pangdahua/php7-wxwork-finance-sdk

C版本SDK地址:https://wwcdn.weixin.qq.com/node/wework/images/sdk_20200401.zip

bash 复制代码
#  1.将php的SDK下载到服务器
 git clone https://github.com/pangdahua/php7-wxwork-finance-sdk.git
 # 2.下载C版本的SDK
 wget https://wwcdn.weixin.qq.com/node/wework/images/sdk_20200401.zip
 # 3.使用unzip解压zip包
 unzip sdk_20200401.zip
 # 4.进入 php7-wxwork-finance-sdk目录
 cd php7-wxwork-finance-sdk
 # 5.使用phpize进行扩展编译
 phpize # 宝塔的路径 /www/server/php/74/bin/phpize
 # 6.编译配置
 # /www/server/php/74/bin/php-config 为当前使用的php
 # /www/sdk_20200401/C_sdk 为上面下载的C版本的sdk路径
 ./configure --with-php-config=/www/server/php/74/bin/php-config --with-wxwork-finance-sdk=/www/sdk_20200401/C_sdk
 # 执行编译安装
 make && make install
  • 最终生成扩展文件路径
bash 复制代码
/www/server/php/74/lib/php/extensions/no-debug-non-zts-20190902/wxwork_finance_sdk.so

1.2 将扩展加入php配置中

bash 复制代码
[wxwork_finance_sdk]
extension=/www/server/php/74/lib/php/extensions/no-debug-non-zts-20190902/wxwork_finance_sdk.so
  • 保留后,重启php。

二、在代码中使用,使用框架:tp6

2.1 composer安装sdk代码

bash 复制代码
composer require tinymeng/wework-finance-sdk

2.2 在代码中实现

php 复制代码
<?php
namespace app\controller;

use app\BaseController;
use think\Request;

use tinymeng\WeWorkFinanceSDK\Exception\FinanceSDKException;
use tinymeng\WeWorkFinanceSDK\WxFinanceSDK;

class Session extends BaseController
{
    /**
     * 获取聊天对话记录(会话存档)
     * @param Request $request
     * @return void
     */
    public function history(Request $request)
    {
        // 企业配置
        $corpConfig = [
            'corpid'       => '企业ID',
            'secret'       => '应用密钥',
            'private_keys' => [
                1 => '-----BEGIN PRIVATE KEY-----
        -----END PRIVATE KEY-----',
            ],
            /**
             * includePath(使用php-ffi扩展时)
             * 可选 :默认使用组件内SDK(默认SDK只支持Liunx),如果想使用其他版本SDK,请填写对应SDK路径
             * 官网下载SDK https://developer.work.weixin.qq.com/document/path/91774
             */
            'includePath' => '',
        ];

        // 包配置
        $srcConfig = [
            'default' => 'php-ext',// 两种方式的切换: php-ext 或 php-ffi
        ];

        $seq = $request->param('seq', 1);
        $limit = $request->param('limit', 10);

        try {
            $wxFinanceSDK = WxFinanceSDK::init($corpConfig, $srcConfig);
            // 获取会话记录数据(解密)
            $list = $wxFinanceSDK->getDecryptChatData($seq, $limit);

            foreach ($list as $key => $item) {
                if ($wxFinanceSDK->isMedia($item['msgtype'])) {
                    // 下载媒体资源
                    $list[$key]['media_path'] = $wxFinanceSDK->getDownloadMediaData($item[$item['msgtype']], $item['msgtype']);
                }
            }
            var_dump($list);

        } catch (FinanceSDKException $exception) {
            echo $exception->getMessage();
            exit();
        }
    }


}
相关推荐
virus59454 小时前
悟空CRM mybatis-3.5.3-mapper.dtd错误解决方案
java·开发语言·mybatis
初次见面我叫泰隆5 小时前
Qt——3、常用控件
开发语言·qt·客户端
无小道6 小时前
Qt——QWidget
开发语言·qt
时艰.6 小时前
Java 并发编程之 CAS 与 Atomic 原子操作类
java·开发语言
梵刹古音6 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
梵刹古音6 小时前
【C语言】 结构化编程与选择结构
c语言·开发语言·嵌入式
Yvonne爱编码7 小时前
JAVA数据结构 DAY3-List接口
java·开发语言·windows·python
一方_self7 小时前
了解和使用python的click命令行cli工具
开发语言·python
南宫码农7 小时前
我的电视 - Android原生电视直播软件 完整使用教程
android·开发语言·windows·电视盒子
CoderCodingNo7 小时前
【GESP】C++四级/五级练习题 luogu-P1223 排队接水
开发语言·c++·算法