Résoudre Laravel pour implémenter l'authentification multi-champs des utilisateurs

巴扎黑
Libérer: 2023-03-16 07:28:02
original
1230 Les gens l'ont consulté

J'ai récemment rencontré un problème au travail qui nécessitait une vérification multi-champs. Je l'ai finalement résolu en recherchant des informations pertinentes. L'article suivant vous présente principalement la solution sur la façon dont Laravel implémente l'authentification multi-champs des utilisateurs. L'introduction du code est très détaillée. Les amis qui en ont besoin peuvent s'y référer.

Avant-propos

Cet article présente principalement le contenu pertinent sur l'authentification multi-champs des utilisateurs Laravel et le partage pour votre référence et votre étude. Mots suivants Pas grand chose à dire, jetons un œil à l'introduction détaillée.

Solution :

  • Pas plus de deux champs de connexion (solution simple)

  • Les champs de connexion sont supérieurs ou égaux à trois (relativement compliqué)

Les champs de connexion ne sont pas supérieurs à deux

J'ai vu une solution relativement simple en ligne, mais elle ne résout pas la validation des deux champs :


filter_var($request->input('login'), FILTER_VALIDATE_EMAIL) ? 'email' : 'name'
Copier après la connexion

Filtre le contenu du formulaire dans la demande pour distinguer le nom d'utilisateur. Les inconvénients sont évidents. Si l'autre n'est pas l'e-mail, vous serez aveuglé... Voici une autre solution générale :

Réécrivez la méthode de connexion dans 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);
}
Copier après la connexion

Vous pouvez voir que même si cela peut résoudre le problème, cela est évidemment contraire au style élégant de Laravel et a coûté tellement cher que je vais partager ma solution avec vous ci-dessous. .

Champs de connexion supérieurs ou égaux à trois (relativement compliqués)

Vous devez d'abord implémenter vous-même une implémentation d'IlluminateContractsAuthUserProvider. Pour plus de détails, veuillez vous référer à Ajout d'un fournisseur d'utilisateurs personnalisé, mais j'aime être paresseux, hérite directement d'EloquentUserProvider et remplace la méthode 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();
}
Copier après la connexion

Remarque : le sera. soyez $query->where($key, $value); Changez-le simplement en $query->orWhere($key, $value);  !

Ensuite, vous devez enregistrer un UserProvider personnalisé :


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'));
  });
 }
}
Copier après la connexion

Enfin, nous modifions la configuration de auth.php et c'est fait :


'providers' => [
 'users' => [
  'driver' => 'eloquent',
  'model' => App\Models\User::class,
 ],

  'custom' => [
   'driver' => 'custom',
   'model' => App\Models\User::class,
  ],
],
Copier après la connexion

Changez le fournisseur du tableau Web par la coutume précédemment enregistrée


'guards' => [
 'web' => [
  'driver' => 'session',
  'provider' => 'custom',
 ],

 'api' => [
  'driver' => 'passport',
  'provider' => 'users',
 ],
],
Copier après la connexion

Maintenant, même si toi Ça marche bien dans plusieurs domaines...

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!