提交代码
This commit is contained in:
263
app/Http/Controllers/AuthController.php
Normal file
263
app/Http/Controllers/AuthController.php
Normal file
@@ -0,0 +1,263 @@
|
||||
<?php
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\User;
|
||||
use App\Rules\Checkmobile;
|
||||
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;
|
||||
|
||||
class AuthController extends Controller
|
||||
{
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->middleware('auth')->except(['login', 'wechat', 'wechatCallback']);
|
||||
}
|
||||
|
||||
public function register(Request $request)
|
||||
{
|
||||
$user = Auth::user();
|
||||
|
||||
if ($request->isMethod('post')) {
|
||||
$request->validate([
|
||||
'username' => ['required', 'unique:users', new Checkmobile],
|
||||
'password' => 'required|between:6,32|confirmed',
|
||||
'password_confirmation' => 'required|between:6,32',
|
||||
'code' => ['required', 'size:4', function ($attribute, $value, $fail) use ($request) {
|
||||
if ($value != SmsModel::where('mobile', $request->username)->where('used', 0)->latest()->value('code')) {
|
||||
return $fail('验证码不正确');
|
||||
}
|
||||
}],
|
||||
], [
|
||||
'username.required' => '手机号码必须填写',
|
||||
'username.unique' => '手机号已经注册',
|
||||
'code.required' => '验证码必须填写',
|
||||
'code.size' => '验证码长度为:size位',
|
||||
'password.required' => '登录密码必须填写',
|
||||
'password.between' => '登录密码有误',
|
||||
'password.confirmed' => '确认密码与登录密码不一致',
|
||||
'password_confirmation.required' => '确认密码必须填写',
|
||||
'password_confirmation.between' => '确认密码有误',
|
||||
]);
|
||||
|
||||
$user->username = $request->username;
|
||||
$user->password = $request->password;
|
||||
$user->save();
|
||||
return $this->success('设置成功', route('index'));
|
||||
} else {
|
||||
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')) {
|
||||
|
||||
$validator = Validator::make($request->all(), [
|
||||
'username' => 'required|mobile|exists:users',
|
||||
'password' => 'required|between:6,32',
|
||||
], [
|
||||
'username.required' => '手机号码必须填写',
|
||||
'username.mobile' => '手机号码格式不正确',
|
||||
'username.exists' => '手机号码不存在',
|
||||
'password.required' => '登录密码必须填写',
|
||||
'password.between' => '登录密码应在:min-:max位之间',
|
||||
]);
|
||||
|
||||
if ($validator->fails()) {
|
||||
return $this->error($validator->errors()->first());
|
||||
}
|
||||
|
||||
$cert = [
|
||||
'username' => $request->username,
|
||||
'password' => $request->password,
|
||||
];
|
||||
|
||||
if (Auth::attempt($cert, true)) {
|
||||
return $this->success('登录成功', route('index'));
|
||||
} else {
|
||||
return $this->error('用户名或密码不存在');
|
||||
}
|
||||
} else {
|
||||
return view('auth.login');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 微信登录 、微信快速注册 *
|
||||
* 注册完之后,在这里没有办法判断推荐关系
|
||||
*
|
||||
* @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) {
|
||||
if ($request['share_uid']) {
|
||||
session(['parent_id' => $request['share_uid']]);
|
||||
}
|
||||
|
||||
if ($request['r']) {
|
||||
session(['r' => $request['r']]);
|
||||
}
|
||||
$app = app('wechat.official_account');
|
||||
$app['config']->set('oauth.callback', 'login/wechatCallback');
|
||||
return $app->oauth->redirect();
|
||||
} else {
|
||||
return redirect()->route('authlogin');
|
||||
}
|
||||
}
|
||||
|
||||
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' => isset($openUser['subscribe_time']) ? date('Y-m-d H:i:s', $openUser['subscribe_time']) : null,
|
||||
'subscribe_scene' => isset($openUser['subscribe_scene']) ? $openUser['subscribe_scene'] : '',
|
||||
]);
|
||||
|
||||
Auth::login($oldUser, true);
|
||||
if (!$oldUser->username) {
|
||||
return redirect()->route('register');
|
||||
} else {
|
||||
$r = session('r', '');
|
||||
if ($r) {
|
||||
return redirect($r);
|
||||
} else {
|
||||
return redirect()->route('index');
|
||||
|
||||
}
|
||||
}
|
||||
} else {
|
||||
$parent_id = session('parent_id', 0);
|
||||
|
||||
$user = User::create(
|
||||
[
|
||||
'openid' => $weUser->id,
|
||||
'parent_id' => $parent_id,
|
||||
]
|
||||
);
|
||||
|
||||
$user->info()->create([
|
||||
'nickname' => $weUser->getOriginal()['nickname'],
|
||||
'headimgurl' => $weUser->getOriginal()['headimgurl'],
|
||||
'sex' => $weUser->getOriginal()['sex'],
|
||||
'country' => $weUser->getOriginal()['country'],
|
||||
'province' => $weUser->getOriginal()['province'],
|
||||
'city' => $weUser->getOriginal()['city'],
|
||||
'subscribe_at' => isset($openUser['subscribe_time']) ? date('Y-m-d H:i:s', $openUser['subscribe_time']) : null,
|
||||
'subscribe_scene' => isset($openUser['subscribe_scene']) ? $openUser['subscribe_scene'] : '',
|
||||
]);
|
||||
|
||||
Session::forget('parent_id');
|
||||
|
||||
event(new Registered($user));
|
||||
Auth::login($user, true);
|
||||
|
||||
return redirect()->route('register');
|
||||
}
|
||||
/**
|
||||
* 这个注册完成事件,只能把 updateOrCreate 这个方法拆分开来使用了
|
||||
*/
|
||||
} catch (\Exception $e) {
|
||||
return redirect()->route('login');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 退出登录
|
||||
* @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->username;
|
||||
switch ($channel) {
|
||||
case 'FORGOT':
|
||||
$validator = Validator::make($request->all(), [
|
||||
'username' => ['required', new Checkmobile],
|
||||
], [
|
||||
'username.required' => '手机号码必须填写',
|
||||
'username.mobile' => '手机号码格式不正确',
|
||||
'username.exists' => '手机号码不存在',
|
||||
]);
|
||||
break;
|
||||
case 'BIND':
|
||||
// 绑定手机号,要不存在才可以
|
||||
$channel = 'DEFAULT';
|
||||
$validator = Validator::make($request->all(), [
|
||||
'username' => ['required', 'unique:users', new Checkmobile],
|
||||
], [
|
||||
'username.required' => '手机号码必须填写',
|
||||
'username.mobile' => '手机号码格式不正确',
|
||||
'username.unique' => '手机号码已经绑定',
|
||||
]);
|
||||
break;
|
||||
default:
|
||||
$validator = Validator::make($request->all(), [
|
||||
'username' => ['required', new Checkmobile],
|
||||
], [
|
||||
'username.required' => '手机号码必须填写',
|
||||
]);
|
||||
break;
|
||||
}
|
||||
|
||||
if ($validator->fails()) {
|
||||
return $this->error($validator->errors()->first());
|
||||
}
|
||||
|
||||
$res = SmsModel::verify_code($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());
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user