Cet article vous apporte une introduction à la méthode de vérification de champ sous le nom multi-domaine de Laravel (avec code). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.
Avant-propos : Un backend d'auteur unifié est en cours de développement pour permettre aux auteurs de soumettre des logiciels au site Web. Nous avons développé un backend d'auteur pour l'un des sites Web, et nous prévoyons maintenant de fournir ce backend à d'autres sites Web. Il présente les caractéristiques suivantes :
Les noms de domaine que nous visitons sont incohérents. Pour la solution, voir l'un de mes articles, Recherche de routage Laravel sur le domaine pour résoudre le problème des noms de domaine multiples
Répartition des fonctions
Avant de commencer, nous devons diviser les différents points fonctionnels du système et estimer les points affectés :
Connectez-vous et inscrivez-vous
La fonction d'enregistrement de connexion est la première à en faire les frais. Nous avons besoin que les utilisateurs accèdent à différents noms de domaine et enregistrent différentes identités lors de l'enregistrement. Nous devons donc effectuer le traitement suivant :
Ajouter des champsidentity
Effectuer un jugement de poids
Effectuer une vérification de connexion
Traitement des données
Ceci ne sera pas abordé. Selon l'identité de l'utilisateur, les données appelées sont également différentes.
Jugement d'inscription
Base du jugement : nous savons qu'après avoir utilisé php artisan make:auth, l'e-mail est utilisé pour se connecter par défaut, et l'e-mail est jugé par défaut dans vérification du formulaire. Le code est le suivant :
Validation du formulaire par défaut :
// Path:app/Http/Controllers/Auth/RegisterController.php protected function validator(array $data) { return Validator::make($data, [ 'name' => ['required', 'string', 'max:255'], 'email' => ['required', 'string', 'email', 'max:255', 'unique:users'], 'password' => ['required', 'string', 'min:8', 'confirmed'], ]); }
Champ de validation de connexion par défaut
// Path:vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php public function username() { return 'email'; } // 当然可以修改验证字段(看过文档的都知道),注意:登录验证字段必须是在表里面唯一的。
Nous devons maintenant analyser nos exigences :
Après utilisateur unique À Taichung, le courrier électronique suffit pour effectuer de lourdes tâches, mais il ne suffit pas que plusieurs utilisateurs l'utilisent ensemble.
Hypothèse : Nous avons deux noms de domaine A et B, correspondant à deux utilisateurs a et b. Nous devons d'abord stocker a et b dans une table. Tout d'abord, nous déterminons si a et b appartiennent à ce nom de domaine (site). Deuxièmement, consultez Cet utilisateur est-il un doublon ?
Utilisons la vérification du formulaire Laravel pour l'implémenter ci-dessous :
Ajouter des champs :
Pour faciliter la démonstration, je l'ai directement modifié sur le fichier de migration généré par make auth Veuillez ne pas le modifier directement. dans le projet réel. , mais en créant un nouveau fichier de migration et en ajoutant des champs en modifiant la structure de la table
public function up() { Schema::create('users', function (Blueprint $table) { $table->bigIncrements('id'); $table->string('name'); $table->string('email'); // 去掉原来的unique $table->string('identity'); // 增加的字段 $table->timestamp('email_verified_at')->nullable(); $table->string('password'); $table->rememberToken(); $table->timestamps(); }); }
Remarque : Dans cette exigence, nous n'avons pas besoin de l'e-mail et du nom. champs du fichier de migration Créez des qualifications uniques, car leur unicité est dépendante et non indépendante.
Simuler l'enregistrement de l'utilisateur, insérer des informations d'identité
// Path: app/Http/Controllers/Auth/RegisterController.php protected function create(array $data) { return User::create([ 'name' => $data['name'], 'email' => $data['email'], 'password' => Hash::make($data['password']), 'identity' => 'pcsoft', // 模拟用户注册时,插入身份字段值 ]); }
Effectuer un traitement de jugement sérieux
protected function validator(array $data) { return Validator::make($data, [ 'name' => ['required', 'string', 'max:255'], 'email' => ['required', 'string', 'email', 'max:255', Rule::unique('users')->where(function ($query) { $query->where('identity', '=', 'onlinedown'); })], // 这句话的意思:按照什么条件对 users 表中的 email 去重,我们需要按照身份字段等于我们访问的域名对 email 去重, 'password' => ['required', 'string', 'min:8', 'confirmed'], ]); }
Test
Effectuer la première inscription, la capture d'écran de la base de données est la suivante :Même identité, même email test
Vérification de connexion
Écraser les informations d'identification et transmettre dans le champ d'authentification
// Path:app/Http/Controllers/Auth/LoginController.php protected function credentials(Request $request) { $request->merge(['identity' => Controller::getWebPrefix()]); return $request->only($this->username(), 'password', 'identity'); }
[Recommandations associées : Tutoriel vidéo PHP】
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!