이 글은 주로 Laravel에서 다중 필드 사용자 인증 구현 문제를 해결하는 방법을 소개합니다. 이제 필요한 친구들이 참고할 수 있도록 공유하겠습니다.
최근 직장에서 문제가 발생했습니다. 다중필드 인증이 필요한 부분을 관련 정보를 검색하여 최종적으로 해결하였습니다. 다음 글에서는 라라벨이 사용자 다중필드 인증을 구현하는 방법에 대한 해결 방법을 주로 샘플 코드를 통해 소개합니다. 아래를 참고하시면 됩니다.
머리말
이 글은 주로 Laravel 사용자 다중 필드 인증에 대한 관련 내용을 소개하며 참고 및 학습을 위해 공유합니다. 아래에서는 자세한 내용을 살펴보겠습니다. 소개. SOLUSTION : SIGHT SOLFICE FILDS (간단한 솔루션) 2 개 이상의 로그인 필드 (상대적으로 복잡한)
2 개 이상의 로그인 필드가 없습니다.
인터넷에서 비교적 간단한 솔루션을 보았지만 두 필드의 확인을 모두 해결할 수는 없습니다.
filter_var($request->input('login'), FILTER_VALIDATE_EMAIL) ? 'email' : 'name'
LoginController에서 로그인 방법을 다시 작성하세요
public function login(Requests $request) { //假设字段是 email if ($this->guard()->attempt($request->only('email', 'password'))) { return $this->sendLoginResponse($request); } //假设字段是 mobile if ($this->guard()->attempt($request->only('mobile', 'password'))) { return $this->sendLoginResponse($request); } //假设字段是 username if ($this->guard()->attempt($request->only('username', 'password'))) { return $this->sendLoginResponse($request); } return $this->sendFailedLoginResponse($request); }
문제는 해결될 수 있지만 분명히 Laravel의 우아한 스타일에 어긋납니다. 많은 어려움을 겪은 후 해결책을 여러분과 공유하겠습니다.
로그인 필드가 3보다 크거나 같은 경우(상대적으로 복잡함)
먼저 IlluminateContractsAuthUserProvider 구현을 직접 구현해야 합니다. 자세한 내용은 맞춤 사용자 공급자 추가를 참조하세요. , 그래서 EloquentUserProvider를 직접 상속하고 RetrieveByCredentials 메소드를 다시 작성했습니다:
public function retrieveByCredentials(array $credentials)
{
if (empty($credentials)) {
return;
}
// First we will add each credential element to the query as a where clause.
// Then we can execute the query and, if we found a user, return it in a
// Eloquent User "model" that will be utilized by the Guard instances.
$query = $this->createModel()->newQuery();
foreach ($credentials as $key => $value) {
if (! Str::contains($key, 'password')) {
$query->orWhere($key, $value);
}
}
return $query->first();
}
참고:
replace
!class AuthServiceProvider extends ServiceProvider { /** * 注册任何应用认证/授权服务。 * * @return void */ public function boot() { $this->registerPolicies(); Auth::provider('custom', function ($app, array $config) { // 返回 Illuminate\Contracts\Auth\UserProvider 实例... return new CustomUserProvider(new BcryptHasher(), config('auth.providers.custom.model')); }); } }
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\Models\User::class,
],
'custom' => [
'driver' => 'custom',
'model' => App\Models\User::class,
],
],
$query->where($key, $value);
改为 $query->orWhere($key, $value);
웹 배열 공급자를 등록된 공급자로 변경합니다. 이전에 custom
'guards' => [ 'web' => [ 'driver' => 'session', 'provider' => 'custom', ], 'api' => [ 'driver' => 'passport', 'provider' => 'users', ], ],
Laravel 5.4에서 다중 필드 로그인을 구현하는 방법에 대해
위 내용은 사용자 다중 필드 인증을 구현하기 위해 Laravel을 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!