많은 웹사이트에 회원을 등록할 때 등록이 완료되면 시스템에서 자동으로 사용자의 메일함으로 이메일을 보냅니다. 이 이메일의 내용은 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
해당 페이지에 등록 양식을 배치하면 사용자가 등록 정보를 입력할 수 있습니다. 사용자 이름, 비밀번호, 이메일을 포함합니다. <… . 이 글에서는 프론트 엔드 인증 코드를 생략합니다. 또한, 해당 페이지에는 사용자가 비밀번호를 다시 입력하도록 요구하는 입력 상자도 있어야 하므로 게으른 경우 건너뛸 수 있습니다.
register.php
사용자는 처리를 위해 등록 정보를 Register.php에 제출합니다. Register.php는 데이터 쓰기와 이메일 보내기라는 두 가지 주요 기능을 완료해야 합니다.
먼저, connect.php와 smtp.class.php라는 두 개의 파일이 들어있습니다. 이 두 파일은 외부에서 제공되는 다운로드 패키지에 포함되어 있습니다.
<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>
그런 다음 사용자가 제출한 정보를 필터링하고 사용자 이름이 존재하는지 확인해야 합니다(프런트 엔드에서도 확인할 수 있음).
include_once("connect.php");//连接数据库 include_once("smtp.class.php");//邮件发送类
그런 다음 사용자 비밀번호를 암호화하고 활성화 식별 코드를 구성합니다.
$username = stripslashes(trim($_POST['username'])); $query = mysql_query("select id from t_user where username='$username'"); $num = mysql_num_rows($query); if($num==1){ echo '用户名已存在,请换个其他的用户名'; exit; }
위 코드에서 $token은 구성된 활성화 식별 코드로, 사용자 이름, 비밀번호 및 현재 시간이 작성되고 md5가 암호화되었습니다. $token_exptime은 활성화 링크 URL의 만료 시간을 설정하는 데 사용됩니다. 사용자는 이 기간 내에 계정을 활성화할 수 있습니다. 이 예에서는 활성화가 24시간 이내에 유효합니다. 마지막으로 이러한 필드는 데이터 테이블 t_user에 삽입됩니다.
데이터가 성공적으로 삽입되면 이메일 전송 클래스를 호출하여 활성화 정보를 사용자의 등록된 메일함으로 전송합니다. 생성된 활성화 식별 코드는 사용자가 클릭할 때 활성화 링크로 완전한 URL로 구성됩니다. . 자세한 내용은 다음과 같습니다. 코드:
$password = md5(trim($_POST['password'])); //加密密码 $email = trim($_POST['email']); //邮箱 $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 ('$username','$password','$email','$token','$token_exptime','$regtime')"; mysql_query($sql);
모든 사람과 공유할 수 있는 매우 사용하기 쉽고 강력한 이메일 전송 클래스도 있습니다. PHPMailer를 사용하여 첨부 파일이 포함된 이메일을 보내고 HTML 콘텐츠를 지원할 수 있습니다. 직접요.
active.php
문제가 없으면 계정 등록 시 입력한 이메일로 helloweba에서 이메일을 받게 됩니다. 이때 활성화 링크를 직접 클릭하여 건네주시면 됩니다. active.php로 넘어갑니다.
active.php接收提交的链接信息,获取参数verify的值,即激活识别码。将它与数据表中的用户信息进行查询对比,如果有相应的数据集,判断是否过期,如果在有效期内则将对应的用户表中字段status设置1,即已激活,这样就完成了激活功能。
include_once("connect.php");//连接数据库 $verify = stripslashes(trim($_GET['verify'])); $nowtime = time(); $query = mysql_query("select id,token_exptime from t_user where status='0' and `token`='$verify'"); $row = mysql_fetch_array($query); if($row){ if($nowtime>$row['token_exptime']){ //24hour $msg = '您的激活有效期已过,请登录您的帐号重新发送激活邮件.'; }else{ mysql_query("update t_user set status=1 where id=".$row['id']); if(mysql_affected_rows($link)!=1) die(0); $msg = '激活成功!'; } }else{ $msg = 'error.'; } echo $msg;
激活成功后,发现token字段并没有用处了,您可以清空。接下来我们会讲解用户找回密码的功能,也要用到邮箱验证,敬请关注。
以上就是(进阶篇)PHP实现用户注册后邮箱验证,激活帐号的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!