| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- <?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]);
- }
- }
|