> 백엔드 개발 > PHP 튜토리얼 > PHP는 사용자 등록 후 이메일 확인 및 계정 활성화를 구현합니다.

PHP는 사용자 등록 후 이메일 확인 및 계정 활성화를 구현합니다.

高洛峰
풀어 주다: 2016-11-21 10:45:34
원래의
1332명이 탐색했습니다.

많은 웹사이트에 회원을 등록할 때 등록이 완료되면 시스템에서 자동으로 사용자의 메일함으로 이메일을 보냅니다. 이 이메일의 내용은 URL 링크입니다. 활성화하려면 사용자가 이 링크를 클릭하고 열어야 합니다. 웹사이트 계정에 등록. 회원가입 기능은 활성화가 성공한 후에만 정상적으로 이용 가능합니다.

이 기사에서는 예제를 사용하여 PHP+Mysql을 사용하여 계정 등록, 활성화 이메일 보내기, 활성화 계정 확인 및 URL 링크 만료 처리 등의 기능을 완료하는 방법을 설명합니다.

비즈니스 프로세스

1. 사용자가 등록 정보를 제출합니다.

2. 데이터베이스에 쓰기는 현재 계정 상태가 활성화되어 있지 않습니다.

3. 사용자 이름, 비밀번호 또는 기타 식별 문자를 암호화하여 활성화 식별 코드를 만듭니다(활성화 코드라고도 함).

4. 생성된 활성화 식별 코드를 사용자가 제출한 이메일 주소의 URL로 보냅니다.

5. 사용자는 이메일에 로그인하고 URL을 클릭하여 활성화합니다.

6. 활성화 식별 코드를 확인하고 올바른 경우 계정을 활성화합니다.

데이터 테이블 준비

사용자 정보 테이블의 이메일 필드는 사용자 확인, 비밀번호 검색에 사용될 수 있으며, 웹사이트 파티에서도 수집에 사용될 수 있습니다. 이메일 마케팅을 위한 사용자 정보, 다음은 사용자 정보 테이블 t_user의 테이블 구조입니다:

CREATE TABLE IF NOT EXISTS `t_user` ( 
  `id` int(11) NOT NULL AUTO_INCREMENT, 
  `username` varchar(30) NOT NULL COMMENT '用户名', 
  `password` varchar(32) NOT NULL COMMENT '密码', 
  `email` varchar(30) NOT NULL COMMENT '邮箱', 
  `token` varchar(50) NOT NULL COMMENT '帐号激活码', 
  `token_exptime` int(10) NOT NULL COMMENT '激活码有效期', 
  `status` tinyint(1) NOT NULL DEFAULT '0' COMMENT '状态,0-未激活,1-已激活', 
  `regtime` int(10) NOT NULL COMMENT '注册时间', 
  PRIMARY KEY (`id`) 
) ENGINE=MyISAM  DEFAULT CHARSET=utf8;
로그인 후 복사

HTML

해당 페이지에 등록 양식을 배치하면 사용자가 등록을 입력할 수 있습니다. 사용자 이름, 비밀번호, 이메일을 포함한 정보.

<form id="reg" action="register.php" method="post"> 
    <p>用户名:<input type="text" class="input" name="username" id="user"></p> 
    <p>密 码:<input type="password" class="input" name="password" id="pass"></p> 
    <p>E-mail:<input type="text" class="input" name="email" id="email"></p> 
    <p><input type="submit" class="btn" value="提交注册"></p> 
</form>
로그인 후 복사

사용자 입력에 필요한 프런트엔드 검증이 필요합니다. 양식 검증 기능에 관해서는 이 사이트의 기사: 양식 검증 플러그인의 적용을 설명하는 예제를 참조하는 것이 좋습니다. 유효성 검사. 이 문서에서는 프런트엔드 인증 코드를 건너뜁니다. 또한 실제로 사용자가 비밀번호를 다시 입력해야 하는 입력 상자가 있어야 합니다.

register.php

사용자는 처리를 위해 등록 정보를 Register.php에 제출합니다. Register.php는 데이터 쓰기와 이메일 보내기라는 두 가지 주요 기능을 완료해야 합니다.

먼저, connect.php와 smtp.class.php라는 두 개의 파일이 들어있습니다. 이 두 파일은 외부에서 제공되는 다운로드 패키지에 포함되어 있습니다.

include_once("connect.php");//连接数据库 
include_once("smtp.class.php");//邮件发送类
로그인 후 복사

그런 다음 사용자가 제출한 정보를 필터링하고 사용자 이름이 존재하는지 확인해야 합니다(프런트 엔드에서도 확인할 수 있음).

$username = stripslashes(trim($_POST[&#39;username&#39;])); 
$query = mysql_query("select id from t_user where username=&#39;$username&#39;"); 
$num = mysql_num_rows($query); 
if($num==1){ 
    echo &#39;用户名已存在,请换个其他的用户名&#39;; 
    exit; 
}
로그인 후 복사

그런 다음 사용자 비밀번호를 암호화하고 활성화 식별 코드를 구성합니다.

$password = md5(trim($_POST[&#39;password&#39;])); //加密密码 
$email = trim($_POST[&#39;email&#39;]); //邮箱 
$regtime = time(); 
 
$token = md5($username.$password.$regtime); //创建用于激活识别码 
$token_exptime = time()+60*60*24;//过期时间为24小时后 
 
$sql = "insert into `t_user` (`username`,`password`,`email`,`token`,`token_exptime`,`regtime`)  
values (&#39;$username&#39;,&#39;$password&#39;,&#39;$email&#39;,&#39;$token&#39;,&#39;$token_exptime&#39;,&#39;$regtime&#39;)"; 
 
mysql_query($sql);
로그인 후 복사

위 코드에서 $token은 구성된 활성화 식별 코드로, 사용자 이름, 비밀번호는 현재 시간으로 구성되며 md5로 암호화됩니다. $token_exptime은 활성화 링크 URL의 만료 시간을 설정하는 데 사용됩니다. 사용자는 이 기간 내에 계정을 활성화할 수 있습니다. 이 예에서는 활성화가 24시간 이내에 유효합니다. 마지막으로 이러한 필드는 데이터 테이블 t_user에 삽입됩니다.

데이터가 성공적으로 삽입되면 이메일 전송 클래스를 호출하여 활성화 정보를 사용자의 등록된 메일함으로 전송합니다. 생성된 활성화 식별 코드는 사용자가 클릭할 때 활성화 링크로 완전한 URL로 구성됩니다. 다음은 세부 코드입니다:

if(mysql_insert_id()){ 
    $smtpserver = ""; //SMTP服务器,如:smtp.163.com 
    $smtpserverport = 25; //SMTP服务器端口,一般为25 
    $smtpusermail = ""; //SMTP服务器的用户邮箱,如xxx@163.com 
    $smtpuser = ""; //SMTP服务器的用户帐号xxx@163.com 
    $smtppass = ""; //SMTP服务器的用户密码 
    $smtp = new Smtp($smtpserver, $smtpserverport, true, $smtpuser, $smtppass); //实例化邮件类 
    $emailtype = "HTML"; //信件类型,文本:text;网页:HTML 
    $smtpemailto = $email; //接收邮件方,本例为注册用户的Email 
    $smtpemailfrom = $smtpusermail; //发送邮件方,如xxx@163.com 
    $emailsubject = "用户帐号激活";//邮件标题 
    //邮件主体内容 
    $emailbody = "亲爱的".$username.":<br/>感谢您在我站注册了新帐号。<br/>请点击链接激活您的帐号。<br/> 
    <a href=&#39;http://www.helloweba.com/demo/register/active.php?verify=".$token."&#39; target= 
&#39;_blank&#39;>http://www.helloweba.com/demo/register/active.php?verify=".$token."</a><br/> 
    如果以上链接无法点击,请将它复制到你的浏览器地址栏中进入访问,该链接24小时内有效。"; 
    //发送邮件 
    $rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype); 
    if($rs==1){ 
        $msg = &#39;恭喜您,注册成功!<br/>请登录到您的邮箱及时激活您的帐号!&#39;;     
    }else{ 
        $msg = $rs;     
    } 
} 
echo $msg;
로그인 후 복사

모든 사람과 공유할 수 있는 매우 사용하기 쉽고 강력한 이메일 전송 클래스도 있습니다. PHPMailer를 사용하여 첨부 파일이 포함된 이메일을 보내고 HTML 콘텐츠를 지원하세요. 직접 사용할 수 있습니다.

active.php

문제가 없으면 계정 등록 시 입력한 이메일로 helloweba에서 이메일을 받게 됩니다. 이때 활성화 링크를 직접 클릭하여 건네주시면 됩니다. active.php로 넘어갑니다.

active.php는 제출된 링크 정보를 수신하고 활성화 식별 코드인 verify 매개변수 값을 얻습니다. 데이터 테이블의 사용자 정보와 쿼리하여 비교합니다. 해당 데이터 세트가 있으면 만료 여부를 확인합니다. 유효 기간 내에 있으면 해당 사용자 테이블의 상태 필드를 1로 설정합니다. 활성화되었습니다.

include_once("connect.php");//连接数据库 
 
$verify = stripslashes(trim($_GET[&#39;verify&#39;])); 
$nowtime = time(); 
 
$query = mysql_query("select id,token_exptime from t_user where status=&#39;0&#39; and  
`token`=&#39;$verify&#39;"); 
$row = mysql_fetch_array($query); 
if($row){ 
    if($nowtime>$row[&#39;token_exptime&#39;]){ //24hour 
        $msg = &#39;您的激活有效期已过,请登录您的帐号重新发送激活邮件.&#39;; 
    }else{ 
        mysql_query("update t_user set status=1 where id=".$row[&#39;id&#39;]); 
        if(mysql_affected_rows($link)!=1) die(0); 
        $msg = &#39;激活成功!&#39;; 
    } 
}else{ 
    $msg = &#39;error.&#39;;     
} 
echo $msg;
로그인 후 복사

활성화에 성공한 후 토큰 필드가 더 이상 유용하지 않다는 것을 알게 되면 이를 지울 수 있습니다. 다음으로 사용자가 비밀번호를 검색하고 이메일 인증을 사용하는 기능에 대해 설명할 예정이니 지켜봐 주시기 바랍니다.

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