kydev / work-wx-user
企业微信用户系统
v0.2.1
2022-08-08 05:55 UTC
Requires
- php: >=8.0
- hyperf/command: 3.0.*
- hyperf/db-connection: 3.0.*
- hyperf/http-server: 3.0.*
- hyperf/model-cache: 3.0.*
- hyperf/redis: 3.0.*
- hyperf/validation: 3.0.*
- limingxinleo/easywechat-classmap: ^1.0
- limingxinleo/hyperf-utils: ^3.3
- w7corp/easywechat: ^6.7
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- hyperf/config: 3.0.*
- mockery/mockery: ^1.0
- phpstan/phpstan: ^1.0
- phpunit/phpunit: >=7.0
- swoole/ide-helper: ^4.5
Suggests
- hyperf/engine-swow: Required to use local oauth login.
README
介绍
基于 Hyperf 框架,快速搭建企业微信用户服务
安装
composer require kydev/work-wx-user
使用
发布配置
php bin/hyperf.php vendor:publish kydev/work-wx-user
登录
创建控制器
<?php declare(strict_types=1); namespace App\Controller; use Hyperf\Di\Annotation\Inject; use KY\WorkWxUser\Request\AuthorizeRequest; use KY\WorkWxUser\UserService; use KY\WorkWxUser\WeChat\WeChat; class OAuthController extends Controller { #[Inject] protected WeChat $wx; #[Inject] protected UserService $service; public function authorize(AuthorizeRequest $request) { $url = (string) $request->input('redirect_uri'); $state = (string) $request->input('state'); $redirectUrl = $this->wx->authorize($url, $state); return $this->response->redirect($redirectUrl); } public function login() { $code = $this->request->input('code'); $result = $this->service->login($code); return $this->response->success([ 'token' => $result->getToken(), 'user' => $result->getUser()->toArray(), ]); } }
增加路由
<?php Router::get('/oauth/authorize', [App\Controller\OAuthController::class, 'authorize']); Router::get('/oauth/login', [App\Controller\OAuthController::class, 'login']); Router::post('/oauth/login', [App\Controller\OAuthController::class, 'login']);
浏览器访问以下地址,并扫码
http://127.0.0.1:9501/oauth/authorize?state=STATE&redirect_uri=http://127.0.0.1:9501/oauth/login
验证登录态
在 middlewares.php
配置中,增加对应的中间件。
<?php declare(strict_types=1); return [ 'http' => [ KY\WorkWxUser\Middleware\UserAuthMiddleware::class, ], ];
使用时,调用 build()
方法,即可验证是否已登录,如果没有登录态,则抛出 KY\WorkWxUser\Exception\TokenInvalidException
异常。
<?php $id = UserAuth::get()->build()->getId();
最后只需要在我们的异常捕获器中,增加对应的异常捕获,并与前端协商好对应的错误码,即可正常使用,例如以下异常捕获器
<?php declare(strict_types=1); namespace App\Exception\Handler; use App\Constants\ErrorCode; use App\Exception\BusinessException; use App\Kernel\Http\Response; use Hyperf\Contract\StdoutLoggerInterface; use Hyperf\Di\Exception\CircularDependencyException; use Hyperf\ExceptionHandler\ExceptionHandler; use Hyperf\HttpMessage\Exception\HttpException; use KY\WorkWxUser\Exception\TokenInvalidException; use Psr\Container\ContainerInterface; use Psr\Http\Message\ResponseInterface; use Psr\Log\LoggerInterface; use Throwable; class BusinessExceptionHandler extends ExceptionHandler { protected Response $response; protected LoggerInterface $logger; public function __construct(protected ContainerInterface $container) { $this->response = $container->get(Response::class); $this->logger = $container->get(StdoutLoggerInterface::class); } public function handle(Throwable $throwable, ResponseInterface $response) { switch (true) { case $throwable instanceof HttpException: return $this->response->handleException($throwable); case $throwable instanceof TokenInvalidException: return $this->response->fail(ErrorCode::TOKEN_INVALID, 'Token Invalid.'); case $throwable instanceof BusinessException: $this->logger->warning(format_throwable($throwable)); return $this->response->fail($throwable->getCode(), $throwable->getMessage()); case $throwable instanceof CircularDependencyException: $this->logger->error($throwable->getMessage()); return $this->response->fail(ErrorCode::SERVER_ERROR, $throwable->getMessage()); } $this->logger->error(format_throwable($throwable)); return $this->response->fail(ErrorCode::SERVER_ERROR, 'Server Error'); } public function isValid(Throwable $throwable): bool { return true; } }