AuthController.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <?php
  2. namespace App\Http\Controllers\Api\mini;
  3. use App\Models\User;
  4. use App\Models\UserReset;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\Auth;
  7. use Illuminate\Support\Facades\Log;
  8. class AuthController extends BaseController
  9. {
  10. protected $model;
  11. public function __construct()
  12. {
  13. $this->model = new User();
  14. }
  15. public function login(Request $request)
  16. {
  17. $credentials = $request->only('phone', 'password');
  18. if(Auth::guard('mini')->attempt($credentials)) {
  19. $user = Auth::guard('mini')->user();
  20. $user->updateToken();
  21. $user->avatar = $user->avatar ? $user->avatar : 'https://t18.9026.com/mini/default-user.png';
  22. $user->topRole = $user->getTopRole();
  23. return $this->success(['data' => $user]);
  24. }
  25. return $this->error(['msg' => '账号或密码错误']);
  26. }
  27. //通过微信登陆时需要判断手机号是否存在,若存在就不要再往数据库中添加数据了
  28. //将这一步的通过微信授权登陆改为直接手机授权登陆
  29. public function loginByWechat(Request $request)
  30. {
  31. $app = app('wechat.mini_program');
  32. $session_key = $request->input('session_key');
  33. if(!$session_key && $request->input('code')) {
  34. $res = $app->auth->session($request->input('code'));
  35. if (empty($res['openid']) || empty($res['session_key'])){
  36. return $this->error(['msg' => '微信code错误']);
  37. }
  38. if(isset($res['session_key'])) $session_key = $res['session_key'];
  39. }
  40. if($session_key) {
  41. $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
  42. Log::info('info'.json_encode($data));
  43. Log::info('info'.json_encode($res));
  44. if(isset($data['phoneNumber'])) {
  45. $user = Auth::guard('mini')->user();
  46. //在数据库中若存在该手机号码的数据需要update进行修改数据、若不存在需要向数据库中添加数据
  47. $user = User::where("phone","=",$data['phoneNumber'])->first();
  48. if(!empty($user)){
  49. if(empty($user->open_id)){
  50. //存在手机号码直接修改
  51. User::where('phone',$data['phoneNumber'] )->update(['open_id' => $res['openid'],'session_key'=>$res['session_key']]);
  52. }
  53. $user->updateToken();
  54. $user = $user->getUserInfo($session_key);
  55. return $this->success(['data' => $user]);
  56. // return $this->error(['msg' => '后台已经存在这个手机号码了,请换一个手机号码绑定']);
  57. }
  58. //用openid区查找用户是否存在,存在更新openid
  59. $user = User::where("open_id","=",$res['openid'])->first();
  60. if(!empty($user)){
  61. if(empty($user->phone)){
  62. User::where('open_id',$res['openid'] )->update(['phone' => $data['phoneNumber'],'session_key'=>$res['session_key']]);
  63. }
  64. $user->updateToken();
  65. $user = $user->getUserInfo($session_key);
  66. return $this->success(['data' => $user]);
  67. }
  68. //不存在手机号码直接添加数据
  69. $user = User::firstOrCreate([
  70. 'open_id' => $res['openid']
  71. ], [
  72. 'open_id' => $res['openid'],
  73. 'session_key'=>$res['session_key'],
  74. 'phone' => $data['phoneNumber'],
  75. ]);
  76. $user = $user->getUserInfo($session_key);
  77. return $this->success(['data' => $user]);
  78. }
  79. return $this->error(['msg' => '获取失败']);
  80. }
  81. return $this->error(['msg' => '获取失败']);
  82. }
  83. public function loginByWechat1(Request $request)
  84. {
  85. $app = app('wechat.mini_program');
  86. $session_key = $request->input('session_key');
  87. if(empty($session_key) && $request->input('code')) {
  88. $res = $app->auth->session($request->input('code'));
  89. if(isset($res['session_key'])) $session_key = $res['session_key'];
  90. }
  91. if($session_key) {
  92. $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
  93. if(isset($data['openId'])) {
  94. if($request->input('bind')) {
  95. $token = $request->header('X-Token');
  96. $user = User::where('token', $token)->first();
  97. if(!$user) return $this->error(['msg' => '找不到用户']);
  98. } else {
  99. $user = User::firstOrCreate([
  100. 'open_id' => $data['openId']
  101. ], [
  102. 'name' => $data['nickName'],
  103. 'nickname' => $data['nickName'],
  104. 'avatar' => $data['avatarUrl']
  105. ]);
  106. if(empty($user)) return $this->error(['msg' => '用户不存在,请先绑定账户']);
  107. }
  108. $union_id = isset($data['unionId']) ? $data['unionId'] : $user->union_id;
  109. $user->update([
  110. 'nickname' => $data['nickName'],
  111. 'avatar' => $data['avatarUrl'],
  112. 'union_id' => $union_id
  113. ]);
  114. $user->updateToken();
  115. $user = $user->getUserInfo($session_key);
  116. return $this->success(['data' => $user]);
  117. }
  118. }
  119. return $this->error(['msg' => '登陆失败']);
  120. }
  121. public function parsePhone(Request $request)
  122. {
  123. $app = app('wechat.mini_program');
  124. $session_key = $request->input('session_key');
  125. if(!$session_key && $request->input('code')) {
  126. $res = $app->auth->session($request->input('code'));
  127. Log::info('进入parsePhone函数 code是',$request->input('code').PHP_EOL);
  128. if(isset($res['session_key'])) $session_key = $res['session_key'];
  129. }
  130. if($session_key) {
  131. Log::info('进入parsePhone函数 有code是',$request->input('code').PHP_EOL);
  132. $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
  133. Log::info('进入parsePhone函数 解析信息',json_encode($data));
  134. if(isset($data['phoneNumber'])) {
  135. Log::info('进入parsePhone函数 没有电话号码');
  136. $user = Auth::guard('mini')->user();
  137. //在个人信息中的第三个选项的手机号码绑定这一步不是先修改的操作而是先判断手机号码是否存在于数据库中,若存在于数据库就可以不用修改了直接返回该手机号码已经在后台设置了
  138. $phone = User::where("phone","=",$data['phoneNumber'])->first();
  139. if(!empty($phone)){
  140. return $this->error(['msg' => '后台已经存在这个手机号码了,请换一个手机号码绑定']);
  141. }
  142. $user->update(['phone' => $data['phoneNumber']]);
  143. $user = $user->getUserInfo($session_key);
  144. return $this->success(['data' => $user]);
  145. }
  146. return $this->error(['msg' => '获取失败']);
  147. }
  148. Log::info('进入parsePhone函数 没有code'.PHP_EOL);
  149. return $this->error(['msg' => '获取失败']);
  150. }
  151. public function reset(Request $request)
  152. {
  153. $user = User::where('phone', $request->input('phone'))->first();
  154. if(!$user) return $this->error(['msg' => '账号不存在']);
  155. UserReset::create([
  156. 'user_id' => $user->id,
  157. 'phone' => $request->input('phone'),
  158. 'name' => $request->input('name')
  159. ]);
  160. return $this->success();
  161. }
  162. public function getUserInfo()
  163. {
  164. $user = Auth::guard('mini')->user();
  165. $user->avatar = $user->avatar ? $user->avatar : 'https://t18.9026.com/mini/default-user.png';
  166. $user = $user->getUserInfo();
  167. return $this->success(['data' => $user]);
  168. }
  169. }