>  기사  >  백엔드 개발  >  PHP에서 사용자 이메일 등록 활성화 코드를 구현하는 방법에 대한 자세한 설명

PHP에서 사용자 이메일 등록 활성화 코드를 구현하는 방법에 대한 자세한 설명

伊谢尔伦
伊谢尔伦원래의
2017-07-15 13:23:045863검색

사용자가 웹사이트에 로그인하고 회원가입을 할 때, 일반적으로 사용자 자신의 이메일 주소를 사용해야 합니다. 해당 이메일 주소는 웹사이트에서 이메일을 받아 계정을 활성화한 후 정상적으로 사용할 수 있습니다. 이 기사 에서는 예제를 사용하여 PHP+Mysql을 사용하여 계정 등록, 활성화 이메일 보내기, 활성화 계정 확인 및 URL 링크 만료 처리 기능을 완료하는 방법을 소개합니다. 활성화 링크가 포함된 이메일을 받으세요.

등록 이메일 활성화 과정

1. 사용자 등록
2. 현재 계정이 활성화되지 않았습니다.
3. 사용자 이름, 비밀번호 또는 기타 식별 문자를 암호화하여 활성화 식별 코드를 만듭니다(활성화 코드라고도 함).
4. 생성된 활성화 식별 코드를 사용자가 제출한 이메일 주소의 URL로 보냅니다.
5. 사용자는 이메일에 로그인하고 URL을 클릭하여 활성화합니다.
6. 활성화 식별 코드를 확인하고 올바른 경우 계정을 활성화하세요.

데이터베이스 생성 테이블

우리는 계정을 등록할 때 일반적으로 사용자 테이블에 ID, 사용자 이름, 비밀번호, 이메일 또는 휴대폰 번호와 계정 활성화 여부를 기록합니다. 필드.

사용자 정보 테이블의 이메일 필드는 사용자 확인, 비밀번호 검색에 매우 중요하며, 웹사이트 파티에서도 이메일 마케팅을 위한 사용자 정보를 수집하는 데 사용될 수 있습니다. 사용자 정보 테이블 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는 데이터 작성 및 이메일 전송을 완료합니다

먼저데이터베이스에 연결하고 이메일 전송 클래스 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()) {//写入成功,发邮件
  include_once("smtp.class.php");
  $smtpserver = "smtp.163.com"; //SMTP服务器
  $smtpserverport = 25; //SMTP服务器端口
  $smtpusermail = "hjl416148489_4@163.com"; //SMTP服务器的用户邮箱
  $smtpuser = "hjl416148489_4@163.com"; //SMTP服务器的用户帐号
  $smtppass = "hjl7233163"; //SMTP服务器的用户密码
  $smtp = new Smtp($smtpserver, $smtpserverport, true, $smtpuser, $smtppass); //这里面的一个true是表示使用身份验证,否则不使用身份验证.
  $emailtype = "HTML"; //信件类型,文本:text;网页:HTML
  $smtpemailto = $email;
  $smtpemailfrom = $smtpusermail;
  $emailsubject = "用户帐号激活";
  $emailbody = "亲爱的" . $username . ":<br/>感谢您在我站注册了新帐号。<br/>请点击链接激活您的帐号。<br/>
  <a href=&#39;http://www.php.cn/demo/active.php?verify=" . $token . "&#39; target=&#39;_blank&#39;>http://www.php.cn/demo/active.php?verify=" . $token . "</a>
  <br/>如果以上链接无法点击,请将它复制到你的浏览器地址栏中进入访问,该链接24小时内有效。<br/>如果此次激活请求非你本人所发,请忽略本邮件。<br/>
  ";
  $rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype);
  if ($rs == 1) {
    $msg = &#39;恭喜您,注册成功!<br/>请登录到您的邮箱及时激活您的帐号!&#39;;
  } else {
    $msg = $rs;
  }
  echo $msg;
}

active.php

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

$email은 등록할 때 사용한 이메일입니다. 이를 인코딩하고 URL의 요청 부분에 대한 문자열을 사용합니다. $activation_key는 활성화 이메일을 보내기 위해 서버를 사용합니다. 이 이메일은 이메일 클라이언트에 하이퍼링크로 표시되며 클릭하면 이메일과 키가 activate.php 파일로 전송됩니다. 즉, 확인을 수행하고 계정을 활성화하게 됩니다. .

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;

활성화에 성공한 후 토큰 필드가 더 이상 유용하지 않다는 것을 알게 되면 이를 지울 수 있습니다. 그리고 상태 활성화 상태가 1로 변경됩니다. 이제 계정이 활성화되었습니다. 로그인 시 사용자는 먼저 활성화 여부를 확인한 후 다음 단계를 진행합니다.

위 내용은 PHP에서 사용자 이메일 등록 활성화 코드를 구현하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.