>  기사  >  백엔드 개발  >  사용자 다중 필드 인증을 구현하기 위해 Laravel을 해결하는 방법

사용자 다중 필드 인증을 구현하기 위해 Laravel을 해결하는 방법

不言
不言원래의
2018-06-13 16:46:04889검색

이 글은 주로 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

!


그런 다음 사용자 정의 UserProvider를 등록해야 합니다.

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'));
  });
 }
}

마지막으로 auth.php의 구성을 수정하면 완료됩니다.

'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',
 ],
],

이제 여러 분야가 있어도...

위 내용은 이 글의 전체 내용입니다. 더 많은 관련 내용을 보시려면 주목해주세요. PHP 중국어 웹사이트!

관련 권장 사항:

Laravel 5.4에서 다중 필드 로그인을 구현하는 방법에 대해

위 내용은 사용자 다중 필드 인증을 구현하기 위해 Laravel을 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.