| xqd
@@ -26,33 +26,50 @@ class AuthController extends BaseController
|
|
|
public function loginByWechat(Request $request)
|
|
|
{
|
|
|
$app = app('wechat.mini_program');
|
|
|
- if($request->input('code')) {
|
|
|
+ $session_key = $request->input('session_key');
|
|
|
+ if(!$session_key && $request->input('code')) {
|
|
|
$res = $app->auth->session($request->input('code'));
|
|
|
- if(isset($res['session_key'])) {
|
|
|
- $data = $app->encryptor->decryptData($res['session_key'], $request->input('iv'), $request->input('encryptedData'));
|
|
|
- if(isset($data['openId'])) {
|
|
|
- if($request->input('bind')) {
|
|
|
- $token = $request->header('X-Token');
|
|
|
- $user = User::where('token', $token)->first();
|
|
|
- if(!$user) return $this->error(['msg' => '找不到用户']);
|
|
|
- } else {
|
|
|
- $user = User::where('open_id', $data['openId'])->first();
|
|
|
- if(empty($user)) return $this->error(['msg' => '用户不存在,请先绑定账户']);
|
|
|
- }
|
|
|
- $user->update([
|
|
|
- 'nickname' => $data['nickName'],
|
|
|
- 'avatar' => $data['avatarUrl']
|
|
|
- ]);
|
|
|
- Log::info($data);
|
|
|
- $user->updateToken();
|
|
|
- $user->topRole = $user->getTopRole();
|
|
|
- return $this->success(['data' => $user]);
|
|
|
+ if(isset($res['session_key'])) $session_key = $res['session_key'];
|
|
|
+ }
|
|
|
+ if($session_key) {
|
|
|
+ $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
|
|
|
+ if(isset($data['openId'])) {
|
|
|
+ if($request->input('bind')) {
|
|
|
+ $token = $request->header('X-Token');
|
|
|
+ $user = User::where('token', $token)->first();
|
|
|
+ if(!$user) return $this->error(['msg' => '找不到用户']);
|
|
|
+ } else {
|
|
|
+ $user = User::where('open_id', $data['openId'])->first();
|
|
|
+ if(empty($user)) return $this->error(['msg' => '用户不存在,请先绑定账户']);
|
|
|
}
|
|
|
+ $user->update([
|
|
|
+ 'nickname' => $data['nickName'],
|
|
|
+ 'avatar' => $data['avatarUrl']
|
|
|
+ ]);
|
|
|
+ $user->updateToken();
|
|
|
+ $user->topRole = $user->getTopRole();
|
|
|
+ $user->session_key = $res['session_key'];
|
|
|
+ return $this->success(['data' => $user]);
|
|
|
}
|
|
|
}
|
|
|
return $this->error(['msg' => '登陆失败']);
|
|
|
}
|
|
|
|
|
|
+ public function parsePhone(Request $request)
|
|
|
+ {
|
|
|
+ $app = app('wechat.mini_program');
|
|
|
+ $session_key = $request->input('session_key');
|
|
|
+ if(!$session_key && $request->input('code')) {
|
|
|
+ $res = $app->auth->session($request->input('code'));
|
|
|
+ if(isset($res['session_key'])) $session_key = $res['session_key'];
|
|
|
+ }
|
|
|
+ if($session_key) {
|
|
|
+ $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
|
|
|
+ return $this->success(['data' => $data]);
|
|
|
+ }
|
|
|
+ return $this->error(['msg' => '登陆失败']);
|
|
|
+ }
|
|
|
+
|
|
|
public function reset(Request $request)
|
|
|
{
|
|
|
$user = User::where('phone', $request->input('phone'))->first();
|