Laravel 다중 도메인 이름(코드 포함)에서 필드 확인 방법 소개
이 글은 Laravel의 다중 도메인 이름(코드 포함)에 대한 소개를 제공합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
서문: 작성자가 웹사이트에 소프트웨어를 제출할 수 있도록 통합 작성자 백엔드가 개발되고 있습니다. 우리는 웹사이트 중 하나에 대한 작성자 백엔드를 개발했으며 이제 이 백엔드를 다른 웹사이트에 제공할 계획입니다. 여기에는 다음과 같은 특징이 있습니다.
우리가 방문하는 도메인 이름이 일관되지 않습니다. 해결 방법은 내 기사 중 하나인 Laravel Routing Research - Domain to Solve Multiple Domain Name Problems를 참조하세요.
기능 분할
시작하기 전에 시스템의 다양한 기능 지점을 분할하고 영향을 받는 지점을 추정해야 합니다.
로그인 및 등록
로그인 및 등록 기능이 가장 먼저 부담을 져야 합니다. 사용자는 등록 시 다른 도메인 이름에 액세스할 수 있습니다. 기록된 ID도 다릅니다. 따라서 다음 처리를 수행해야 합니다.
필드 추가identity
가중치 판단 수행
로그인 확인 수행
데이터 처리
이 내용은 논의되지 않습니다. 사용자의 신원에 따라 호출되는 데이터가 달라집니다.
등록 판단
판단 근거: php artisan make:auth를 사용한 후 기본적으로 이메일을 사용하여 로그인하고 양식 확인에서 이메일을 기본적으로 판단한다는 것을 알고 있습니다. 코드는 다음과 같습니다.
기본 양식 확인:
// 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'], ]); }
기본 로그인 확인 필드
// Path:vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php public function username() { return 'email'; } // 当然可以修改验证字段(看过文档的都知道),注意:登录验证字段必须是在表里面唯一的。
이제 요구 사항을 분석해야 합니다.
단일 사용자 배경에서는 이메일 판단으로 충분하지만 여러 사용자에게는 적합하지 않습니다. 함께 사용하면 충분합니다.
가정: 두 명의 사용자 a와 b에 해당하는 두 개의 도메인 이름 A와 B가 있습니다. 먼저 a와 b가 해당 도메인 이름(사이트)에 속하는지 확인해야 합니다. 이 사용자를 살펴보세요. 반복할지 여부입니다.
아래에서는 Laravel 양식 검증을 사용하여 구현하겠습니다.
필드 추가:
시연의 편의를 위해 make auth로 생성된 마이그레이션 파일을 직접 수정했습니다. 실제 프로젝트에서 직접 수정하지 말고 새로운 마이그레이션을 생성해 주세요. 테이블 구조를 수정하여 필드를 추가하세요
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(); }); }
참고: 이 요구 사항에서는 마이그레이션 파일의 이메일 및 이름 필드를 고유하게 한정할 필요가 없습니다. 해당 필드의 고유성은 독립적이지 않고 종속적이기 때문입니다.
사용자 등록 시뮬레이션, 신원 정보 삽입
// 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', // 模拟用户注册时,插入身份字段值 ]); }
중중 판단 처리
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'], ]); }
테스트
첫 번째 등록의 경우 데이터베이스 스크린샷은 다음과 같습니다.
동일한 신원, 동일한 이메일 주소 테스트
로그인 확인
자격 증명 덮어쓰기, 인증 필드 전달
// Path:app/Http/Controllers/Auth/LoginController.php protected function credentials(Request $request) { $request->merge(['identity' => Controller::getWebPrefix()]); return $request->only($this->username(), 'password', 'identity'); }
[관련 권장 사항: PHP 비디오 튜토리얼]
위 내용은 Laravel 다중 도메인 이름(코드 포함)에서 필드 확인 방법 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

숙련된 PHP 개발자라면 이미 그런 일을 해왔다는 느낌을 받을 것입니다. 귀하는 상당한 수의 애플리케이션을 개발하고, 수백만 줄의 코드를 디버깅하고, 여러 스크립트를 수정하여 작업을 수행했습니다.

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

PHP의 마법 방법은 무엇입니까? PHP의 마법 방법은 다음과 같습니다. 1. \ _ \ _ Construct, 객체를 초기화하는 데 사용됩니다. 2. \ _ \ _ 파괴, 자원을 정리하는 데 사용됩니다. 3. \ _ \ _ 호출, 존재하지 않는 메소드 호출을 처리하십시오. 4. \ _ \ _ get, 동적 속성 액세스를 구현하십시오. 5. \ _ \ _ Set, 동적 속성 설정을 구현하십시오. 이러한 방법은 특정 상황에서 자동으로 호출되어 코드 유연성과 효율성을 향상시킵니다.
