1. 安装 laravel/socialite
如果你已经安装过此 Package,则可以跳过此步骤。
1). 直接运行以下命令安装扩展包
composer require laravel/socialite
2). 在你的 config/app.php
文件中添加以下配置信息
'providers' => [
...
// 注意:下文中要集成 Socialite Driver 扩展,因此将会删除此行配置。
Laravel\Socialite\SocialiteServiceProvider::class,
],
'aliases' => [
...
'Socialite' => Laravel\Socialite\Facades\Socialite::class,
],
2. 安装 socialiteProviders/weixin
1). 直接运行以下命令安装扩展包
composer require socialiteproviders/weixin
2). 在你的 config/app.php
文件中添加以下配置信息
'providers' => [
...
# 注意:如果你之前已经安装了 laravel/socialite,则务必删除掉下面的配置
// 删除这行配置 Laravel\Socialite\SocialiteServiceProvider::class,
# 新增配置
\SocialiteProviders\Manager\ServiceProvider::class,
],
3). 在你的 app/Providers/EventServiceProvider.php
文件中添加以下事件处理器
protected $listen = [
\SocialiteProviders\Manager\SocialiteWasCalled::class => [
'SocialiteProviders\Weixin\WeixinExtendSocialite@handle',
],
];
3. 添加配置
1). 在你的 .env
文件中添加以下配置
WEIXIN_KEY=你的AppID
WEIXIN_SECRET=你的AppSecret
WEIXIN_REDIRECT_URI=你的回调地址
# 例如
WEIXIN_KEY=wxba52fab0726b9023
WEIXIN_SECRET=xxxxxxxxxxxxxxxxxx
WEIXIN_REDIRECT_URI=https://phphub.org/auth/callback?driver=wechat
2). 在你的 config/services.php
文件中添加以下配置
'weixin' => [
'client_id' => env('WEIXIN_KEY'),
'client_secret' => env('WEIXIN_SECRET'),
'redirect' => env('WEIXIN_REDIRECT_URI'),
# 这一行配置非常重要,必须要写成这个地址。
'auth_base_uri' => 'https://open.weixin.qq.com/connect/qrconnect',
],
至此,安装全部完成。
代码调用
准备工作都完成以后,现在就到了接口对接阶段。
1). 添加路由
# 用户点击登录按钮时请求的地址
Route::get('/auth/oauth', 'Auth\AuthController@oauth');
# 微信接口回调地址
Route::get('/auth/callback', 'Auth\AuthController@callback');
2). 在你的 app/Http/Controllers/Auth/AuthController.php
文件里添加以下方法
# 用户点击微信登录按钮后,调用此方法请求微信接口
public function oauth(Request $request)
{
return \Socialite::with('weixin')->redirect();
}
# 微信的回调地址
public function callback(Request $request)
{
$oauthUser = \Socialite::with('weixin')->user();
// 在这里可以获取到用户在微信的资料
dd($oauthUser);
// 接下来处理相关的业务逻辑
...
}