用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 中检查或过滤IP地址的实现代码
Nov 27 PHP
php比较多维数组中值的大小排序实现代码
Sep 08 PHP
php之CodeIgniter学习笔记
Jun 17 PHP
PHP数据库链接类(PDO+Access)实例分享
Dec 05 PHP
PHP中使用FFMPEG获取视频缩略图和视频总时长实例
May 04 PHP
php使用fopen创建utf8编码文件的方法
Oct 31 PHP
PHP使用正则表达式获取微博中的话题和对象名
Jul 18 PHP
yii2框架中使用下拉菜单的自动搜索yii-widget-select2实例分析
Jan 09 PHP
PHP开发中常用的十个代码样例
Feb 02 PHP
PHP微信开发之有道翻译
Jun 23 PHP
php in_array() 检查数组中是否存在某个值详解
Nov 23 PHP
PHP使用curl_multi实现并发请求的方法示例
Apr 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 判断数组是几维数组
2013/03/20 PHP
PHP中file_get_contents函数抓取https地址出错的解决方法(两种方法)
2015/09/22 PHP
CodeIgniter基于Email类发邮件的方法
2016/03/29 PHP
PHP laravel中的多对多关系实例详解
2017/06/07 PHP
PHP的mysqli_thread_id()函数讲解
2019/01/24 PHP
PHP时间函数使用详解
2019/03/21 PHP
Laravel解决nesting level错误和隐藏index.php的问题
2019/10/12 PHP
ExtJS 2.0实用简明教程 之Border区域布局
2009/04/29 Javascript
IE6图片加载的一个BUG解决方法
2010/07/13 Javascript
JavaScript 拾碎[三] 使用className属性
2010/10/16 Javascript
jQuery获取CSS样式中的颜色值的问题,不同浏览器格式不同的解决办法
2013/05/13 Javascript
js获取电脑分辨率的思路及操作
2013/11/22 Javascript
jquery实现弹出div,始终显示在屏幕正中间的简单实例
2014/03/08 Javascript
javascript操作excel生成报表全攻略
2014/05/04 Javascript
ionic实现带字的toggle滑动组件
2016/08/27 Javascript
JavaScript定义数组的三种方法(new Array(),new Array('x','y')
2016/10/04 Javascript
基于AGS JS开发自定义贴图图层
2017/03/31 Javascript
深入理解Node中的buffer模块
2017/06/03 Javascript
浅谈JS如何实现真正的对象常量
2017/06/25 Javascript
简述jQuery Easyui一些用法
2017/08/01 jQuery
node.js读取Excel数据(下载图片)的方法示例
2018/08/02 Javascript
JavaScript实现选项卡效果的分析及步骤
2019/04/16 Javascript
从零开始在vue-cli4配置自适应vw布局的实现
2020/06/08 Javascript
解决echarts 一条柱状图显示两个值,类似进度条的问题
2020/07/20 Javascript
react-intl实现React国际化多语言的方法
2020/09/27 Javascript
[02:48]DOTA2英雄基础教程 暗夜魔王
2013/12/12 DOTA
[01:10:48]完美世界DOTA2联赛PWL S2 GXR vs PXG 第一场 11.18
2020/11/18 DOTA
Python xlrd读取excel日期类型的2种方法
2015/04/28 Python
利用python实现周期财务统计可视化
2019/08/25 Python
Matplotlib使用字符串代替变量绘制散点图的方法
2020/02/17 Python
用HTML5中的Canvas结合公式绘制粒子运动的教程
2015/05/08 HTML / CSS
介绍一下木马病毒的种类
2015/07/26 面试题
超市中秋节活动方案
2014/02/12 职场文书
挂牌仪式主持词
2014/03/20 职场文书
领导干部失职检讨书
2015/05/05 职场文书
使用pycharm运行flask应用程序的详细教程
2021/06/07 Python