diff --git a/vendor/autoload.php b/vendor/autoload.php index 3f96b928d..b55f6870e 100644 --- a/vendor/autoload.php +++ b/vendor/autoload.php @@ -4,4 +4,4 @@ require_once __DIR__ . '/composer/autoload_real.php'; -return ComposerAutoloaderInite0d2dad2bed8969160696ec97729e10a::getLoader(); +return ComposerAutoloaderInit6588b91efff19d88b158b1c18209b5f4::getLoader(); diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php index d9068a5ae..9c54c0fb4 100644 --- a/vendor/composer/autoload_classmap.php +++ b/vendor/composer/autoload_classmap.php @@ -114,7 +114,9 @@ return array( 'Symfony\\Component\\OptionsResolver\\Exception\\UndefinedOptionsException' => $vendorDir . '/symfony/options-resolver/Exception/UndefinedOptionsException.php', 'Symfony\\Component\\OptionsResolver\\Options' => $vendorDir . '/symfony/options-resolver/Options.php', 'Symfony\\Component\\OptionsResolver\\OptionsResolver' => $vendorDir . '/symfony/options-resolver/OptionsResolver.php', + 'We' => $vendorDir . '/zoujingli/wechat-developer/We.php', 'WeChat\\Card' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Card.php', + 'WeChat\\Contracts\\BasicPay' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicPay.php', 'WeChat\\Contracts\\BasicPushEvent' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicPushEvent.php', 'WeChat\\Contracts\\BasicWeChat' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWeChat.php', 'WeChat\\Contracts\\DataArray' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Contracts/DataArray.php', @@ -123,6 +125,7 @@ return array( 'WeChat\\Custom' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Custom.php', 'WeChat\\Exceptions\\InvalidArgumentException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidArgumentException.php', 'WeChat\\Exceptions\\InvalidDecryptException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidDecryptException.php', + 'WeChat\\Exceptions\\InvalidInstanceException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidInstanceException.php', 'WeChat\\Exceptions\\InvalidResponseException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidResponseException.php', 'WeChat\\Exceptions\\LocalCacheException' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Exceptions/LocalCacheException.php', 'WeChat\\Limit' => $vendorDir . '/zoujingli/wechat-developer/WeChat/Limit.php', @@ -156,6 +159,13 @@ return array( 'WeOpen\\Login' => $vendorDir . '/zoujingli/weopen-developer/WeOpen/Login.php', 'WeOpen\\MiniApp' => $vendorDir . '/zoujingli/weopen-developer/WeOpen/MiniApp.php', 'WeOpen\\Service' => $vendorDir . '/zoujingli/weopen-developer/WeOpen/Service.php', + 'WePay\\Bill' => $vendorDir . '/zoujingli/wechat-developer/WePay/Bill.php', + 'WePay\\Coupon' => $vendorDir . '/zoujingli/wechat-developer/WePay/Coupon.php', + 'WePay\\Order' => $vendorDir . '/zoujingli/wechat-developer/WePay/Order.php', + 'WePay\\Redpack' => $vendorDir . '/zoujingli/wechat-developer/WePay/Redpack.php', + 'WePay\\Refund' => $vendorDir . '/zoujingli/wechat-developer/WePay/Refund.php', + 'WePay\\TransFresBank' => $vendorDir . '/zoujingli/wechat-developer/WePay/TransFresBank.php', + 'WePay\\Transfers' => $vendorDir . '/zoujingli/wechat-developer/WePay/Transfers.php', 'app\\admin\\controller\\Auth' => $baseDir . '/application/admin/controller/Auth.php', 'app\\admin\\controller\\Config' => $baseDir . '/application/admin/controller/Config.php', 'app\\admin\\controller\\Index' => $baseDir . '/application/admin/controller/Index.php', diff --git a/vendor/composer/autoload_psr4.php b/vendor/composer/autoload_psr4.php index 0e306a2ed..bcbe296cb 100644 --- a/vendor/composer/autoload_psr4.php +++ b/vendor/composer/autoload_psr4.php @@ -9,6 +9,7 @@ return array( 'think\\composer\\' => array($vendorDir . '/topthink/think-installer/src'), 'think\\captcha\\' => array($vendorDir . '/topthink/think-captcha/src'), 'app\\' => array($baseDir . '/application'), + 'WePay\\' => array($vendorDir . '/zoujingli/wechat-developer/WePay'), 'WeOpen\\' => array($vendorDir . '/zoujingli/weopen-developer/WeOpen'), 'WeMini\\' => array($vendorDir . '/zoujingli/wechat-developer/WeMini', $vendorDir . '/zoujingli/weopen-developer/WeMini'), 'WeChat\\' => array($vendorDir . '/zoujingli/wechat-developer/WeChat', $vendorDir . '/zoujingli/weopen-developer/WeChat'), diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php index fd304d286..26e797b24 100644 --- a/vendor/composer/autoload_real.php +++ b/vendor/composer/autoload_real.php @@ -2,7 +2,7 @@ // autoload_real.php @generated by Composer -class ComposerAutoloaderInite0d2dad2bed8969160696ec97729e10a +class ComposerAutoloaderInit6588b91efff19d88b158b1c18209b5f4 { private static $loader; @@ -19,15 +19,15 @@ class ComposerAutoloaderInite0d2dad2bed8969160696ec97729e10a return self::$loader; } - spl_autoload_register(array('ComposerAutoloaderInite0d2dad2bed8969160696ec97729e10a', 'loadClassLoader'), true, true); + spl_autoload_register(array('ComposerAutoloaderInit6588b91efff19d88b158b1c18209b5f4', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(); - spl_autoload_unregister(array('ComposerAutoloaderInite0d2dad2bed8969160696ec97729e10a', 'loadClassLoader')); + spl_autoload_unregister(array('ComposerAutoloaderInit6588b91efff19d88b158b1c18209b5f4', 'loadClassLoader')); $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded()); if ($useStaticLoader) { require_once __DIR__ . '/autoload_static.php'; - call_user_func(\Composer\Autoload\ComposerStaticInite0d2dad2bed8969160696ec97729e10a::getInitializer($loader)); + call_user_func(\Composer\Autoload\ComposerStaticInit6588b91efff19d88b158b1c18209b5f4::getInitializer($loader)); } else { $map = require __DIR__ . '/autoload_namespaces.php'; foreach ($map as $namespace => $path) { @@ -48,19 +48,19 @@ class ComposerAutoloaderInite0d2dad2bed8969160696ec97729e10a $loader->register(true); if ($useStaticLoader) { - $includeFiles = Composer\Autoload\ComposerStaticInite0d2dad2bed8969160696ec97729e10a::$files; + $includeFiles = Composer\Autoload\ComposerStaticInit6588b91efff19d88b158b1c18209b5f4::$files; } else { $includeFiles = require __DIR__ . '/autoload_files.php'; } foreach ($includeFiles as $fileIdentifier => $file) { - composerRequiree0d2dad2bed8969160696ec97729e10a($fileIdentifier, $file); + composerRequire6588b91efff19d88b158b1c18209b5f4($fileIdentifier, $file); } return $loader; } } -function composerRequiree0d2dad2bed8969160696ec97729e10a($fileIdentifier, $file) +function composerRequire6588b91efff19d88b158b1c18209b5f4($fileIdentifier, $file) { if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { require $file; diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php index 7416311ff..d307742be 100644 --- a/vendor/composer/autoload_static.php +++ b/vendor/composer/autoload_static.php @@ -4,7 +4,7 @@ namespace Composer\Autoload; -class ComposerStaticInite0d2dad2bed8969160696ec97729e10a +class ComposerStaticInit6588b91efff19d88b158b1c18209b5f4 { public static $files = array ( '1cfd2761b63b0a29ed23657ea394cb2d' => __DIR__ . '/..' . '/topthink/think-captcha/src/helper.php', @@ -23,6 +23,7 @@ class ComposerStaticInite0d2dad2bed8969160696ec97729e10a ), 'W' => array ( + 'WePay\\' => 6, 'WeOpen\\' => 7, 'WeMini\\' => 7, 'WeChat\\' => 7, @@ -58,6 +59,10 @@ class ComposerStaticInite0d2dad2bed8969160696ec97729e10a array ( 0 => __DIR__ . '/../..' . '/application', ), + 'WePay\\' => + array ( + 0 => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay', + ), 'WeOpen\\' => array ( 0 => __DIR__ . '/..' . '/zoujingli/weopen-developer/WeOpen', @@ -199,7 +204,9 @@ class ComposerStaticInite0d2dad2bed8969160696ec97729e10a 'Symfony\\Component\\OptionsResolver\\Exception\\UndefinedOptionsException' => __DIR__ . '/..' . '/symfony/options-resolver/Exception/UndefinedOptionsException.php', 'Symfony\\Component\\OptionsResolver\\Options' => __DIR__ . '/..' . '/symfony/options-resolver/Options.php', 'Symfony\\Component\\OptionsResolver\\OptionsResolver' => __DIR__ . '/..' . '/symfony/options-resolver/OptionsResolver.php', + 'We' => __DIR__ . '/..' . '/zoujingli/wechat-developer/We.php', 'WeChat\\Card' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Card.php', + 'WeChat\\Contracts\\BasicPay' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicPay.php', 'WeChat\\Contracts\\BasicPushEvent' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicPushEvent.php', 'WeChat\\Contracts\\BasicWeChat' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/BasicWeChat.php', 'WeChat\\Contracts\\DataArray' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Contracts/DataArray.php', @@ -208,6 +215,7 @@ class ComposerStaticInite0d2dad2bed8969160696ec97729e10a 'WeChat\\Custom' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Custom.php', 'WeChat\\Exceptions\\InvalidArgumentException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidArgumentException.php', 'WeChat\\Exceptions\\InvalidDecryptException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidDecryptException.php', + 'WeChat\\Exceptions\\InvalidInstanceException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidInstanceException.php', 'WeChat\\Exceptions\\InvalidResponseException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/InvalidResponseException.php', 'WeChat\\Exceptions\\LocalCacheException' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Exceptions/LocalCacheException.php', 'WeChat\\Limit' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WeChat/Limit.php', @@ -241,6 +249,13 @@ class ComposerStaticInite0d2dad2bed8969160696ec97729e10a 'WeOpen\\Login' => __DIR__ . '/..' . '/zoujingli/weopen-developer/WeOpen/Login.php', 'WeOpen\\MiniApp' => __DIR__ . '/..' . '/zoujingli/weopen-developer/WeOpen/MiniApp.php', 'WeOpen\\Service' => __DIR__ . '/..' . '/zoujingli/weopen-developer/WeOpen/Service.php', + 'WePay\\Bill' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Bill.php', + 'WePay\\Coupon' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Coupon.php', + 'WePay\\Order' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Order.php', + 'WePay\\Redpack' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Redpack.php', + 'WePay\\Refund' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Refund.php', + 'WePay\\TransFresBank' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/TransFresBank.php', + 'WePay\\Transfers' => __DIR__ . '/..' . '/zoujingli/wechat-developer/WePay/Transfers.php', 'app\\admin\\controller\\Auth' => __DIR__ . '/../..' . '/application/admin/controller/Auth.php', 'app\\admin\\controller\\Config' => __DIR__ . '/../..' . '/application/admin/controller/Config.php', 'app\\admin\\controller\\Index' => __DIR__ . '/../..' . '/application/admin/controller/Index.php', @@ -287,9 +302,9 @@ class ComposerStaticInite0d2dad2bed8969160696ec97729e10a public static function getInitializer(ClassLoader $loader) { return \Closure::bind(function () use ($loader) { - $loader->prefixLengthsPsr4 = ComposerStaticInite0d2dad2bed8969160696ec97729e10a::$prefixLengthsPsr4; - $loader->prefixDirsPsr4 = ComposerStaticInite0d2dad2bed8969160696ec97729e10a::$prefixDirsPsr4; - $loader->classMap = ComposerStaticInite0d2dad2bed8969160696ec97729e10a::$classMap; + $loader->prefixLengthsPsr4 = ComposerStaticInit6588b91efff19d88b158b1c18209b5f4::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInit6588b91efff19d88b158b1c18209b5f4::$prefixDirsPsr4; + $loader->classMap = ComposerStaticInit6588b91efff19d88b158b1c18209b5f4::$classMap; }, null, ClassLoader::class); } diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json index 5c73d4bdd..a49520792 100644 --- a/vendor/composer/installed.json +++ b/vendor/composer/installed.json @@ -80,17 +80,17 @@ }, { "name": "zoujingli/wechat-developer", - "version": "v1.1.7", - "version_normalized": "1.1.7.0", + "version": "v1.1.9", + "version_normalized": "1.1.9.0", "source": { "type": "git", "url": "https://github.com/zoujingli/WeChatDeveloper.git", - "reference": "f01ac5dafc85cb408fd3e0bafc462437785ae178" + "reference": "26419890645299e1850c648ed620f23069949271" }, "dist": { "type": "zip", - "url": "https://files.phpcomposer.com/files/zoujingli/WeChatDeveloper/f01ac5dafc85cb408fd3e0bafc462437785ae178.zip", - "reference": "f01ac5dafc85cb408fd3e0bafc462437785ae178", + "url": "https://files.phpcomposer.com/files/zoujingli/WeChatDeveloper/26419890645299e1850c648ed620f23069949271.zip", + "reference": "26419890645299e1850c648ed620f23069949271", "shasum": "" }, "require": { @@ -98,11 +98,15 @@ "ext-openssl": "*", "php": ">=5.4" }, - "time": "2018-05-16T05:48:16+00:00", + "time": "2018-05-25T02:47:12+00:00", "type": "library", "installation-source": "dist", "autoload": { + "classmap": [ + "We.php" + ], "psr-4": { + "WePay\\": "WePay", "WeChat\\": "WeChat", "WeMini\\": "WeMini" } @@ -122,8 +126,10 @@ "homepage": "https://github.com/zoujingli/WeChatDeveloper", "keywords": [ "WeChatDeveloper", + "WeMini", "wechat", - "wechatpay" + "wechatpay", + "wepay" ] }, { diff --git a/vendor/zoujingli/wechat-developer/.gitignore b/vendor/zoujingli/wechat-developer/.gitignore index 1d2b80a0d..d13044caf 100644 --- a/vendor/zoujingli/wechat-developer/.gitignore +++ b/vendor/zoujingli/wechat-developer/.gitignore @@ -1,6 +1,7 @@ -/.idea /.git +/.idea /.DS_Store /vendor /Cache /Test/cert +/composer.lock diff --git a/vendor/zoujingli/wechat-developer/Test/mini-qrc.php b/vendor/zoujingli/wechat-developer/Test/mini-qrc.php index f636610e8..ce62ae101 100644 --- a/vendor/zoujingli/wechat-developer/Test/mini-qrc.php +++ b/vendor/zoujingli/wechat-developer/Test/mini-qrc.php @@ -8,7 +8,11 @@ $config = [ 'appsecret' => '78b7b8d65bd67b078babf951d4342b42', ]; -$mini = new WeMini\Qrcode($config); +//We::config($config); + +$mini = We::WeMiniQrcode($config); + +//$mini = new WeMini\Qrcode($config); //echo '
';
 try {
diff --git a/vendor/zoujingli/wechat-developer/We.php b/vendor/zoujingli/wechat-developer/We.php
new file mode 100644
index 000000000..9b982cb2d
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/We.php
@@ -0,0 +1,110 @@
+
+ * @date 2018/05/24 13:23
+ *
+ * ----- WeChat -----
+ * @method \WeChat\Card WeChatCard($options = []) static 微信卡券管理
+ * @method \WeChat\Custom WeChatCustom($options = []) static 微信客服消息
+ * @method \WeChat\Limit WeChatLimit($options = []) static 接口调用频次限制
+ * @method \WeChat\Media WeChatMedia($options = []) static 微信素材管理
+ * @method \WeChat\Menu WeChatMenu($options = []) static 微信菜单管理
+ * @method \WeChat\Oauth WeChatOauth($options = []) static 微信网页授权
+ * @method \WeChat\Pay WeChatPay($options = []) static 微信支付商户
+ * @method \WeChat\Product WeChatProduct($options = []) static 微信商店管理
+ * @method \WeChat\Qrcode WeChatQrcode($options = []) static 微信二维码管理
+ * @method \WeChat\Receive WeChatReceive($options = []) static 微信推送管理
+ * @method \WeChat\Scan WeChatScan($options = []) static 微信扫一扫接入管理
+ * @method \WeChat\Script WeChatScript($options = []) static 微信前端支持
+ * @method \WeChat\Shake WeChatShake($options = []) static 微信揺一揺周边
+ * @method \WeChat\Tags WeChatTags($options = []) static 微信用户标签管理
+ * @method \WeChat\Template WeChatTemplate($options = []) static 微信模板消息
+ * @method \WeChat\User WeChatUser($options = []) static 微信粉丝管理
+ * @method \WeChat\Wifi WeChatWifi($options = []) static 微信门店WIFI管理
+ *
+ * ----- WeMini -----
+ * @method \WeMini\Crypt WeMiniCrypt($options = []) static 小程序数据加密处理
+ * @method \WeMini\Plugs WeMiniPlugs($options = []) static 小程序插件管理
+ * @method \WeMini\Poi WeMiniPoi($options = []) static 小程序地址管理
+ * @method \WeMini\Qrcode WeMiniQrcode($options = []) static 小程序二维码管理
+ * @method \WeMini\Template WeMiniTemplate($options = []) static 小程序模板消息支持
+ * @method \WeMini\Total WeMiniTotal($options = []) static 小程序数据接口
+ *
+ * ----- WePay -----
+ * @method \WePay\Bill WePayBill($options = []) static 微信商户账单及评论
+ * @method \WePay\Order WePayOrder($options = []) static 微信商户订单
+ * @method \WePay\Refund WePayRefund($options = []) static 微信商户退款
+ * @method \WePay\Coupon WePayCoupon($options = []) static 微信商户代金券
+ * @method \WePay\Redpack WePayRedpack($options = []) static 微信红包支持
+ * @method \WePay\Transfers WePayTransfers($options = []) static 微信商户打款到零钱
+ * @method \WePay\TransFresBank WePayTransFresBank($options = []) static 微信商户打款到银行卡
+ */
+class We
+{
+    /**
+     * 静态配置
+     * @var array
+     */
+    private static $config;
+
+    /**
+     * 设置及获取参数
+     * @param array $option
+     * @return array
+     */
+    public static function config($option = null)
+    {
+        if (is_array($option)) {
+            self::$config = new DataArray($option);
+        }
+        if (self::$config instanceof DataArray) {
+            return self::$config->get();
+        }
+        return [];
+    }
+
+    /**
+     * 静态魔术加载方法
+     * @param string $name 静态类名
+     * @param array $arguments 参数集合
+     * @return mixed
+     * @throws InvalidInstanceException
+     */
+    public static function __callStatic($name, $arguments)
+    {
+        if (substr($name, 0, 6) === 'WeChat') {
+            $class = 'WeChat\\' . substr($name, 6);
+        } elseif (substr($name, 0, 6) === 'WeMini') {
+            $class = 'WeMini\\' . substr($name, 6);
+        } elseif (substr($name, 0, 5) === 'WePay') {
+            $class = 'WePay\\' . substr($name, 5);
+        }
+        if (!empty($class) && class_exists($class)) {
+            $option = array_pop($arguments);
+            $config = is_array($option) ? $option : self::$config->get();
+            return new $class($config);
+        }
+        throw new InvalidInstanceException("class {$name} not found");
+    }
+
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WeChat/Contracts/BasicPay.php b/vendor/zoujingli/wechat-developer/WeChat/Contracts/BasicPay.php
new file mode 100644
index 000000000..8de0a1118
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WeChat/Contracts/BasicPay.php
@@ -0,0 +1,153 @@
+config = new DataArray($options);
+        // 商户基础参数
+        $this->params = new DataArray([
+            'appid'     => $this->config->get('appid'),
+            'mch_id'    => $this->config->get('mch_id'),
+            'nonce_str' => Tools::createNoncestr(),
+        ]);
+        // 商户参数支持
+        if ($this->config->get('sub_appid')) {
+            $this->params->set('sub_appid', $this->config->get('sub_appid'));
+        }
+        if ($this->config->get('sub_mch_id')) {
+            $this->params->set('sub_mch_id', $this->config->get('sub_mch_id'));
+        }
+    }
+
+    /**
+     * 获取微信支付通知
+     * @return array
+     * @throws InvalidResponseException
+     */
+    public function getNotify()
+    {
+        $data = Tools::xml2arr(file_get_contents('php://input'));
+        if (!empty($data['sign'])) {
+            if ($this->getPaySign($data) === $data['sign']) {
+                return $data;
+            }
+        }
+        throw new InvalidResponseException('Invalid Notify.', '0');
+    }
+
+    /**
+     * 生成支付签名
+     * @param array $data 参与签名的数据
+     * @param string $signType 参与签名的类型
+     * @param string $buff 参与签名字符串前缀
+     * @return string
+     */
+    public function getPaySign(array $data, $signType = 'MD5', $buff = '')
+    {
+        unset($data['sign']);
+        ksort($data);
+        foreach ($data as $k => $v) {
+            $buff .= "{$k}={$v}&";
+        }
+        $buff .= ("key=" . $this->config->get('mch_key'));
+        if (strtoupper($signType) === 'MD5') {
+            return strtoupper(md5($buff));
+        }
+        return strtoupper(hash_hmac('SHA256', $buff, $this->config->get('mch_key')));
+    }
+
+    /**
+     * 转换短链接
+     * @param string $longUrl 需要转换的URL,签名用原串,传输需URLencode
+     * @return array
+     * @throws InvalidResponseException
+     */
+    public function shortUrl($longUrl)
+    {
+        $url = 'https://api.mch.weixin.qq.com/tools/shorturl';
+        return $this->callPostApi($url, ['long_url' => $longUrl]);
+    }
+
+    /**
+     * 以Post请求接口
+     * @param string $url 请求
+     * @param array $data 接口参数
+     * @param bool $isCert 是否需要使用双向证书
+     * @param string $signType 数据签名类型 MD5|SHA256
+     * @param bool $needSignType 是否需要传签名类型参数
+     * @return array
+     * @throws InvalidResponseException
+     */
+    protected function callPostApi($url, array $data, $isCert = false, $signType = 'HMAC-SHA256', $needSignType = true)
+    {
+        $option = [];
+        if ($isCert) {
+            $option['ssl_cer'] = $this->config->get('ssl_cer');
+            $option['ssl_key'] = $this->config->get('ssl_key');
+            if (empty($option['ssl_cer']) || !file_exists($option['ssl_cer']))
+                throw new InvalidArgumentException("Missing Config -- ssl_cer", '0');
+            if (empty($option['ssl_key']) || !file_exists($option['ssl_key']))
+                throw new InvalidArgumentException("Missing Config -- ssl_key", '0');
+        }
+        $params = $this->params->merge($data);
+        $needSignType && ($params['sign_type'] = strtoupper($signType));
+        $params['sign'] = $this->getPaySign($params, $signType);
+        $result = Tools::xml2arr(Tools::post($url, Tools::arr2xml($params), $option));
+        if ($result['return_code'] !== 'SUCCESS') {
+            throw new InvalidResponseException($result['return_msg'], '0');
+        }
+        return $result;
+    }
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WeChat/Exceptions/InvalidInstanceException.php b/vendor/zoujingli/wechat-developer/WeChat/Exceptions/InvalidInstanceException.php
new file mode 100644
index 000000000..e4c6816f8
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WeChat/Exceptions/InvalidInstanceException.php
@@ -0,0 +1,40 @@
+raw = $raw;
+    }
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WeChat/Oauth.php b/vendor/zoujingli/wechat-developer/WeChat/Oauth.php
index 6ee8fc892..151a4eed7 100644
--- a/vendor/zoujingli/wechat-developer/WeChat/Oauth.php
+++ b/vendor/zoujingli/wechat-developer/WeChat/Oauth.php
@@ -41,6 +41,7 @@ class Oauth extends BasicWeChat
     /**
      * 通过 code 获取 AccessToken 和 openid
      * @return bool|array
+     * @throws Exceptions\InvalidResponseException
      */
     public function getOauthAccessToken()
     {
@@ -55,6 +56,7 @@ class Oauth extends BasicWeChat
      * 刷新AccessToken并续期
      * @param string $refresh_token
      * @return bool|array
+     * @throws Exceptions\InvalidResponseException
      */
     public function getOauthRefreshToken($refresh_token)
     {
@@ -68,6 +70,7 @@ class Oauth extends BasicWeChat
      * @param string $access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
      * @param string $openid 用户的唯一标识
      * @return array
+     * @throws Exceptions\InvalidResponseException
      */
     public function checkOauthAccessToken($access_token, $openid)
     {
@@ -81,6 +84,7 @@ class Oauth extends BasicWeChat
      * @param string $openid 用户的唯一标识
      * @param string $lang 返回国家地区语言版本,zh_CN 简体,zh_TW 繁体,en 英语
      * @return array
+     * @throws Exceptions\InvalidResponseException
      */
     public function getUserInfo($access_token, $openid, $lang = 'zh_CN')
     {
diff --git a/vendor/zoujingli/wechat-developer/WeChat/Pay.php b/vendor/zoujingli/wechat-developer/WeChat/Pay.php
index 3f40508be..d3e5f6e89 100644
--- a/vendor/zoujingli/wechat-developer/WeChat/Pay.php
+++ b/vendor/zoujingli/wechat-developer/WeChat/Pay.php
@@ -14,59 +14,22 @@
 
 namespace WeChat;
 
-use WeChat\Contracts\DataArray;
-use WeChat\Contracts\Tools;
-use WeChat\Exceptions\InvalidArgumentException;
-use WeChat\Exceptions\InvalidDecryptException;
+use WeChat\Contracts\BasicPay;
 use WeChat\Exceptions\InvalidResponseException;
+use WePay\Bill;
+use WePay\Order;
+use WePay\Refund;
+use WePay\Transfers;
+use WePay\TransFresBank;
 
 /**
  * 微信支付商户
  * Class Pay
  * @package WeChat\Contracts
  */
-class Pay
+class Pay extends BasicPay
 {
 
-    /**
-     * 商户配置
-     * @var DataArray
-     */
-    protected $config;
-
-    /**
-     * 当前请求数据
-     * @var DataArray
-     */
-    protected $params;
-
-
-    /**
-     * WeChat constructor.
-     * @param array $options
-     */
-    public function __construct(array $options)
-    {
-        if (empty($options['appid'])) {
-            throw new InvalidArgumentException("Missing Config -- [appid]");
-        }
-        if (empty($options['mch_id'])) {
-            throw new InvalidArgumentException("Missing Config -- [mch_id]");
-        }
-        if (empty($options['mch_key'])) {
-            throw new InvalidArgumentException("Missing Config -- [mch_key]");
-        }
-        if (!empty($options['cache_path'])) {
-            Tools::$cache_path = $options['cache_path'];
-        }
-        $this->config = new DataArray($options);
-        $this->params = new DataArray([
-            'appid'     => $this->config->get('appid'),
-            'mch_id'    => $this->config->get('mch_id'),
-            'nonce_str' => Tools::createNoncestr(),
-        ]);
-    }
-
     /**
      * 统一下单
      * @param array $options
@@ -75,8 +38,8 @@ class Pay
      */
     public function createOrder(array $options)
     {
-        $url = 'https://api.mch.weixin.qq.com/pay/unifiedorder';
-        return $this->callPostApi($url, $options, false, 'MD5');
+        $pay = new Order($this->config->get());
+        return $pay->create($options);
     }
 
 
@@ -87,15 +50,8 @@ class Pay
      */
     public function createParamsForJsApi($prepay_id)
     {
-        $option = [];
-        $option["appId"] = $this->config->get('appid');
-        $option["timeStamp"] = (string)time();
-        $option["nonceStr"] = Tools::createNoncestr();
-        $option["package"] = "prepay_id={$prepay_id}";
-        $option["signType"] = "MD5";
-        $option["paySign"] = $this->getPaySign($option, 'MD5');
-        $option['timestamp'] = $option['timeStamp'];
-        return $option;
+        $pay = new Order($this->config->get());
+        return $pay->jsapiParams($prepay_id);
     }
 
     /**
@@ -105,15 +61,8 @@ class Pay
      */
     public function createParamsForRuleQrc($product_id)
     {
-        $data = [
-            'appid'      => $this->config->get('appid'),
-            'mch_id'     => $this->config->get('mch_id'),
-            'time_stamp' => (string)time(),
-            'nonce_str'  => Tools::createNoncestr(),
-            'product_id' => (string)$product_id,
-        ];
-        $data['sign'] = $this->getPaySign($data, 'MD5');
-        return "weixin://wxpay/bizpayurl?" . http_build_query($data);
+        $pay = new Order($this->config->get());
+        return $pay->qrcParams($product_id);
     }
 
     /**
@@ -124,8 +73,8 @@ class Pay
      */
     public function queryOrder(array $options)
     {
-        $url = 'https://api.mch.weixin.qq.com/pay/orderquery';
-        return $this->callPostApi($url, $options);
+        $pay = new Order($this->config->get());
+        return $pay->query($options);
     }
 
     /**
@@ -136,8 +85,8 @@ class Pay
      */
     public function closeOrder($out_trade_no)
     {
-        $url = 'https://api.mch.weixin.qq.com/pay/closeorder';
-        return $this->callPostApi($url, ['out_trade_no' => $out_trade_no]);
+        $pay = new Order($this->config->get());
+        return $pay->close($out_trade_no);
     }
 
     /**
@@ -148,8 +97,8 @@ class Pay
      */
     public function createRefund(array $options)
     {
-        $url = 'https://api.mch.weixin.qq.com/secapi/pay/refund';
-        return $this->callPostApi($url, $options, true);
+        $pay = new Refund($this->config->get());
+        return $pay->create($options);
     }
 
     /**
@@ -160,8 +109,8 @@ class Pay
      */
     public function queryRefund(array $options)
     {
-        $url = 'https://api.mch.weixin.qq.com/pay/refundquery';
-        return $this->callPostApi($url, $options);
+        $pay = new Refund($this->config->get());
+        return $pay->query($options);
     }
 
     /**
@@ -172,8 +121,8 @@ class Pay
      */
     public function report(array $options)
     {
-        $url = 'https://api.mch.weixin.qq.com/payitil/report';
-        return $this->callPostApi($url, $options);
+        $pay = new Order($this->config->get());
+        return $pay->report($options);
     }
 
     /**
@@ -184,20 +133,8 @@ class Pay
      */
     public function queryAuthCode($authCode)
     {
-        $url = 'https://api.mch.weixin.qq.com/tools/authcodetoopenid';
-        return $this->callPostApi($url, ['auth_code' => $authCode]);
-    }
-
-    /**
-     * 转换短链接
-     * @param string $longUrl 需要转换的URL,签名用原串,传输需URLencode
-     * @return array
-     * @throws InvalidResponseException
-     */
-    public function shortUrl($longUrl)
-    {
-        $url = 'https://api.mch.weixin.qq.com/tools/shorturl';
-        return $this->callPostApi($url, ['long_url' => $longUrl]);
+        $pay = new Order($this->config->get());
+        return $pay->queryAuthCode($authCode);
     }
 
     /**
@@ -209,16 +146,8 @@ class Pay
      */
     public function billDownload(array $options, $outType = null)
     {
-        $this->params->set('sign_type', 'MD5');
-        $params = $this->params->merge($options);
-        $params['sign'] = $this->getPaySign($params, 'MD5');
-        $result = Tools::post('https://api.mch.weixin.qq.com/pay/downloadbill', Tools::arr2xml($params));
-        if (($jsonData = Tools::xml2arr($result))) {
-            if ($jsonData['return_code'] !== 'SUCCESS') {
-                throw new InvalidResponseException($jsonData['return_msg'], '0');
-            }
-        }
-        return is_null($outType) ? $result : $outType($result);
+        $pay = new Bill($this->config->get());
+        return $pay->download($options, $outType);
     }
 
 
@@ -230,8 +159,8 @@ class Pay
      */
     public function billCommtent(array $options)
     {
-        $url = 'https://api.mch.weixin.qq.com/billcommentsp/batchquerycomment';
-        return $this->callPostApi($url, $options, true);
+        $pay = new Bill($this->config->get());
+        return $pay->commtent($options);
     }
 
     /**
@@ -242,12 +171,8 @@ class Pay
      */
     public function createTransfers(array $options)
     {
-        $this->params->set('mchid', $this->config->get('mch_id'));
-        $this->params->set('mch_appid', $this->config->get('appid'));
-        $this->params->offsetUnset('appid');
-        $this->params->offsetUnset('mch_id');
-        $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers';
-        return $this->callPostApi($url, $options, true, 'MD5', false);
+        $pay = new Transfers($this->config->get());
+        return $pay->create($options);
     }
 
     /**
@@ -258,12 +183,8 @@ class Pay
      */
     public function queryTransfers($partner_trade_no)
     {
-        $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo';
-        $this->params->set('appid', $this->config->get('appid'));
-        $this->params->set('mch_id', $this->config->get('mch_id'));
-        $this->params->offsetUnset('mchid');
-        $this->params->offsetUnset('mch_appid');
-        return $this->callPostApi($url, ['partner_trade_no' => $partner_trade_no], true, 'MD5', false);
+        $pay = new Transfers($this->config->get());
+        return $pay->query($partner_trade_no);
     }
 
     /**
@@ -276,30 +197,8 @@ class Pay
      */
     public function createTransfersBank(array $options)
     {
-        if (!isset($options['partner_trade_no'])) {
-            throw new InvalidArgumentException('Missing Options -- [partner_trade_no]');
-        }
-        if (!isset($options['enc_bank_no'])) {
-            throw new InvalidArgumentException('Missing Options -- [enc_bank_no]');
-        }
-        if (!isset($options['enc_true_name'])) {
-            throw new InvalidArgumentException('Missing Options -- [enc_true_name]');
-        }
-        if (!isset($options['bank_code'])) {
-            throw new InvalidArgumentException('Missing Options -- [bank_code]');
-        }
-        if (!isset($options['amount'])) {
-            throw new InvalidArgumentException('Missing Options -- [amount]');
-        }
-        isset($options['desc']) && $this->config['desc'] = $options['desc'];
-        $this->params->offsetUnset('appid');
-        return $this->callPostApi('https://api.mch.weixin.qq.com/mmpaysptrans/pay_bank', [
-            'amount'           => $options['amount'],
-            'bank_code'        => $options['bank_code'],
-            'partner_trade_no' => $options['partner_trade_no'],
-            'enc_bank_no'      => $this->rsaEncode($options['enc_bank_no']),
-            'enc_true_name'    => $this->rsaEncode($options['enc_true_name']),
-        ], true, 'MD5', false);
+        $pay = new TransFresBank($this->config->get());
+        return $pay->create($options);
     }
 
     /**
@@ -310,120 +209,7 @@ class Pay
      */
     public function queryTransFresBank($partner_trade_no)
     {
-        $this->params->offsetUnset('appid');
-        $url = 'https://api.mch.weixin.qq.com/mmpaysptrans/query_bank';
-        return $this->callPostApi($url, ['partner_trade_no' => $partner_trade_no], true, 'MD5', false);
-    }
-
-    /**
-     * RSA加密处理
-     * @param string $string
-     * @param string $encrypted
-     * @return string
-     * @throws Exceptions\LocalCacheException
-     * @throws Exceptions\InvalidDecryptException
-     * @throws Exceptions\InvalidResponseException
-     */
-    private function rsaEncode($string, $encrypted = '')
-    {
-        $search = ['-----BEGIN RSA PUBLIC KEY-----', '-----END RSA PUBLIC KEY-----', "\n", "\r"];
-        $pkc1 = str_replace($search, '', $this->getRsaContent());
-        $publicKey = '-----BEGIN PUBLIC KEY-----' . PHP_EOL .
-            wordwrap('MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A' . $pkc1, 64, PHP_EOL, true) . PHP_EOL .
-            '-----END PUBLIC KEY-----';
-        if (!openssl_public_encrypt("{$string}", $encrypted, $publicKey, OPENSSL_PKCS1_OAEP_PADDING)) {
-            throw new InvalidDecryptException('Rsa Encrypt Error.');
-        }
-        return base64_encode($encrypted);
-    }
-
-    /**
-     * 获取签名文件内容
-     * @return string
-     * @throws Exceptions\LocalCacheException
-     * @throws Exceptions\InvalidResponseException
-     */
-    private function getRsaContent()
-    {
-        $cacheKey = "pub_ras_key_" . $this->config->get('mch_id');
-        if (($pub_key = Tools::getCache($cacheKey))) {
-            return $pub_key;
-        }
-        $data = $this->callPostApi('https://fraud.mch.weixin.qq.com/risk/getpublickey', [], true, 'MD5');
-        if (!isset($data['return_code']) || $data['return_code'] !== 'SUCCESS' || $data['result_code'] !== 'SUCCESS') {
-            $error = 'ResultError:' . $data['return_msg'];
-            $error .= isset($data['err_code_des']) ? ' - ' . $data['err_code_des'] : '';
-            throw new InvalidResponseException($error, 20000, $data);
-        }
-        Tools::setCache($cacheKey, $data['pub_key'], 600);
-        return $data['pub_key'];
-    }
-
-    /**
-     * 获取微信支付通知
-     * @return array
-     * @throws InvalidResponseException
-     */
-    public function getNotify()
-    {
-        $data = Tools::xml2arr(file_get_contents('php://input'));
-        if (!empty($data['sign'])) {
-            if ($this->getPaySign($data) === $data['sign']) {
-                return $data;
-            }
-        }
-        throw new InvalidResponseException('Invalid Notify.', '0');
-    }
-
-    /**
-     * 生成支付签名
-     * @param array $data 参与签名的数据
-     * @param string $signType 参与签名的类型
-     * @param string $buff 参与签名字符串前缀
-     * @return string
-     */
-    public function getPaySign(array $data, $signType = 'MD5', $buff = '')
-    {
-        unset($data['sign']);
-        ksort($data);
-        foreach ($data as $k => $v) {
-            $buff .= "{$k}={$v}&";
-        }
-        $buff .= ("key=" . $this->config->get('mch_key'));
-        if (strtoupper($signType) === 'MD5') {
-            return strtoupper(md5($buff));
-        }
-        return strtoupper(hash_hmac('SHA256', $buff, $this->config->get('mch_key')));
-    }
-
-    /**
-     * 以Post请求接口
-     * @param string $url 请求
-     * @param array $data 接口参数
-     * @param bool $isCert 是否需要使用双向证书
-     * @param string $signType 数据签名类型 MD5|SHA256
-     * @param bool $needSignType 是否需要传签名类型参数
-     * @return array
-     * @throws InvalidResponseException
-     */
-    public function callPostApi($url, array $data, $isCert = false, $signType = 'HMAC-SHA256', $needSignType = true)
-    {
-        $option = [];
-        if ($isCert) {
-            $option['ssl_cer'] = $this->config->get('ssl_cer');
-            $option['ssl_key'] = $this->config->get('ssl_key');
-            if (empty($option['ssl_cer']) || !file_exists($option['ssl_cer']))
-                throw new InvalidArgumentException("Missing Config -- ssl_cer", '0');
-            if (empty($option['ssl_key']) || !file_exists($option['ssl_key']))
-                throw new InvalidArgumentException("Missing Config -- ssl_key", '0');
-        }
-        $params = $this->params->merge($data);
-        $needSignType && ($params['sign_type'] = strtoupper($signType));
-        $params['sign'] = $this->getPaySign($params, $signType);
-        $result = Tools::xml2arr(Tools::post($url, Tools::arr2xml($params), $option));
-        if ($result['return_code'] !== 'SUCCESS') {
-            throw new InvalidResponseException($result['return_msg'], '0');
-        }
-        return $result;
+        $pay = new TransFresBank($this->config->get());
+        return $pay->query($partner_trade_no);
     }
 }
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WePay/Bill.php b/vendor/zoujingli/wechat-developer/WePay/Bill.php
new file mode 100644
index 000000000..d24b92968
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WePay/Bill.php
@@ -0,0 +1,61 @@
+params->set('sign_type', 'MD5');
+        $params = $this->params->merge($options);
+        $params['sign'] = $this->getPaySign($params, 'MD5');
+        $result = Tools::post('https://api.mch.weixin.qq.com/pay/downloadbill', Tools::arr2xml($params));
+        if (($jsonData = Tools::xml2arr($result))) {
+            if ($jsonData['return_code'] !== 'SUCCESS') {
+                throw new InvalidResponseException($jsonData['return_msg'], '0');
+            }
+        }
+        return is_null($outType) ? $result : $outType($result);
+    }
+
+
+    /**
+     * 拉取订单评价数据
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function commtent(array $options)
+    {
+        $url = 'https://api.mch.weixin.qq.com/billcommentsp/batchquerycomment';
+        return $this->callPostApi($url, $options, true);
+    }
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WePay/Coupon.php b/vendor/zoujingli/wechat-developer/WePay/Coupon.php
new file mode 100644
index 000000000..328104876
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WePay/Coupon.php
@@ -0,0 +1,62 @@
+callPostApi($url, $options, true);
+    }
+
+    /**
+     * 查询代金券批次
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function queryStock(array $options)
+    {
+        $url = "https://api.mch.weixin.qq.com/mmpaymkttransfers/query_coupon_stock";
+        return $this->callPostApi($url, $options, false);
+    }
+
+    /**
+     * 查询代金券信息
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function queryInfo(array $options)
+    {
+        $url = "https://api.mch.weixin.qq.com/mmpaymkttransfers/query_coupon_stock";
+        return $this->callPostApi($url, $options, false);
+    }
+
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WePay/Order.php b/vendor/zoujingli/wechat-developer/WePay/Order.php
new file mode 100644
index 000000000..bed6af650
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WePay/Order.php
@@ -0,0 +1,135 @@
+callPostApi($url, $options, false, 'MD5');
+    }
+
+    /**
+     * 查询订单
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function query(array $options)
+    {
+        $url = 'https://api.mch.weixin.qq.com/pay/orderquery';
+        return $this->callPostApi($url, $options);
+    }
+
+    /**
+     * 关闭订单
+     * @param string $outTradeNo 商户订单号
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function close($outTradeNo)
+    {
+        $url = 'https://api.mch.weixin.qq.com/pay/closeorder';
+        return $this->callPostApi($url, ['out_trade_no' => $outTradeNo]);
+    }
+
+    /**
+     * 创建JsApi及H5支付参数
+     * @param string $prepayId 统一下单预支付码
+     * @return array
+     */
+    public function jsapiParams($prepayId)
+    {
+        $option = [];
+        $option["appId"] = $this->config->get('appid');
+        $option["timeStamp"] = (string)time();
+        $option["nonceStr"] = Tools::createNoncestr();
+        $option["package"] = "prepay_id={$prepayId}";
+        $option["signType"] = "MD5";
+        $option["paySign"] = $this->getPaySign($option, 'MD5');
+        $option['timestamp'] = $option['timeStamp'];
+        return $option;
+    }
+
+    /**
+     * 获取支付规则二维码
+     * @param string $productId 商户定义的商品id或者订单号
+     * @return string
+     */
+    public function qrcParams($productId)
+    {
+        $data = [
+            'appid'      => $this->config->get('appid'),
+            'mch_id'     => $this->config->get('mch_id'),
+            'time_stamp' => (string)time(),
+            'nonce_str'  => Tools::createNoncestr(),
+            'product_id' => (string)$productId,
+        ];
+        $data['sign'] = $this->getPaySign($data, 'MD5');
+        return "weixin://wxpay/bizpayurl?" . http_build_query($data);
+    }
+
+    /**
+     * 刷卡支付 撤销订单
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function reverse(array $options)
+    {
+        $url = 'https://api.mch.weixin.qq.com/secapi/pay/reverse';
+        return $this->callPostApi($url, $options, true);
+    }
+
+    /**
+     * 刷卡支付 授权码查询openid
+     * @param string $authCode 扫码支付授权码,设备读取用户微信中的条码或者二维码信息
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function queryAuthCode($authCode)
+    {
+        $url = 'https://api.mch.weixin.qq.com/tools/authcodetoopenid';
+        return $this->callPostApi($url, ['auth_code' => $authCode]);
+    }
+
+    /**
+     * 刷卡支付 交易保障
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function report(array $options)
+    {
+        $url = 'https://api.mch.weixin.qq.com/payitil/report';
+        return $this->callPostApi($url, $options);
+    }
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WePay/Redpack.php b/vendor/zoujingli/wechat-developer/WePay/Redpack.php
new file mode 100644
index 000000000..8456810a4
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WePay/Redpack.php
@@ -0,0 +1,69 @@
+params->offsetUnset('appid');
+        $this->params->set('wxappid', $this->config->get('appid'));
+        $url = "https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack";
+        return $this->callPostApi($url, $options, true);
+    }
+
+    /**
+     * 发放裂变红包
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function groups(array $options)
+    {
+        $this->params->offsetUnset('appid');
+        $this->params->set('wxappid', $this->config->get('appid'));
+        $url = "https://api.mch.weixin.qq.com/mmpaymkttransfers/sendgroupredpack";
+        return $this->callPostApi($url, $options, true);
+    }
+
+    /**
+     * 查询红包记录
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function query(array $options)
+    {
+        $this->params->offsetUnset('wxappid');
+        $this->params->set('appid', $this->config->get('appid'));
+        $url = "https://api.mch.weixin.qq.com/mmpaymkttransfers/gethbinfo";
+        return $this->callPostApi($url, $options, true);
+    }
+
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WePay/Refund.php b/vendor/zoujingli/wechat-developer/WePay/Refund.php
new file mode 100644
index 000000000..a91493ee9
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WePay/Refund.php
@@ -0,0 +1,51 @@
+callPostApi($url, $options, true);
+    }
+
+    /**
+     * 查询退款
+     * @param array $options
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function query(array $options)
+    {
+        $url = 'https://api.mch.weixin.qq.com/pay/refundquery';
+        return $this->callPostApi($url, $options);
+    }
+
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WePay/TransFresBank.php b/vendor/zoujingli/wechat-developer/WePay/TransFresBank.php
new file mode 100644
index 000000000..b4400d27d
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WePay/TransFresBank.php
@@ -0,0 +1,124 @@
+config['desc'] = $options['desc'];
+        $this->params->offsetUnset('appid');
+        return $this->callPostApi('https://api.mch.weixin.qq.com/mmpaysptrans/pay_bank', [
+            'amount'           => $options['amount'],
+            'bank_code'        => $options['bank_code'],
+            'partner_trade_no' => $options['partner_trade_no'],
+            'enc_bank_no'      => $this->rsaEncode($options['enc_bank_no']),
+            'enc_true_name'    => $this->rsaEncode($options['enc_true_name']),
+        ], true, 'MD5', false);
+    }
+
+    /**
+     * 商户企业付款到银行卡操作进行结果查询
+     * @param string $partnerTradeNo 商户订单号,需保持唯一
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function query($partnerTradeNo)
+    {
+        $this->params->offsetUnset('appid');
+        $url = 'https://api.mch.weixin.qq.com/mmpaysptrans/query_bank';
+        return $this->callPostApi($url, ['partner_trade_no' => $partnerTradeNo], true, 'MD5', false);
+    }
+
+    /**
+     * RSA加密处理
+     * @param string $string
+     * @param string $encrypted
+     * @return string
+     * @throws \WeChat\Exceptions\InvalidDecryptException
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     * @throws \WeChat\Exceptions\LocalCacheException
+     */
+    private function rsaEncode($string, $encrypted = '')
+    {
+        $search = ['-----BEGIN RSA PUBLIC KEY-----', '-----END RSA PUBLIC KEY-----', "\n", "\r"];
+        $pkc1 = str_replace($search, '', $this->getRsaContent());
+        $publicKey = '-----BEGIN PUBLIC KEY-----' . PHP_EOL .
+            wordwrap('MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A' . $pkc1, 64, PHP_EOL, true) . PHP_EOL .
+            '-----END PUBLIC KEY-----';
+        if (!openssl_public_encrypt("{$string}", $encrypted, $publicKey, OPENSSL_PKCS1_OAEP_PADDING)) {
+            throw new InvalidDecryptException('Rsa Encrypt Error.');
+        }
+        return base64_encode($encrypted);
+    }
+
+    /**
+     * 获取签名文件内容
+     * @return string
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     * @throws \WeChat\Exceptions\LocalCacheException
+     */
+    private function getRsaContent()
+    {
+        $cacheKey = "pub_ras_key_" . $this->config->get('mch_id');
+        if (($pub_key = Tools::getCache($cacheKey))) {
+            return $pub_key;
+        }
+        $data = $this->callPostApi('https://fraud.mch.weixin.qq.com/risk/getpublickey', [], true, 'MD5');
+        if (!isset($data['return_code']) || $data['return_code'] !== 'SUCCESS' || $data['result_code'] !== 'SUCCESS') {
+            $error = 'ResultError:' . $data['return_msg'];
+            $error .= isset($data['err_code_des']) ? ' - ' . $data['err_code_des'] : '';
+            throw new InvalidResponseException($error, 20000, $data);
+        }
+        Tools::setCache($cacheKey, $data['pub_key'], 600);
+        return $data['pub_key'];
+    }
+
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/WePay/Transfers.php b/vendor/zoujingli/wechat-developer/WePay/Transfers.php
new file mode 100644
index 000000000..410aa8b75
--- /dev/null
+++ b/vendor/zoujingli/wechat-developer/WePay/Transfers.php
@@ -0,0 +1,59 @@
+params->set('mchid', $this->config->get('mch_id'));
+        $this->params->set('mch_appid', $this->config->get('appid'));
+        $this->params->offsetUnset('appid');
+        $this->params->offsetUnset('mch_id');
+        $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers';
+        return $this->callPostApi($url, $options, true, 'MD5', false);
+    }
+
+    /**
+     * 查询企业付款到零钱
+     * @param string $partnerTradeNo 商户调用企业付款API时使用的商户订单号
+     * @return array
+     * @throws \WeChat\Exceptions\InvalidResponseException
+     */
+    public function query($partnerTradeNo)
+    {
+        $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo';
+        $this->params->set('appid', $this->config->get('appid'));
+        $this->params->set('mch_id', $this->config->get('mch_id'));
+        $this->params->offsetUnset('mchid');
+        $this->params->offsetUnset('mch_appid');
+        return $this->callPostApi($url, ['partner_trade_no' => $partnerTradeNo], true, 'MD5', false);
+    }
+
+}
\ No newline at end of file
diff --git a/vendor/zoujingli/wechat-developer/composer.json b/vendor/zoujingli/wechat-developer/composer.json
index 895e4e8db..371dff343 100644
--- a/vendor/zoujingli/wechat-developer/composer.json
+++ b/vendor/zoujingli/wechat-developer/composer.json
@@ -12,6 +12,8 @@
     }
   ],
   "keywords": [
+    "WePay",
+    "WeMini",
     "WeChat",
     "WeChatPay",
     "WeChatDeveloper"
@@ -22,7 +24,11 @@
     "ext-openssl": "*"
   },
   "autoload": {
+    "classmap": [
+      "We.php"
+    ],
     "psr-4": {
+      "WePay\\": "WePay",
       "WeChat\\": "WeChat",
       "WeMini\\": "WeMini"
     }
diff --git a/vendor/zoujingli/wechat-developer/include.php b/vendor/zoujingli/wechat-developer/include.php
index 889d8c6fb..49dc9f8da 100644
--- a/vendor/zoujingli/wechat-developer/include.php
+++ b/vendor/zoujingli/wechat-developer/include.php
@@ -12,7 +12,6 @@
 // | github开源项目:https://github.com/zoujingli/WeChatDeveloper
 // +----------------------------------------------------------------------
 
-// 动态注册SDK自动加载
 spl_autoload_register(function ($classname) {
     $separator = DIRECTORY_SEPARATOR;
     $filename = __DIR__ . $separator . str_replace('\\', $separator, $classname) . '.php';
@@ -23,5 +22,11 @@ spl_autoload_register(function ($classname) {
         if (stripos($classname, 'WeMini') === 0) {
             include $filename;
         }
+        if (stripos($classname, 'WePay') === 0) {
+            include $filename;
+        }
+        if ($classname === 'We') {
+            include $filename;
+        }
     }
 });
\ No newline at end of file