Heim >PHP-Framework >Laravel >Einführung in Feldüberprüfungsmethoden unter Laravel mit mehreren Domänennamen (mit Code)

Einführung in Feldüberprüfungsmethoden unter Laravel mit mehreren Domänennamen (mit Code)

不言
不言nach vorne
2019-04-04 11:34:462478Durchsuche

Dieser Artikel bietet Ihnen eine Einführung in die Feldverifizierungsmethode unter dem Multi-Domain-Namen (mit Code). Ich hoffe, dass er für Sie hilfreich ist.

Vorwort: Es wird ein einheitliches Autoren-Backend entwickelt, damit Autoren Software auf der Website einreichen können. Wir haben für eine der Websites ein Autoren-Backend entwickelt und planen nun, dieses Backend auch anderen Websites zur Verfügung zu stellen. Es weist die folgenden Merkmale auf:

Die von uns besuchten Domänennamen sind inkonsistent. Die Lösung finden Sie in einem meiner Artikel: Laravel-Routing-Recherche zu Domänen zur Lösung des Problems mehrerer Domänennamen

Zweitens Jeder Standort hat unterschiedliche Anforderungen an das Backend. Die Anforderungen sind gleich, das heißt, ein Hintergrund wird von N Stationen verwendet.

Funktionsaufteilung

Bevor wir beginnen, müssen wir die verschiedenen Funktionspunkte des Systems aufteilen und die betroffenen Punkte abschätzen:

Anmelden und registrieren

Die Login-Registrierungsfunktion ist die erste, die die Hauptlast trägt. Wir benötigen, dass Benutzer bei der Registrierung auf unterschiedliche Domainnamen zugreifen und unterschiedliche Identitäten erfassen. Daher müssen wir die folgende Verarbeitung durchführen:

Felder hinzufügenidentity

Gewichtsbeurteilung durchführen

Anmeldeüberprüfung durchführen

Datenverarbeitung

Hierauf wird nicht eingegangen. Abhängig von der Identität des Nutzers sind auch die abgerufenen Daten unterschiedlich.

Registrierungsbeurteilung

Beurteilungsgrundlage: Wir wissen, dass nach der Verwendung von php artisan make:auth standardmäßig E-Mail zum Anmelden verwendet wird und E-Mail standardmäßig beurteilt wird Formularüberprüfung. Der Code lautet wie folgt:

Standardformularvalidierung:

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

Standard-Anmeldevalidierungsfeld

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

Jetzt müssen wir unsere Bedürfnisse analysieren:
In einem Einzelbenutzerhintergrund , E-Mail-Urteil Schwer genug ist genug, aber nicht genug für mehrere Benutzer.
Annahme: Wir haben zwei Domänennamen A und B, die zwei Benutzern a und b entsprechen. Wir müssen a und b in einer Tabelle speichern. Zuerst bestimmen wir, ob a und b zu diesem Domänennamen (Site) gehören. Zweitens siehe Ist dieser Benutzer ein Duplikat?
Verwenden wir die Laravel-Formularüberprüfung, um es unten zu implementieren:

Felder hinzufügen:
Zur Vereinfachung der Demonstration habe ich es direkt in der von make auth generierten Migrationsdatei geändert. Bitte ändern Sie es nicht direkt im eigentlichen Projekt, aber durch Erstellen einer neuen Migrationsdatei und Hinzufügen von Feldern durch Ändern der Tabellenstruktur

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

Hinweis: In dieser Anforderung müssen wir die E-Mail-Adresse und den Namen nicht eindeutig angeben Felder in der Migrationsdatei. Qualifiziert, da ihre Einzigartigkeit abhängig und nicht unabhängig ist.

Benutzerregistrierung simulieren, Identitätsinformationen einfügen

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

zur Beurteilungsverarbeitung

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

Für die erste Registrierung lautet der Datenbank-Screenshot wie folgt:

Einführung in Feldüberprüfungsmethoden unter Laravel mit mehreren Domänennamen (mit Code)

Zum zweiten Mal registrieren, gleiche E-Mail, andere Identität:

Einführung in Feldüberprüfungsmethoden unter Laravel mit mehreren Domänennamen (mit Code)

Gleiche Identität, gleicher E-Mail-Test

Einführung in Feldüberprüfungsmethoden unter Laravel mit mehreren Domänennamen (mit Code)

Anmeldebestätigung

Anmeldeinformationen überschreiben und Authentifizierungsfeld übergeben

// Path:app/Http/Controllers/Auth/LoginController.php
protected function credentials(Request $request)
{
    $request->merge(['identity' => Controller::getWebPrefix()]);
    return $request->only($this->username(), 'password', 'identity');
}

[Verwandte Empfehlungen: PHP-Video-Tutorial]

Das obige ist der detaillierte Inhalt vonEinführung in Feldüberprüfungsmethoden unter Laravel mit mehreren Domänennamen (mit Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen