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