>  기사  >  백엔드 개발  >  PHP는 등록 후 새로운 사용자 로그인 기능을 활성화하기 위해 확인 이메일을 구현합니다.

PHP는 등록 후 새로운 사용자 로그인 기능을 활성화하기 위해 확인 이메일을 구현합니다.

巴扎黑
巴扎黑원래의
2017-08-09 15:02:232386검색

이 글에서는 주로 PHP에서 구현된 사용자 등록 및 확인 메일함 활성화 기능을 소개하고, PHP 이메일로 사용자를 활성화하는 데 관련된 데이터베이스 및 이메일 관련 조작 기술을 자세히 분석합니다. 예제와 함께 PHP로 구현된 활성화 사용자 등록 확인 이메일 기능. 참조를 위해 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

여기에는 PHP+Mysql을 사용하여 계정 등록, 활성화 이메일 보내기, 활성화 계정 확인 및 URL 처리 기능을 완료하는 방법을 소개하는 예제가 포함되어 있습니다. 링크 만료.

등록 이메일 활성화 과정1. 사용자 등록

2. 현재 계정이 활성화되지 않았습니다.

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

t_user.sql사용자 정보 테이블의 이메일 필드는 사용자 확인, 비밀번호 검색에 매우 중요하며, 웹사이트 파티에서도 이메일을 위한 사용자 정보를 수집하는 데 사용될 수 있습니다. Marketing 다음은 사용자입니다. 정보 테이블 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.jb51.net/demo/active.php?verify=" . $token . "&#39; target=&#39;_blank&#39;>http://www.jb51.net/demo/active.php?verify=" . $token . "</a><br/>如果以上链接无法点击,请将它复制到你的浏览器地址栏中进入访问,该链接24小时内有效。<br/>如果此次激活请求非你本人所发,请忽略本邮件。<br/><p style=&#39;text-align:right&#39;>-------- 脚本之家http://www.jb51.net敬上</p>";
  $rs = $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype);
  if ($rs == 1) {
    $msg = &#39;恭喜您,注册成功!<br/>请登录到您的邮箱及时激活您的帐号!&#39;;
  } else {
    $msg = $rs;
  }
  echo $msg;
}

active.phpactive.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;

활성화에 성공한 후 토큰 필드가 더 이상 유용하지 않다는 것을 알게 되면 이를 지울 수 있습니다. 그리고 상태 활성화 상태가 1로 변경됩니다.

위 내용은 PHP는 등록 후 새로운 사용자 로그인 기능을 활성화하기 위해 확인 이메일을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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