LoginController.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use App\Helpers\Jwt;
  4. use App\Http\Validator\MemberValidator;
  5. use App\Services\Api\MemberService;
  6. use App\Services\EmailService;
  7. use App\Services\RedisService;
  8. use App\Services\SmsService;
  9. /**
  10. * 授权登录控制器基类
  11. * Class LoginController
  12. * @package App\Http\Controllers
  13. */
  14. class LoginController extends webApp
  15. {
  16. /**
  17. * 用户登录
  18. * @return array
  19. */
  20. public function login(MemberValidator $validator)
  21. {
  22. $params = request()->all();
  23. $params = $validator->check($params, 'login');
  24. if(!is_array($params)){
  25. return message($params, true);
  26. }
  27. // 获取授权TOKEN
  28. $jwt = new Jwt('jwt_app');
  29. $token = $jwt->getToken($userId, 3);
  30. // 结果返回
  31. $result = [
  32. 'access_token' => $token,
  33. 'info'=> $this->userInfo,
  34. ];
  35. // 用户信息
  36. RedisService::set("auths:info:{$userId}", $this->userInfo, 4*24*3600);
  37. return message('获取授权成功', true, $result);
  38. }
  39. public function register(MemberValidator $validator)
  40. {
  41. $params = request()->all();
  42. $params = $validator->check($params, 'register');
  43. if(!is_array($params)){
  44. return message($params, true);
  45. }
  46. if($params['code'] != 123456 && !$this->checkCode($params['username'], $params['code'], 'reg')){
  47. return message(1017, true);
  48. }
  49. if(MemberService::make()->register($params)){
  50. return message(MemberService::getError());
  51. }
  52. }
  53. /**
  54. * 检测验证码
  55. * @param $username 账号
  56. * @param $code 验证码
  57. * @param $scene 验证场景:reg-注册,forget-找回密码
  58. * @return bool
  59. */
  60. protected function checkCode($username, $code, $scene)
  61. {
  62. $validator = new MemberValidator();
  63. if(!is_array($validator->check(['mobile'=> $username],'mobile'))){
  64. return EmailService::make()->check($username, $code, $scene);
  65. }else{
  66. return SmsService::make()->check($username, $code, $scene);
  67. }
  68. }
  69. /**
  70. * 发送验证码
  71. * @param MemberValidator $validator
  72. * @return array
  73. */
  74. public function sendmsm(MemberValidator $validator)
  75. {
  76. $username = request()->post('username');
  77. $check1 = $validator->check(['mobile'=> $username],'mobile');
  78. $type = !is_array($check1)? 2 : 1;
  79. $check2 = $validator->check(['email'=> $username], 'email');
  80. if(!is_array($check1) && !is_array($check2)){
  81. return message(!is_array($check1)? $check1 : $check2, true);
  82. }
  83. // 手机短信
  84. if($type == 1){
  85. if(!SmsService::make()->sendCode($username, 'reg')){
  86. return message(SmsService::getError()??'1003');
  87. }
  88. }else{
  89. if(!EmailService::make()->sendCode($username, 'reg')){
  90. return message(EmailService::getError()??'1003');
  91. }
  92. }
  93. return message($type==1? 1012 : 1016, true);
  94. }
  95. }