PHPackages                             jianyan74/yii2-easy-wechat - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [API Development](/categories/api)
4. /
5. jianyan74/yii2-easy-wechat

ActiveYii2-extension[API Development](/categories/api)

jianyan74/yii2-easy-wechat
==========================

WeChat SDK for yii2, 基于 overtrue/easywechat

2.0.2(4y ago)14339.4k↑12.5%37[1 issues](https://github.com/jianyan74/yii2-easy-wechat/issues)1MITPHPPHP &gt;=7.4

Since May 19Pushed 4y ago8 watchersCompare

[ Source](https://github.com/jianyan74/yii2-easy-wechat)[ Packagist](https://packagist.org/packages/jianyan74/yii2-easy-wechat)[ RSS](/packages/jianyan74-yii2-easy-wechat/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (10)Dependencies (2)Versions (18)Used By (1)

yii2-easy-wechat
================

[](#yii2-easy-wechat)

> 支持 overtrue/wechat 4.x 和 5.x

由于 [max-wen/yii2-easy-wechat](https://github.com/max-wen/yii2-easy-wechat) 不支持 EasyWechat 4.x 所以建立该项目

WeChat SDK for Yii2 , 基于 [overtrue/wechat](https://github.com/overtrue/wechat).
这个扩展可以简单的用yii2的方式去调用EasyWechat: `Yii::$app->wechat`.

[![Latest Stable Version](https://camo.githubusercontent.com/acf768975daa341af7dd2206f3560e6d953a003a65110098e33ad7dd0dcbd30b/68747470733a2f2f706f7365722e707567782e6f72672f6a69616e79616e37342f796969322d656173792d7765636861742f762f737461626c65)](https://packagist.org/packages/jianyan74/yii2-easy-wechat)[![Total Downloads](https://camo.githubusercontent.com/c5178449fa02b82ac677a08e53bb75061d5d01e593cc3e72ab148fe01acb1a3c/68747470733a2f2f706f7365722e707567782e6f72672f6a69616e79616e37342f796969322d656173792d7765636861742f646f776e6c6f616473)](https://packagist.org/packages/jianyan74/yii2-easy-wechat)[![License](https://camo.githubusercontent.com/65bdd049fcf5cc82f06d44a182cc3294110bd8fc79304dad6014ad825180d671/68747470733a2f2f706f7365722e707567782e6f72672f6a69616e79616e37342f796969322d656173792d7765636861742f6c6963656e7365)](https://packagist.org/packages/jianyan74/yii2-easy-wechat)

安装 EasyWechat 4.x
-----------------

[](#安装-easywechat-4x)

```
composer require jianyan74/yii2-easy-wechat:~1.0

```

安装 EasyWechat 5.x
-----------------

[](#安装-easywechat-5x)

```
composer require jianyan74/yii2-easy-wechat:~2.0

```

配置
--

[](#配置)

添加 SDK 到Yii2的 `config/main.php` 的 `component`:

```
'components' => [
	// ...
	'wechat' => [
		'class' => 'jianyan\easywechat\Wechat',
		'userOptions' => [],  // 用户身份类参数
		'sessionParam' => 'wechatUser', // 微信用户信息将存储在会话在这个密钥
		'returnUrlParam' => '_wechatReturnUrl', // returnUrl 存储在会话中
		'rebinds' => [ // 自定义服务模块
		    // 'cache' => 'common\components\Cache',
		]
	],
	// ...
]
```

设置基础配置信息和微信支付信息到 `config/params.php`:

```
// 微信配置 具体可参考EasyWechat
'wechatConfig' => [],

// 微信支付配置 具体可参考EasyWechat
'wechatPaymentConfig' => [],

// 微信小程序配置 具体可参考EasyWechat
'wechatMiniProgramConfig' => [],

// 微信开放平台第三方平台配置 具体可参考EasyWechat
'wechatOpenPlatformConfig' => [],

// 微信企业微信配置 具体可参考EasyWechat
'wechatWorkConfig' => [],

// 微信企业微信开放平台 具体可参考EasyWechat
'wechatOpenWorkConfig' => [],

// 微信小微商户 具体可参考EasyWechat
'wechatMicroMerchantConfig' => [],
```

配置文档

[微信配置说明文档.](https://www.easywechat.com/docs/master/official-account/configuration)
[微信支付配置说明文档.](https://www.easywechat.com/docs/master/payment/jssdk)
[微信小程序配置说明文档.](https://www.easywechat.com/docs/master/mini-program/index)
[微信开放平台第三方平台](https://www.easywechat.com/docs/master/open-platform/index)
[企业微信](https://www.easywechat.com/docs/master/wework/index)
[企业微信开放平台](https://www.easywechat.com/docs/master/open-work/index)
[小微商户](https://www.easywechat.com/docs/master/micro-merchant/index)

使用例子
----

[](#使用例子)

微信网页授权+获取当前用户信息

```
if (Yii::$app->wechat->isWechat && !Yii::$app->wechat->isAuthorized()) {
    return Yii::$app->wechat->authorizeRequired()->send();
}

// 获取微信当前用户信息方法一
Yii::$app->session->get('wechatUser')

// 获取微信当前用户信息方法二
Yii::$app->wechat->user
```

获取微信SDK实例

```
$app = Yii::$app->wechat->app;
```

获取微信支付SDK实例

```
$payment = Yii::$app->wechat->payment;
```

获取微信小程序实例

```
$miniProgram = Yii::$app->wechat->miniProgram;
```

获取微信开放平台第三方平台实例

```
$openPlatform = Yii::$app->wechat->openPlatform;
```

获取企业微信实例

```
$work = Yii::$app->wechat->work;
```

获取微信企业微信开放平台

```
$work = Yii::$app->wechat->openWork;
```

获取微信小微商户

```
$microMerchant = Yii::$app->wechat->microMerchant;
```

微信支付(JsApi):

```
// 支付参数
$orderData = [
    'openid' => '.. '
    // ... etc.
];

// 生成支付配置
$payment = Yii::$app->wechat->payment;
$result = $payment->order->unify($orderData);
if ($result['return_code'] == 'SUCCESS') {
    $prepayId = $result['prepay_id'];
    $config = $payment->jssdk->sdkConfig($prepayId);
} else {
    throw new yii\base\ErrorException('微信支付异常, 请稍后再试');
}

return $this->render('wxpay', [
    'jssdk' => $payment->jssdk, // $app通过上面的获取实例来获取
    'config' => $config
]);
```

JSSDK发起支付

```

    //数组内为jssdk授权可用的方法，按需添加，详细查看微信jssdk的方法
    wx.config();
    // 发起支付
    wx.chooseWXPay({
        timestamp: ,
        nonceStr: '',
        package: '',
        signType: '',
        paySign: '', // 支付签名
        success: function (res) {
            // 支付成功后的回调函数
        }
    });

```

### 智能提示

[](#智能提示)

如果你需要编辑器（PhpStorm等）的智能提示来使用`Yii::$app->wechat`，可以在`yii\base\Application`中加入:

```
