0
0
Files
Babyclass/app/Http/Controllers/AuthController.php
2020-08-04 10:09:42 +08:00

432 lines
16 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Rules\Checkmobile;
use App\User;
use Auth;
use Illuminate\Auth\Events\Login;
use Illuminate\Auth\Events\Registered;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Session;
use Illuminate\Support\Facades\View;
use RuLong\Sms\Models\Sms as SmsModel;
use Validator;
use \Illuminate\Support\Facades\URL;
class AuthController extends Controller
{
public function __construct()
{
$this->middleware('guest')->except(['logout', 'smsCode']);
}
public function register(Request $request)
{
if ($request->isMethod('post')) {
$request->validate([
'mobile' => ['required', 'unique:users', new Checkmobile],
'verify' => ['required', 'size:4', function ($attribute, $value, $fail) use ($request) {
if ($value != SmsModel::where('mobile', $request->mobile)->where('used', 0)->latest()->value('code')) {
return $fail('验证码不正确');
}
}],
'password' => 'required|between:6,32|confirmed',
'password_confirmation' => 'required|between:6,32',
], [
'mobile.required' => '手机号码必须填写',
'mobile.unique' => '手机号已经注册',
'verify.required' => '验证码必须填写',
'verify.size' => '验证码长度为:size位',
'password.required' => '登录密码必须填写',
'password.between' => '登录密码有误',
'password.confirmed' => '确认密码与登录密码不一致',
'password_confirmation.required' => '确认密码必须填写',
'password_confirmation.between' => '确认密码有误',
]);
$Original = session('Original');
if ($Original) {
$app = app('wechat.official_account');
$openUser = $app->user->get($Original['openid']);
$Original['subscribe_at'] = $openUser->subscribe_time;
$Original['subscribe_scene'] = $openUser->subscribe_scene;
$Original['qr_scene'] = $openUser->qr_scene;
$Original['qr_scene_str'] = $openUser->qr_scene_str;
}
$parent_id = session('parent_id', 0);
$seller_id = 0;
if ($parent_id) {
$parent = User::find($parent_id);
$seller_id = $parent->seller_id ?? '0';
}
$findUser = User::where('openid', $Original['openid'])->first();
if ($findUser) {
return $this->success('注册失败:此微信已被使用');
}
$user = User::updateOrCreate(
[
'openid' => $Original['openid'],
'mobile' => $request->mobile,
'seller_id' => $seller_id,
'password' => $request->password,
],
[
'parent_id' => session('parent_id', 0),
'info' => [
'nickname' => $Original['nickname'],
'headimgurl' => $Original['headimgurl'],
'sex' => $Original['sex'],
'country' => $Original['country'],
'province' => $Original['province'],
'city' => $Original['city'],
'subscribe_at' => $Original['subscribe_at'] ?? null,
'subscribe_scene' => $Original['subscribe_scene'] ?? null,
'qr_scene' => $Original['qr_scene'] ?? null,
'qr_scene_str' => $Original['qr_scene_str'] ?? null,
],
]
);
Session::forget('parent_id');
// 实现注册完自动登录
Auth::login($user);
event(new Registered($user));
return $this->success('注册成功', route('baby'));
} else {
if (Session::has('Original') === false) {
$app = app('wechat.official_account');
$app['config']->set('oauth.callback', 'register/auth/wechat');
return $app->oauth->redirect();
}
return view('auth.register');
}
}
/**
* 用户登录 *
* @Author:<C.Jason>
* @Date:2018-11-07T13:47:02+0800
* @param Request $request
*/
public function login(Request $request)
{
if ($request->isMethod('POST')) {
$Original = session('Original');
$validator = Validator::make($request->all(), [
'mobile' => 'required|mobile|exists:users',
'password' => 'required|between:6,32',
], [
'mobile.required' => '手机号码必须填写',
'mobile.mobile' => '手机号码格式不正确',
'mobile.exists' => '手机号码不存在',
'password.required' => '登录密码必须填写',
'password.between' => '登录密码应在:min-:max位之间',
]);
if ($validator->fails()) {
return $this->error($validator->errors()->first());
}
$cert = [
'mobile' => $request->mobile,
'password' => $request->password,
];
if (Auth::attempt($cert, true)) {
$reback = $request->r ?: route('index.index');
return $this->success('登录成功', $reback);
} else {
return $this->error('用户名或密码不存在');
}
} else {
return view('auth.login');
}
}
public function regwechat()
{
$app = app('wechat.official_account');
$weUser = $app->oauth->user();
$Original = $weUser->getOriginal();
Session::put('Original', $Original);
return redirect()->route('register');
}
/**
* 微信登录 、微信快速注册 *
* 注册完之后,在这里没有办法判断推荐关系
*
* @Author:<C.Jason>
* @Date:2018-11-07T13:44:34+0800
* @param Request $request
*/
public function wechat(Request $request)
{
if (strpos($request->server('HTTP_USER_AGENT'), 'MicroMessenger') !== false) {
$app = app('wechat.official_account');
$app['config']->set('oauth.callback', 'login/wechatCallback');
return $app->oauth->redirect();
} else {
return redirect()->route('login');
}
}
public function wechatCallback(Request $request)
{
try {
$app = app('wechat.official_account');
$weUser = $app->oauth->user();
$callback = $request['callback'] ?? '';
$openUser = $app->user->get($weUser->id);
$oldUser = User::where('openid', $weUser->id)->first();
if ($oldUser) {
$oldUser->info->update([
'headimgurl' => $weUser->getOriginal()['headimgurl'],
'sex' => $weUser->getOriginal()['sex'],
'country' => $weUser->getOriginal()['country'],
'province' => $weUser->getOriginal()['province'],
'city' => $weUser->getOriginal()['city'],
'subscribe_at' => $openUser->subscribe_time ?? null,
'subscribe_scene' => $openUser->subscribe_scene ?? '',
'qr_scene' => $openUser->qr_scene ?? '',
'qr_scene_str' => $openUser->qr_scene_str ?? '',
]);
Auth::login($oldUser, true);
if ($callback) {
$callback = base64_decode($callback);
return redirect($callback);
} else {
return redirect()->route('user.index');
}
} else {
// $user = User::updateOrCreate(
// [
// 'openid' => $weUser->id,
// ],
// [
// 'parent_id' => session('parent_id', 1),
// 'info' => [
// 'nickname' => $weUser->getOriginal()['nickname'],
// 'headimgurl' => $weUser->getOriginal()['headimgurl'],
// 'sex' => $weUser->getOriginal()['sex'],
// 'country' => $weUser->getOriginal()['country'],
// 'province' => $weUser->getOriginal()['province'],
// 'city' => $weUser->getOriginal()['city'],
// 'source' => 'Web',
// 'subscribe_at' => $openUser->subscribe_time ?? null,
// 'subscribe_scene' => $openUser->subscribe_scene ?? '',
// 'qr_scene' => $openUser->qr_scene ?? '',
// 'qr_scene_str' => $openUser->qr_scene_str ?? '',
// ],
// ]
// );
// event(new Registered($user));
// Auth::login($user, true);
// if ($callback) {
// $callback = base64_decode($callback);
// return redirect($callback);
// } else {
// return redirect()->route('vip.create');
// }
return redirect()->route('register');
}
/**
* 这个注册完成事件,只能把 updateOrCreate 这个方法拆分开来使用了
*/
} catch (\Exception $e) {
return redirect()->route('login');
}
}
/**
* 验证码登录 *
* @Author:<C.Jason>
* @Date:2018-11-07T13:46:10+0800
* @param Request $request
*/
public function bycode(Request $request)
{
if ($request->isMethod('POST')) {
$validator = Validator::make($request->all(), [
'mobile' => 'required|mobile|exists:users',
'code' => 'required|sms_check:mobile,BYCODE',
], [
'mobile.required' => '手机号码必须填写',
'mobile.mobile' => '手机号码格式不正确',
'mobile.exists' => '手机号码不存在',
'code.required' => '验证码必须填写',
'code.sms_check' => '验证码不正确',
]);
if ($validator->fails()) {
return $this->error($validator->errors()->first());
}
$user = User::where('mobile', $request->mobile)->first();
try {
Auth::login($user, true);
return $this->success('登录成功', route('user.index'));
} catch (\Exception $e) {
return $this->error($e->getMessage());
}
} else {
return view('auth.bycode');
}
}
/**
* 找回密码
* @Author:<C.Jason>
* @Date:2018-11-07T13:46:34+0800
* @param Request $request
*/
public function forgot(Request $request)
{
if ($request->isMethod('POST')) {
$validator = Validator::make($request->all(), [
'mobile' => 'required|mobile|exists:users',
'code' => 'required|sms_check:mobile,FORGOT',
], [
'mobile.required' => '手机号码必须填写',
'mobile.mobile' => '手机号码格式不正确',
'mobile.exists' => '手机号码不存在',
'code.required' => '验证码必须填写',
'code.sms_check' => '验证码不正确',
]);
if ($validator->fails()) {
return $this->error($validator->errors()->first());
}
$request->session()->put('reset_mobile', $request->mobile);
return $this->success('身份验证成功', Url::temporarySignedRoute('forgot.reset', now()->addHour()));
} else {
return view('auth.forgot');
}
}
public function reset(Request $request)
{
if ($request->isMethod('POST')) {
$validator = Validator::make($request->all(), [
'password' => 'required|between:6,32',
], [
'password.required' => '登录密码必须填写',
'password.mobile' => '登录密码应在:min-:max位之间',
]);
if ($validator->fails()) {
return $this->error($validator->errors()->first());
}
$reset_mobile = $request->session()->pull('reset_mobile');
$password = $request->password;
try {
$user = User::where('mobile', $reset_mobile)->first();
$user->password = $password;
$user->save();
return $this->success('密码重置成功', route('login'));
} catch (\Exception $e) {
return $this->success('密码重置失败', route('forgot'));
}
} else {
return view('auth.reset');
}
}
/**
* 退出登录
* @Author:<C.Jason>
* @Date:2018-11-07T13:46:45+0800
*/
public function logout()
{
Auth::logout();
session()->flush();
return redirect()->route('login');
}
/**
* 发送验证码
* @Author:<C.Jason>
* @Date:2018-11-07T13:49:55+0800
* @return
*/
public function smsCode(Request $request)
{
$channel = $request->channel;
$mobile = $request->mobile;
switch ($channel) {
case 'BYCODE':
case 'FORGOT':
// 验证码登录,必须要手机号存在才行
$validator = Validator::make($request->all(), [
'mobile' => ['required', 'exists:users', new Checkmobile],
], [
'mobile.required' => '手机号码必须填写',
'mobile.mobile' => '手机号码格式不正确',
'mobile.exists' => '手机号码不存在',
]);
break;
case 'BIND':
// 绑定手机号,要不存在才可以
$validator = Validator::make($request->all(), [
'mobile' => ['required', 'unique:users', new Checkmobile],
], [
'mobile.required' => '手机号码必须填写',
'mobile.mobile' => '手机号码格式不正确',
'mobile.unique' => '手机号码已经绑定',
]);
break;
case 'BINDLast':
$channel = 'DEFAULT';
$validator = Validator::make($request->all(), [
'mobile' => 'required|mobile',
], [
'mobile.required' => '手机号码必须填写',
'mobile.mobile' => '手机号码格式不正确',
]);
break;
default:
$validator = Validator::make($request->all(), [
'mobile' => ['required', new Checkmobile],
], [
'mobile.required' => '手机号码必须填写',
]);
break;
}
if ($validator->fails()) {
return $this->error($validator->errors()->first());
}
$res = SmsModel::verify_code($request->mobile);
if ($res !== true) {
return $this->error($res);
}
try {
$code = \Sms::send($mobile, $channel);
$config = config('rulong_sms');
if ($config['debug'] != true) {
return $this->success('验证码发送成功');
} else {
return $this->success('验证码发送成功' . $code);
}
} catch (\Exception $e) {
return $this->error($e->getMessage());
}
}
}