Maison > cadre php > Laravel > Introduction aux méthodes de vérification de champ sous les noms de domaines multiples Laravel (avec code)

Introduction aux méthodes de vérification de champ sous les noms de domaines multiples Laravel (avec code)

不言
Libérer: 2019-04-04 11:34:46
avant
2486 Les gens l'ont consulté

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

Deuxièmement. , chaque site a des exigences différentes pour le backend. Les exigences sont les mêmes, c'est-à-dire qu'un arrière-plan est utilisé par N stations.

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

Champ de validation de connexion par défaut

// Path:vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php
public function username()
{
    return 'email';
}
// 当然可以修改验证字段(看过文档的都知道),注意:登录验证字段必须是在表里面唯一的。
Copier après la connexion

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

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', // 模拟用户注册时,插入身份字段值
    ]);
}
Copier après la connexion

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

Test

Effectuer la première inscription, la capture d'écran de la base de données est la suivante :

Introduction aux méthodes de vérification de champ sous les noms de domaines multiples Laravel (avec code)

Une deuxième fois, même email, identité différente :

Introduction aux méthodes de vérification de champ sous les noms de domaines multiples Laravel (avec code)

Même identité, même email test

Introduction aux méthodes de vérification de champ sous les noms de domaines multiples Laravel (avec code)

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

[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!

Étiquettes associées:
source:segmentfault.com
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