Demo.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <?php
  2. /**
  3. +-----------------------------------------------------------------------------------------------
  4. * GouGuOPEN [ 左手研发,右手开源,未来可期!]
  5. +-----------------------------------------------------------------------------------------------
  6. * @Copyright (c) 2021~2024 http://www.gouguoa.com All rights reserved.
  7. +-----------------------------------------------------------------------------------------------
  8. * @Licensed 勾股OA,开源且可免费使用,但并不是自由软件,未经授权许可不能去除勾股OA的相关版权信息
  9. +-----------------------------------------------------------------------------------------------
  10. * @Author 勾股工作室 <hdm58@qq.com>
  11. +-----------------------------------------------------------------------------------------------
  12. */
  13. declare (strict_types = 1);
  14. namespace app\api\controller;
  15. use app\api\BaseController;
  16. use app\api\middleware\Auth;
  17. use Firebase\JWT\JWT;
  18. use Firebase\JWT\Key;
  19. use think\facade\Db;
  20. use think\facade\Request;
  21. class Demo extends BaseController
  22. {
  23. /**
  24. * 控制器中间件 [登录、注册 不需要鉴权]
  25. * @var array
  26. */
  27. protected $middleware = [
  28. Auth::class => ['except' => ['index','login'] ]
  29. ];
  30. /**
  31. * @param $user_id
  32. * @return string
  33. */
  34. public function getToken($user_id){
  35. $time = time(); //当前时间
  36. $conf = $this->jwt_conf;
  37. $token = [
  38. 'iss' => $conf['iss'], //签发者 可选
  39. 'aud' => $conf['aud'], //接收该JWT的一方,可选
  40. 'iat' => $time, //签发时间
  41. 'nbf' => $time-1 , //(Not Before):某个时间点后才能访问,比如设置time+30,表示当前时间30秒后才能使用
  42. 'exp' => $time+$conf['exptime'], //过期时间,这里设置2个小时
  43. 'data' => [
  44. //自定义信息,不要定义敏感信息
  45. 'userid' =>$user_id,
  46. ]
  47. ];
  48. return JWT::encode($token, $conf['secrect'], 'HS256'); //输出Token 默认'HS256'
  49. }
  50. /**
  51. * @param $token
  52. */
  53. public static function checkToken($token){
  54. try {
  55. JWT::$leeway = 60;//当前时间减去60,把时间留点余地
  56. $decoded = JWT::decode($token, self::$config['secrect'], ['HS256']); //HS256方式,这里要和签发的时候对应
  57. return (array)$decoded;
  58. } catch(\Firebase\JWT\SignatureInvalidException $e) { //签名不正确
  59. return json(['code'=>403,'msg'=>'签名错误']);
  60. }catch(\Firebase\JWT\BeforeValidException $e) { // 签名在某个时间点之后才能用
  61. return json(['code'=>401,'msg'=>'token失效']);
  62. }catch(\Firebase\JWT\ExpiredException $e) { // token过期
  63. return json(['code'=>401,'msg'=>'token已过期']);
  64. }catch(Exception $e) { //其他错误
  65. return json(['code'=>404,'msg'=>'非法请求']);
  66. }catch(\UnexpectedValueException $e) { //其他错误
  67. return json(['code'=>404,'msg'=>'非法请求']);
  68. } catch(\DomainException $e) { //其他错误
  69. return json(['code'=>404,'msg'=>'非法请求']);
  70. }
  71. }
  72. /**
  73. * @api {post} /demo/login 会员登录
  74. * @apiDescription 系统登录接口,返回 token 用于操作需验证身份的接口
  75. * @apiParam (请求参数:) {string} username 登录用户名
  76. * @apiParam (请求参数:) {string} password 登录密码
  77. * @apiParam (响应字段:) {string} token Token
  78. * @apiSuccessExample {json} 成功示例
  79. * {"code":0,"msg":"登录成功","time":1627374739,"data":{"token":"eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJhcGkuZ291Z3VjbXMuY29tIiwiYXVkIjoiZ291Z3VjbXMiLCJpYXQiOjE2MjczNzQ3MzksImV4cCI6MTYyNzM3ODMzOSwidWlkIjoxfQ.gjYMtCIwKKY7AalFTlwB2ZVWULxiQpsGvrz5I5t2qTs"}}
  80. * @apiErrorExample {json} 失败示例
  81. * {"code":1,"msg":"帐号或密码错误","time":1627374820,"data":[]}
  82. */
  83. public function login()
  84. {
  85. $param = get_params();
  86. if (empty($param['username']) || empty($param['password'])) {
  87. $this->apiError('参数错误');
  88. }
  89. // 校验用户名密码
  90. $user = Db::name('Admin')->where(['username' => $param['username']])->find();
  91. if (empty($user)) {
  92. $this->apiError('帐号或密码错误');
  93. }
  94. $param['pwd'] = set_password($param['password'], $user['salt']);
  95. if ($param['pwd'] !== $user['pwd']) {
  96. $this->apiError('帐号或密码错误');
  97. }
  98. if ($user['status'] == -1) {
  99. $this->apiError('该用户禁止登录,请于平台联系');
  100. }
  101. $data = [
  102. 'last_login_time' => time(),
  103. 'last_login_ip' => request()->ip(),
  104. 'login_num' => $user['login_num'] + 1,
  105. ];
  106. $res = Db::name('Admin')->where(['id' => $user['id']])->update($data);
  107. if ($res) {
  108. $token = self::getToken($user['id']);
  109. $this->apiSuccess('登录成功', ['token' => $token]);
  110. }
  111. }
  112. /**
  113. * @api {post} /index/demo 测试页面
  114. * @apiDescription 返回文章列表信息
  115. * @apiParam (请求参数:) {string} token Token
  116. * @apiSuccessExample {json} 响应数据样例
  117. * {"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":"注册会员"}}
  118. */
  119. public function test(Request $request)
  120. {
  121. $uid = JWT_UID;
  122. $userInfo = Db::name('Admin')->where(['id' => $uid])->find();
  123. $this->apiSuccess('请求成功', ['user' => $userInfo]);
  124. }
  125. }