PHP에서 사용자 인증을 위해 이메일을 보내는 방법

*文
풀어 주다: 2023-03-18 09:30:02
원래의
4849명이 탐색했습니다.

때때로 웹사이트에서는 사용자의 악의적인 등록, 신원 확인 및 기타 작업을 방지하기 위해 이메일 확인을 사용해야 합니다. 하지만 PHP 백엔드를 사용하여 확인 이메일을 보내는 방법은 무엇입니까? 이 기사에서는 일련의 등록 예제를 사용하여 PHP가 이메일을 보내는 방법을 설명합니다.

사용자 등록 시 가장 일반적인 보안 확인 중 하나는 이메일 확인입니다. 일반적인 업계 관행에 따르면 이메일 확인은 잠재적인 보안 위험을 방지하는 데 매우 중요한 관행입니다. 이제 이러한 모범 사례에 대해 논의하고 PHP에서 이메일 확인을 만드는 방법을 살펴보겠습니다.

등록 양식부터 시작해 보겠습니다.

<form method="post" action="http://mydomain.com/registration/">
    <fieldset>
        <label for="fname">First Name:</label>
        <input type="text" name="fname" required />
    </fieldset>
    <fieldset>
        <label for="lname">Last Name:</label>
        <input type="text" name="lname" required />
    </fieldset>
    <fieldset>
        <label for="email">Last name:</label>
        <input type="email" name="email" required />
    </fieldset>
    <fieldset>
        <label for="password">Password:</label>
        <input type="password" name="password" required />
    </fieldset>
    <fieldset>
        <label for="cpassword">Confirm Password:</label>
        <input type="password" name="cpassword" required />
    </fieldset>
    <fieldset>
        <button type="submit">Register</button>
    </fieldset>
</form>
로그인 후 복사


다음은 데이터베이스의 테이블 구조입니다.

CREATE TABLE IF NOT EXISTS `user` (
    `id` INT(10) NOT NULL AUTO_INCREMENT PRIMARY KEY,
    `fname` VARCHAR(255) ,
    `lname` VARCHAR(255) ,
    `email` VARCHAR(50) ,
    `password` VARCHAR(50) ,
    `is_active` INT(1) DEFAULT &#39;0&#39;,
    `verify_token` VARCHAR(255) ,
    `created_at` TIMESTAMP,
    `updated_at` TIMESTAMP,
);
로그인 후 복사


양식이 제출되면 사용자 입력을 확인하고 새 사용자를 생성해야 합니다.

// Validation rules
$rules = array(
    &#39;fname&#39; => &#39;required|max:255&#39;,
    &#39;lname&#39; => &#39;required|max:255&#39;,
    &#39;email&#39; => &#39;required&#39;,
    &#39;password&#39; => &#39;required|min:6|max:20&#39;,
    &#39;cpassword&#39; => &#39;same:password&#39;
);
$validator = Validator::make(Input::all(), $rules);
// If input not valid, go back to registration page
if($validator->fails()) {
    return Redirect::to(&#39;registration&#39;)->with(&#39;error&#39;, $validator->messages()->first())->withInput();
}
$user = new User();
$user->fname = Input::get(&#39;fname&#39;);
$user->lname = Input::get(&#39;lname&#39;);
$user->password = Input::get(&#39;password&#39;);
// You will generate the verification code here and save it to the database
// Save user to the database
if(!$user->save()) {
    // If unable to write to database for any reason, show the error
    return Redirect::to(&#39;registration&#39;)->with(&#39;error&#39;, &#39;Unable to write to database at this time. Please try again later.&#39;)->withInput();
}
// User is created and saved to database
// Verification e-mail will be sent here
// Go back to registration page and show the success message
return Redirect::to(&#39;registration&#39;)->with(&#39;success&#39;, &#39;You have successfully created an account. The verification link has been sent to e-mail address you have provided. Please click on that link to activate your account.&#39;);
로그인 후 복사

등록 후 사용자의 이메일이 확인될 때까지 사용자의 계정은 유효하지 않은 상태로 유지됩니다. 이 기능은 사용자가 입력한 이메일 주소의 소유자임을 확인하고, 스팸 및 이메일 무단 사용 및 정보 유출을 방지하는 데 도움이 됩니다.

전체 과정은 매우 간단합니다. 새 사용자가 생성되면 등록 과정에서 사용자가 입력한 이메일 주소로 확인 링크가 포함된 이메일이 전송됩니다. 사용자가 이메일 확인 링크를 클릭하고 이메일 주소를 확인하기 전에는 로그인하여 웹사이트 애플리케이션을 사용할 수 없습니다.

확인된 링크에 대해 몇 가지 참고할 사항이 있습니다. 확인된 링크에는 충분히 길고 특정 기간 동안만 유효한 무작위로 생성된 토큰이 포함되어야 합니다. 이는 네트워크 공격을 방지하기 위해 수행됩니다. 동시에 여러 사용자를 공격할 수 있는 잠재적인 위험을 피하기 위해 이메일 확인에는 사용자의 고유 식별자도 포함되어야 합니다.

이제 실제로 확인 링크를 생성하는 방법을 살펴보겠습니다.

// We will generate a random 32 alphanumeric string
// It is almost impossible to brute-force this key space
$code = str_random(32);
$user->confirmation_code = $code;
로그인 후 복사


이 확인이 생성되면 데이터베이스에 저장하고 사용자에게 보냅니다.

Mail::send(&#39;emails.email-confirmation&#39;, array(&#39;code&#39; => $code, &#39;id&#39; => $user->id), function($message)
{
$message->from(&#39;my@domain.com&#39;, &#39;Mydomain.com&#39;)->to($user->email, $user->fname . &#39; &#39; . $user->lname)->subject(&#39;Mydomain.com: E-mail confirmation&#39;);
});
로그인 후 복사


이메일 확인 내용:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
    </head>
    <body>
        <p style="margin:0">
            Please confirm your e-mail address by clicking the following link:
            <a href="http://mydomain.com/verify?code=<?php echo $code; ?>&user=<?php echo $id; ?>"></a>
        </p>
    </body>
</html>
로그인 후 복사


이제 작동하는지 확인해 보겠습니다.

$user = User::where(&#39;id&#39;, &#39;=&#39;, Input::get(&#39;user&#39;))
            ->where(&#39;is_active&#39;, &#39;=&#39;, 0)
            ->where(&#39;verify_token&#39;, &#39;=&#39;, Input::get(&#39;code&#39;))
            ->where(&#39;created_at&#39;, &#39;>=&#39;, time() - (86400 * 2))
            ->first();
if($user) {
    $user->verify_token = null;
    $user->is_active = 1;
    if(!$user->save()) {
        // If unable to write to database for any reason, show the error
        return Redirect::to(&#39;verify&#39;)->with(&#39;error&#39;, &#39;Unable to connect to database at this time. Please try again later.&#39;);
    }
    // Show the success message
    return Redirect::to(&#39;verify&#39;)->with(&#39;success&#39;, &#39;You account is now active. Thank you.&#39;);
}
// Code not valid, show error message
return Redirect::to(&#39;verify&#39;)->with(&#39;error&#39;, &#39;Verification code not valid.&#39;);
로그인 후 복사


결론:

위에 표시된 코드는 단지 튜토리얼 예제일 뿐이며 충분히 테스트되지 않았습니다. 웹 애플리케이션에서 사용하기 전에 테스트해 보세요. 위 코드는 Laravel 프레임워크에서 수행되었지만 다른 PHP 프레임워크로 쉽게 마이그레이션할 수 있습니다. 동시에 확인 링크는 48시간 동안 유효하며 그 이후에는 만료됩니다. 작업 대기열을 도입하면 만료된 확인 링크를 적시에 처리할 수 있습니다.

관련 권장 사항:

php 전체 확인 코드 코드 php 확인 코드 생성 php SMS 확인 코드 php 확인 코드 코드

php SMS 인터페이스 샘플 코드(시작하기)

php SMS 게이트웨이 SMS 콘텐츠에는 공백이 있을 수 없습니다. SMS 게이트웨이 SMS 콘텐츠_PHP 튜토리얼

위 내용은 PHP에서 사용자 인증을 위해 이메일을 보내는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿