总共需两个页面,register.PHP 和 verify.PHP
2. 创建用户数据表格 Users
`id` int(11) NOT NULL auto_increment,
`status` varchar(20) NOT NULL,
`username` varchar(20) NOT NULL,
`password` varchar(20) NOT NULL,
`email` varchar(20) NOT NULL,
`activationkey` varchar(100) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `username` (`username`),
UNIQUE KEY `email` (`email`),
UNIQUE KEY `activationkey` (`activationkey`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=9 ;
3. 创建验证码 用户注册信息存入数据表
我们使用状态‘verify' 来表示尚未激活的用户。
$username = MysqL_real_escape_string($_POST[username]);
$password = MysqL_real_escape_string($_POST[password]);
$email = MysqL_real_escape_string($_POST[email]);
$sql="INSERT INTO users (username,password,email,activationkey,status) VALUES ('$username','$password','$email','$activationKey','verify')";
4. 发送验证码
##Send activation Email
$to = $_POST[email];
$subject = " YOURWEBSITE.com Registration";
$message = "Welcome to our website!\r\rYou,or someone using your email address,has completed registration at YOURWEBSITE.com. You can complete registration by clicking the following link:\rhttp://www.YOURWEBSITE.com/verify.PHP?$activationKey\r\rIf this is an error,ignore this email and you will be removed from our mailing list.\r\rRegards,\ YOURWEBSITE.com Team";
$headers = 'From: noreply@ YOURWEBSITE.com' . "\r\n" .
'Reply-To: noreply@ YOURWEBSITE.com' . "\r\n" .
'X-Mailer: PHP/' . PHPversion();
mail($to,$subject,$message,$headers);
5. 验证激活代码 verify.PHP
如果验证码相同,则激活用户。
$query = "SELECT * FROM users";
$result = MysqL_query($query) or die(MysqL_error());
while($row = MysqL_fetch_array($result)){
if ($queryString == $row["activationkey"]){
echo "Congratulations!" . $row["username"] . " is Now the proud new owner of a YOURWEBSITE.com account.";
$sql="UPDATE users SET activationkey = '',status='activated' WHERE (id = $row[id])";
die('Error: ' . MysqL_error());
}
// 到这里,用户已经完全激活了账号,你可以将页面跳转到登陆后的界面了
}
} // end of while
原文地址:https://www.jb51.cc/php/26721.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。