TP5 封装通用的微信服务类

1、安装依赖包

我们这里用的是 EasyWeChat

EasyWeCha官网 https://www.easywechat.com/
安装地址 https://github.com/easywechat/docs
相关文档 https://www.easywechat.com/docs/4.1/payment/index

  • composer安装
$ composer require overtrue/wechat:~4.0 -vvv

1、封装服务类

<?php

namespace app\common\service;
use EasyWeChat\Factory;
use EasyWeChat\MiniProgram\Application;
use think\Hook;

/**
 * 微信服务
 * @package app\common\service
 */
class WeChatService
{

    //微信公众号配置
    private $officeConfig = [
        'app_id' => 'wx727ac3b3f4439a25',
        'secret' => '23471aaeb7d0ab3679da9f9a7d58bb25',
        // 指定 API 调用返回结果的类型:array(default)/collection/object/raw/自定义类名
        'response_type' => 'array',
        //...
    ];

    //微信支付
    private $payConfig = [
        // 必要配置
        'app_id' => 'xxxx',
        'mch_id' => 'your-mch-id',
        'key' => 'key-for-signature',   // API 密钥

        // 如需使用敏感接口(如退款、发送红包等)需要配置 API 证书路径(登录商户平台下载 API 证书)
        'cert_path' => 'path/to/your/cert.pem', // XXX: 绝对路径!!!!
        'key_path' => 'path/to/your/key',      // XXX: 绝对路径!!!!

        'notify_url' => '默认的订单回调地址',     // 你也可以在下单时单独设置来想覆盖它
    ];

    //微信小程序配置
    private $miniConfig = [
        'app_id' => 'wx3cf0f39249eb0exx',
        'secret' => 'f1c242f4f28f735d4687abb469072axx',

        // 下面为可选项
        // 指定 API 调用返回结果的类型:array(default)/collection/object/raw/自定义类名
        'response_type' => 'array',

        'log' => [
            'level' => 'debug',
            'file' => PUBLIC_PATH . '/logs/wechat.log',
        ],
    ];

    //开放平台配置
    private $openConfig = [
        'app_id' => '开放平台第三方平台 APPID',
        'secret' => '开放平台第三方平台 Secret',
        'token' => '开放平台第三方平台 Token',
        'aes_key' => '开放平台第三方平台 AES Key'
    ];

    private $token = ''; //获取小程序的ACCESS_TOKEN
    private $isContract = false; //是否开启支付中签约

    /**
     * @ApiTitle    (实例化)
     * @param int $type
     * @return bool|Application|\EasyWeChat\OfficialAccount\Application|\EasyWeChat\OpenPlatform\Application|\EasyWeChat\Payment\Application
     * @throws \EasyWeChat\Kernel\Exceptions\HttpException
     * @throws \EasyWeChat\Kernel\Exceptions\InvalidArgumentException
     * @throws \EasyWeChat\Kernel\Exceptions\InvalidConfigException
     * @throws \EasyWeChat\Kernel\Exceptions\RuntimeException
     * @throws \Psr\SimpleCache\InvalidArgumentException
     */
    public function connect($type = 0)
    {
        //实例化对象
        if ($type == 0) $app = Factory::miniProgram($this->miniConfig); //微信小程序
        if ($type == 1) $app = Factory::officialAccount($this->officeConfig); //微信公众号
        if ($type == 2) $app = Factory::payment($this->payConfig); //微信支付
        if ($type == 3) $app = Factory::openPlatform($this->payConfig); //微信开放平台

        //获取token
        $accessToken = $app->access_token;
        $this->token = $accessToken->getToken()['access_token']; // token 数组  token['access_token'] 字符串

        return $app ?? false;
    }

    /**
     * @ApiTitle    (生成小程序二维码)
     * @return bool|int
     * @throws \EasyWeChat\Kernel\Exceptions\HttpException
     * @throws \EasyWeChat\Kernel\Exceptions\InvalidArgumentException
     * @throws \EasyWeChat\Kernel\Exceptions\InvalidConfigException
     * @throws \EasyWeChat\Kernel\Exceptions\RuntimeException
     * @throws \Psr\SimpleCache\InvalidArgumentException
     */
    public function createCode()
    {
        $app = $this->connect(0);

        $response = $app->app_code->getUnlimit('scene-value', [
            'page' => 'path/to/page',
            'width' => 600,
        ]);

        if ($response instanceof \EasyWeChat\Kernel\Http\StreamResponse) {
            $dir = 'qrCode/' . date('Ymd', time()) . '/';
            if (!file_exists($dir)) mkdir($dir, 0777, true);
            $url = PUBLIC_PATH . $dir . 'app_mini_code.png';
            $response->save($url);

            //保存到OSS
            $urlOss = Hook::listen("upload_oss", $url, null, true);

            //删除本地图片和文件夹
            if (file_exists($url)) {
                unlink($url);
                rmdir($dir);
            }
        }
        return $urlOss ?? false;
    }

}

其中微信小程序、公众号、微信支付和开放平台等配置都在这里面写,如果需要企业微信等配置自行根据自己的业务修改里面的代码即可。

3、调用服务类

  • 我们只要 new 一个服务类就可以使用里面的方法了
public function createWeChatCode()
{
    $code = (new WeChatService)->createCode();
    $this->success('生成小程序码成功', $code);
}
  • 调用 EasyWeChat 包的方法,只需要 connect 一下就可以了,其中需要传参
$app = (new WeChatService())->connect(1);

感谢你的观看,如果有什么问题欢迎在留言区留言。

最后编辑于:2020-05-08 15:54


喜欢的朋友记得点赞、收藏、关注哦!!!

相关推荐

  1. 小程序个人开放服务目表

    2024-07-12 21:38:04       28 阅读
  2. 套接字通信封装

    2024-07-12 21:38:04       53 阅读
  3. 小程序封装网络请求设置超时5min不生效

    2024-07-12 21:38:04       55 阅读
  4. Taro@3.x+Vue@3.x+TS开发小程序,网络请求封装

    2024-07-12 21:38:04       39 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-12 21:38:04       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-12 21:38:04       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-12 21:38:04       57 阅读
  4. Python语言-面向对象

    2024-07-12 21:38:04       68 阅读

热门阅读

  1. 二叉树专题刷题

    2024-07-12 21:38:04       22 阅读
  2. 【Leetcode 每日一题】349. 两个数组的交集

    2024-07-12 21:38:04       23 阅读
  3. 力扣题解(环绕字符串中唯一的子字符串)

    2024-07-12 21:38:04       16 阅读
  4. python连接kafka生产者发送消息

    2024-07-12 21:38:04       19 阅读
  5. 链路追踪详解(六):Zipkin 和 Jaeger 的安装方法

    2024-07-12 21:38:04       18 阅读
  6. 进制-奇怪的捐赠c++

    2024-07-12 21:38:04       19 阅读
  7. flutter 使用wechat_assets_picker的权限检测

    2024-07-12 21:38:04       16 阅读
  8. Sqlmap中文使用手册 - Request模块参数使用

    2024-07-12 21:38:04       16 阅读
  9. pdf文件如何快速英文转中文?

    2024-07-12 21:38:04       20 阅读
  10. Windows图形界面(GUI)-SDK-C/C++ - 编辑框(edit)

    2024-07-12 21:38:04       23 阅读
  11. 小红书后端

    2024-07-12 21:38:04       16 阅读