6
0
Fork 0

用户注册时,短信验证码校验

release
李静 2021-11-24 16:29:23 +08:00
parent 6a10add37a
commit 43b1046ae4
2 changed files with 52 additions and 15 deletions

View File

@ -5,11 +5,12 @@ namespace App\Http\Controllers\Api\V1\Auth;
use App\Constants\Device; use App\Constants\Device;
use App\Exceptions\BizException; use App\Exceptions\BizException;
use App\Http\Controllers\Api\V1\Controller; use App\Http\Controllers\Api\V1\Controller;
use App\Http\Requests\Api\V1\RegisterRequest;
use App\Models\SmsCode;
use App\Models\User; use App\Models\User;
use App\Models\UserInfo; use App\Models\UserInfo;
use Illuminate\Http\Request; use App\Services\SmsCodeService;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
use Illuminate\Validation\Rule;
use Throwable; use Throwable;
class RegisterController extends Controller class RegisterController extends Controller
@ -17,25 +18,25 @@ class RegisterController extends Controller
/** /**
* 注册 * 注册
* *
* @param \Illuminate\Http\Request $request * @param \App\Http\Requests\Api\V1\RegisterRequest $request
* @return \Illuminate\Http\Response * @param \App\Services\SmsCodeService $smsCodeService
* @return \Illuminate\Http\JsonResponse
*/ */
public function __invoke(Request $request) public function __invoke(RegisterRequest $request, SmsCodeService $smsCodeService)
{ {
$request->validate([ $input = $request->validated();
'phone' => ['bail', 'required', Rule::unique(User::class)],
'password' => ['bail', 'required', 'string', 'min:6', 'max:32'],
'verify_code' => ['bail', 'required', 'string'],
'code' => ['bail', 'nullable', 'string'],
]);
// @todo 验证短信验证码 $smsCodeService->validate(
$input['phone'],
SmsCode::TYPE_REGISTER,
$input['verify_code']
);
$inviter = null; $inviter = null;
if ( if (
$request->filled('code') $request->filled('code') &&
&& is_null($inviter = UserInfo::where('code', $request->input('code'))->first()) is_null($inviter = UserInfo::where('code', $input['code'])->first())
) { ) {
throw new BizException(__('Invalid invitation code')); throw new BizException(__('Invalid invitation code'));
} }
@ -46,7 +47,7 @@ class RegisterController extends Controller
try { try {
DB::beginTransaction(); DB::beginTransaction();
$user = new User($request->only(['phone', 'password'])); $user = new User($input);
$user->phone_verified_at = $time; $user->phone_verified_at = $time;
$user->register_ip = $ip; $user->register_ip = $ip;
$user->last_login_at = $time; $user->last_login_at = $time;

View File

@ -0,0 +1,36 @@
<?php
namespace App\Http\Requests\Api\V1;
use App\Models\User;
use App\Rules\PhoneNumber;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Validation\Rule;
class RegisterRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
'phone' => ['bail', 'required', new PhoneNumber(), Rule::unique(User::class)],
'password' => ['bail', 'required', 'string', 'min:6', 'max:32'],
'verify_code' => ['bail', 'required', 'string'],
'code' => ['bail', 'nullable', 'string'],
];
}
}