用Php编写注册后Email激活验证的实例代码


Posted in PHP onMarch 11, 2013

总共需两个页面,register.php 和 verify.php

1. 用户注册表格 register.php

 <html> 
 <body> 
   <form action="register.php" method="post" name="register"> 
      用户名:<input type="text" name="username" /> 
      密码:<input type="password" name="password" /> 
      电子邮件:<input type="text" name="email" /> 
      <input type="submit" value="注册" /> 
   </form> 
 </body> 
 </html>

2. 创建用户数据表格 Users

 CREATE TABLE IF NOT EXISTS `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' 来表示尚未激活的用户。

 $activationKey =  mt_rand() . mt_rand() . mt_rand() . mt_rand() . mt_rand(); 
 $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. 发送验证码

 echo "An email has been sent to $_POST[email] with an activation key. Please check your mail to complete registration."; 
 ##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
如果验证码相同,则激活用户。

 $queryString = $_SERVER['QUERY_STRING']; 
 $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])";          
        if (!mysql_query($sql)) { 
           die('Error: ' . mysql_error()); 
        }           
         // 到这里,用户已经完全激活了账号,你可以将页面跳转到登陆后的界面了   
     } 
   } // end of while
PHP 相关文章推荐
PHP 5昨天隆重推出--PHP 5/Zend Engine 2.0新特性
Oct 09 PHP
在同一窗体中使用PHP来处理多个提交任务
May 08 PHP
使用PHP获取汉字的拼音(全部与首字母)
Jun 27 PHP
PHP生成Gif图片验证码
Oct 27 PHP
PHP的mysqli_query参数MYSQLI_STORE_RESULT和MYSQLI_USE_RESULT的区别
Sep 29 PHP
详解WordPress开发中的get_post与get_posts函数使用
Jan 04 PHP
CodeIgniter视图使用注意事项
Jan 20 PHP
PHP重定向与伪静态区别
Feb 19 PHP
PHP基于正则批量替换Img中src内容实现获取缩略图的功能示例
Jun 07 PHP
PHP中递归的实现实例详解
Nov 14 PHP
php-msf源码详解
Dec 25 PHP
ThinkPHP实现的rsa非对称加密类示例
May 29 PHP
php 生成唯一id的几种解决方法
Mar 08 #PHP
PHP Directory 函数的详解
Mar 07 #PHP
PHP重定向的3种方式
Mar 07 #PHP
file_get_contents获取不到网页内容的解决方法
Mar 07 #PHP
PHP屏蔽蜘蛛访问代码及常用搜索引擎的HTTP_USER_AGENT
Mar 06 #PHP
php设置编码格式的方法
Mar 05 #PHP
简单实现限定phpmyadmin访问ip的方法
Mar 05 #PHP
You might like
PHP通用检测函数集合
2006/11/25 PHP
配置Apache2.2+PHP5+CakePHP1.2+MySQL5运行环境
2009/04/25 PHP
php截取中文字符串不乱码的方法
2013/12/25 PHP
浅谈PHP值mysql操作类
2016/06/29 PHP
PHP入门教程之PHP操作MySQL的方法分析
2016/09/11 PHP
PHP数组相加操作及与array_merge的区别浅析
2016/11/26 PHP
PHP使用反向Ajax技术实现在线客服系统详解
2019/07/01 PHP
greybox——不开新窗口看新的网页
2007/02/20 Javascript
用jquery统计子菜单的条数示例代码
2013/10/18 Javascript
javascript操作table(insertRow,deleteRow,insertCell,deleteCell方法详解)
2013/12/16 Javascript
jQuery Form表单取值的方法
2017/01/11 Javascript
解决JQuery全选/反选第二次失效的问题
2017/10/11 jQuery
Angular4学习之Angular CLI的安装与使用教程
2018/01/04 Javascript
详解node child_process模块学习笔记
2018/01/24 Javascript
vue源码解析之事件机制原理
2018/04/21 Javascript
零基础之Node.js搭建API服务器的详解
2019/03/08 Javascript
vue组件系列之TagsInput详解
2020/05/14 Javascript
谈谈JavaScript令人迷惑的==与+
2020/08/31 Javascript
vue+element实现动态加载表单
2020/12/13 Vue.js
[01:07:34]DOTA2-DPC中国联赛定级赛 RNG vs Aster BO3第二场 1月9日
2021/03/11 DOTA
Python中用PIL库批量给图片加上序号的教程
2015/05/06 Python
Python实现进程同步和通信的方法
2018/01/02 Python
python框架django项目部署相关知识详解
2019/11/04 Python
python快速排序的实现及运行时间比较
2019/11/22 Python
Python数据正态性检验实现过程
2020/04/18 Python
Python3自带工具2to3.py 转换 Python2.x 代码到Python3的操作
2021/03/03 Python
css3的动画特效之动画序列(animation)
2017/12/22 HTML / CSS
伦敦高级内衣品牌:Agent Provocateur(大内密探)
2016/08/23 全球购物
便携式太阳能系统的创新者:GOAL ZERO
2018/02/04 全球购物
选购国际女性时装设计师品牌:IFCHIC(支持中文)
2018/04/12 全球购物
科茨沃尔德家居商店:Scotts of Stow
2018/06/29 全球购物
阿拉伯书店:Jamalon
2019/07/24 全球购物
金鑫耀Java笔试题
2014/09/06 面试题
敬老院活动总结
2014/04/28 职场文书
商务信函英语问候语
2015/11/10 职场文书
C#连接ORACLE出现乱码问题的解决方法
2021/10/05 Oracle