<?php
|
/**
|
+-----------------------------------------------------------------------------------------------
|
* GouGuOPEN [ 左手研发,右手开源,未来可期!]
|
+-----------------------------------------------------------------------------------------------
|
* @Copyright (c) 2021~2024 http://www.gouguoa.com All rights reserved.
|
+-----------------------------------------------------------------------------------------------
|
* @Licensed 勾股OA,开源且可免费使用,但并不是自由软件,未经授权许可不能去除勾股OA的相关版权信息
|
+-----------------------------------------------------------------------------------------------
|
* @Author 勾股工作室 <hdm58@qq.com>
|
+-----------------------------------------------------------------------------------------------
|
*/
|
|
declare (strict_types = 1);
|
namespace app\api\controller;
|
|
use app\api\BaseController;
|
use app\api\middleware\Auth;
|
use Firebase\JWT\JWT;
|
use Firebase\JWT\Key;
|
use think\facade\Db;
|
use think\facade\Request;
|
|
class Demo extends BaseController
|
{
|
/**
|
* 控制器中间件 [登录、注册 不需要鉴权]
|
* @var array
|
*/
|
protected $middleware = [
|
Auth::class => ['except' => ['index','login'] ]
|
];
|
|
/**
|
* @param $user_id
|
* @return string
|
*/
|
public function getToken($user_id){
|
$time = time(); //当前时间
|
$conf = $this->jwt_conf;
|
$token = [
|
'iss' => $conf['iss'], //签发者 可选
|
'aud' => $conf['aud'], //接收该JWT的一方,可选
|
'iat' => $time, //签发时间
|
'nbf' => $time-1 , //(Not Before):某个时间点后才能访问,比如设置time+30,表示当前时间30秒后才能使用
|
'exp' => $time+$conf['exptime'], //过期时间,这里设置2个小时
|
'data' => [
|
//自定义信息,不要定义敏感信息
|
'userid' =>$user_id,
|
]
|
];
|
return JWT::encode($token, $conf['secrect'], 'HS256'); //输出Token 默认'HS256'
|
}
|
|
/**
|
* @param $token
|
*/
|
public static function checkToken($token){
|
try {
|
JWT::$leeway = 60;//当前时间减去60,把时间留点余地
|
$decoded = JWT::decode($token, self::$config['secrect'], ['HS256']); //HS256方式,这里要和签发的时候对应
|
return (array)$decoded;
|
} catch(\Firebase\JWT\SignatureInvalidException $e) { //签名不正确
|
return json(['code'=>403,'msg'=>'签名错误']);
|
}catch(\Firebase\JWT\BeforeValidException $e) { // 签名在某个时间点之后才能用
|
return json(['code'=>401,'msg'=>'token失效']);
|
}catch(\Firebase\JWT\ExpiredException $e) { // token过期
|
return json(['code'=>401,'msg'=>'token已过期']);
|
}catch(Exception $e) { //其他错误
|
return json(['code'=>404,'msg'=>'非法请求']);
|
}catch(\UnexpectedValueException $e) { //其他错误
|
return json(['code'=>404,'msg'=>'非法请求']);
|
} catch(\DomainException $e) { //其他错误
|
return json(['code'=>404,'msg'=>'非法请求']);
|
}
|
|
}
|
|
/**
|
* @api {post} /demo/login 会员登录
|
* @apiDescription 系统登录接口,返回 token 用于操作需验证身份的接口
|
|
* @apiParam (请求参数:) {string} username 登录用户名
|
* @apiParam (请求参数:) {string} password 登录密码
|
|
* @apiParam (响应字段:) {string} token Token
|
|
* @apiSuccessExample {json} 成功示例
|
* {"code":0,"msg":"登录成功","time":1627374739,"data":{"token":"eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJhcGkuZ291Z3VjbXMuY29tIiwiYXVkIjoiZ291Z3VjbXMiLCJpYXQiOjE2MjczNzQ3MzksImV4cCI6MTYyNzM3ODMzOSwidWlkIjoxfQ.gjYMtCIwKKY7AalFTlwB2ZVWULxiQpsGvrz5I5t2qTs"}}
|
* @apiErrorExample {json} 失败示例
|
* {"code":1,"msg":"帐号或密码错误","time":1627374820,"data":[]}
|
*/
|
|
public function login()
|
{
|
$param = get_params();
|
if (empty($param['username']) || empty($param['password'])) {
|
$this->apiError('参数错误');
|
}
|
// 校验用户名密码
|
$user = Db::name('Admin')->where(['username' => $param['username']])->find();
|
if (empty($user)) {
|
$this->apiError('帐号或密码错误');
|
}
|
$param['pwd'] = set_password($param['password'], $user['salt']);
|
if ($param['pwd'] !== $user['pwd']) {
|
$this->apiError('帐号或密码错误');
|
}
|
if ($user['status'] == -1) {
|
$this->apiError('该用户禁止登录,请于平台联系');
|
}
|
$data = [
|
'last_login_time' => time(),
|
'last_login_ip' => request()->ip(),
|
'login_num' => $user['login_num'] + 1,
|
];
|
$res = Db::name('Admin')->where(['id' => $user['id']])->update($data);
|
if ($res) {
|
$token = self::getToken($user['id']);
|
$this->apiSuccess('登录成功', ['token' => $token]);
|
}
|
}
|
/**
|
* @api {post} /index/demo 测试页面
|
* @apiDescription 返回文章列表信息
|
|
* @apiParam (请求参数:) {string} token Token
|
|
* @apiSuccessExample {json} 响应数据样例
|
* {"code":1,"msg":"","time":1563517637,"data":{"id":13,"email":"test110@qq.com","password":"e10adc3949ba59abbe56e057f20f883e","sex":1,"last_login_time":1563517503,"last_login_ip":"127.0.0.1","qq":"123455","mobile":"","mobile_validated":0,"email_validated":0,"type_id":1,"status":1,"create_ip":"127.0.0.1","update_time":1563507130,"create_time":1563503991,"type_name":"注册会员"}}
|
*/
|
public function test(Request $request)
|
{
|
$uid = JWT_UID;
|
$userInfo = Db::name('Admin')->where(['id' => $uid])->find();
|
$this->apiSuccess('请求成功', ['user' => $userInfo]);
|
}
|
}
|