123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- <?php
- namespace app\common\controller;
- use Firebase\JWT\JWT;
- use Firebase\JWT\Key;
- use app\BaseController;
- use app\common\util\Result;
- use EasyWeChatComposer\EasyWeChat;
- use app\common\exception\CatchException;
- class JwtBaseController extends BaseController
- {
- protected $failException = true;
- /**
- * $key jwt HS256 key
- *
- * @var string
- */
- protected $key;
- /**
- * $table 当前使用的表
- *
- * @var mixed
- */
- protected $table;
- /**
- * $model 当前使用的模型
- *
- * @var \think\Model
- */
- protected $model;
- /**
- * $wechat 微信小程序api实例
- *
- * @var \EasyWeChat\MiniProgram\Application
- */
- private static $_wechat;
- /**
- * 设置jwt密钥
- *
- * @param mixed $key
- *
- * @return void
- */
- protected function setKey($key) {
- $this->key = $key;
- }
- /**
- * 验证token
- *
- * @return void
- */
- public function valid()
- {
- // 允许 Authorization 头部通过 cors
- $jwt = $this->request->header('Authorization');
- if (empty($jwt)) {
- throw new CatchException("未授权用户", 600);
- }
- $jwt = str_replace('Bearer ', '', $jwt);
- // try decode
- $this->decodeJwt($jwt);
- return Result::rest(true);
- }
- /**
- * 默认参数
- *
- * @return mixed
- */
- protected function params($validator = null, $name = '')
- {
- $params = $this->request->param($name, null, 'trim');
- // 尝试校验
- if (!is_null($validator)) {
- $this->validate($params, $validator);
- }
- return $params;
- }
- protected function only(array $names)
- {
- return $this->request->only($names);
- }
- /**
- * encodeJwt
- *
- * @param array|\stdClass $payload
- *
- * @return string
- */
- protected function encodeJwt($payload)
- {
- return JWT::encode($payload, $this->key, 'HS256');
- }
- /**
- * decodeJwt
- *
- * @param string $jwt
- *
- * @return \stdClass
- */
- protected function decodeJwt($jwt)
- {
- return JWT::decode($jwt, new Key($this->key, 'HS256'));
- }
- }
|