Register
고급 템플릿에서 frontend/index.php?r=site%2Fsignup 페이지를 입력하면 프레임워크의 등록 페이지를 볼 수 있습니다
사용자 이름, 이메일, 비밀번호를 입력한 후, Signup을 클릭하면 형식이 올바르지 않은 경우 frontend/models/SignuForm의 rule() 함수가 예비 확인을 수행합니다. 모든 형식이 올바른 후에는 데이터가 frontend/controllers/SiteController의 actionSignup() 함수로 전송됩니다. frontend/models/SignupForm의 signup() 함수에서 사용자가 입력한 등록 정보를 로드합니다.
아래 인용된 텍스트는 해당 함수의 구체적인 내용을 설명하기 위한 것입니다. 읽지 않으면 영향을 미치지 않습니다. 전체. 텍스트 접기 기능이 없기 때문에 아래와 동일하게 인용 방법을 사용합니다.
if (!$this->validate()) { return null; }
signup() 함수는 먼저 yii2/base/Model에서 검증() 함수를 호출하여 확인합니다
첫 번째 단계는 지우는 것입니다. 사용자 입력
if ($clearErrors) { $this->clearErrors(); }
을 입력할 때 frontend/models/SignuForm에서 rule() 함수를 사용할 때 오류 메시지가 발생합니다. 두 번째 단계인 beforeValidate() 함수는 beforeValidate 이벤트를 트리거하고 true를 반환합니다
세 번째 단계는 시나리오를 설정하는 것입니다. 기본값은 default입니다
네 번째 단계, 여기의 $attributeNames가 null이므로
$attributeNames = $this->activeAttributes();
실행 후 반환
array(3) { [0]=> string(8) "username" [1]=> string(5) "email" [2]=> string(8) >"password" }
5단계, $ this->getActiveValidators()는 frontend/의 규칙()에서 11개의 유효성 검사 규칙을 가져옵니다. 검증을 위한 verifyAttributes()용 models/SignuForm
여섯 번째 단계는 afterValidate() 함수를 실행하여 afterValidate 이벤트를 트리거하는 것입니다
마지막으로 모든 검증이 통과되면 $this->hasErrors()는 false이므로 함수는 마침내 true를 반환합니다
데이터 테이블의 사용자 필드를 살펴보겠습니다
사용자가 사용자 이름, 비밀번호 및 이메일을 입력했는데, Yii2 프레임워크는 어떻게 다른 필드를 생성하는지 살펴보겠습니다. SignupFrom의 signup 함수에서 비밀번호 생성은 setPassword 함수입니다. 이 함수는 common/models/User에 있습니다. setPassword 함수는 yii2/base/Security 함수의 각 규칙에 대해 generatePasswordHash를 호출합니다.
if (function_exists('password_hash')) { /** @noinspection PhpUndefinedConstantInspection */ return password_hash($password, PASSWORD_DEFAULT, ['cost' => $cost]); }
있다면, 암호화는 패스워드_해시 함수를 사용하세요. PHP에 패스워드_해시 함수가 없다면, 암호화는 crypt 함수를 사용하세요. 결국 PHP 5.5 이하 버전과 호환된다는 것입니다. 5.5보다 큰 버전에서만 비밀번호 해시 기능이 시작됩니다
common/models/User의 signup() 함수는 비밀번호를 암호화한 후 계속해서 인증 키를 생성합니다. 인증 키는 사용자가 기억하기를 클릭할 때의 확인 정보입니다. 인증 키를 생성하는 방법은 다음과 같습니다. yii2/base/Security에서 generateRandomString 및 generateRandomString은 generateRandomKey 함수를 호출합니다. PHP 버전이 5.2~5.6 또는 7인 경우 random_bytes를 사용하여 32바이트 문자열을 생성합니다. 아닙니다. 시스템이 Windows이고 OpenSSL이 설치된 경우 openssl_random_pseudo_bytes 함수가 호출되어 OpenSSL이 설치되지 않은 경우 mcrypt_create_iv를 사용하여 생성합니다.
사용 중인 시스템이 Windows가 아닌 경우 /dev/urandom을 호출해야 합니다. FreeBSD 시스템은 특별하며 /dev/random을 호출한 다음 stream_set_read_buffer 메서드를 호출하여 8바이트 문자 파일을 생성합니다. 생성 후 fread 함수를 통해 파일의 32바이트를 읽은 다음 해당 데이터를 반환합니다.
status는 common/models/User
const STATUS_DELETED = 0; const STATUS_ACTIVE = 10;
사용자가 등록할 때 규칙의 상태가 기본적으로 10으로 설정됩니다.
created_time 및 update_time도 common/models/User
User의 Behaviors() 함수에서 생성됩니다. 데이터는 자격이 있는 것으로 확인되고 프레임워크에서 생성된 데이터도 추가되어 데이터의 사용자 테이블에 저장됩니다.
추천 학습:
yii 프레임워크위 내용은 yii에 등록하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!