PHP中使用crypt()实现用户身份验证的代码

2015-01-24信息快讯网

在开发PHP应用中如果不想自己开发新的加密算法,还可以利用PHP提供的crypt()函数来完成单向加密功能

了解crypt()

  只要有一点使用非Windows平台经验的读者都可能对crypt()相当熟悉,这一函数完成被称作单向加密的功能,它可以加密一些明码,但不能反过来将密码重新转换为原来的明码。crypt()函数定义如下。

  string crypt (string input_string [, string salt])

  其中,input_string参数是需要加密的明文字符串,第二个可选的salt是一个位字串,能够影响加密的暗码,进一步排除被破解的可能性。缺省情况下,PHP使用一个2个字符的DES干扰串,如果系统使用的是MD5(参考下一节内容),PHP则会使用一个12个字符的干扰串。可以通过执行下面的命令发现系统将要使用的干扰串的长度。

  print "My system salt size is: ". CRYPT_SALT_LENGTH;

  crypt()支持4种加密算法,表19.1显示了其支持的算法和相应的salt参数的长度。

  表crypt()支持四种加密算法
算法Salt长度
CRYPT_STD_DES2-character (Default)
CRYPT_EXT_DES9-character
CRYPT_MD512-character beginning with $1$
CRYPT_BLOWFISH16-character beginning with $2$

从表面上看,crypt()的函数似乎没有什么用处,但该函数的确被广泛用来保证系统密码的完整性。因为,单向加密的口令即使落入第三方的手里,由于不能被还原为明文,也没有什么大用处。
  用crypt()实现用户身份验证
  上一部分简单介绍了crypt()函数的功能,下面利用其来实现用户的身份验证,其所要实现的目标同19.2.3节所介绍的一致。
 
<!--check_user_crypt.php:使用crypt() 函数验证用户----------------> 
<?php 
$user_name=$_POST["user_name"]; 
require_once("sys_conf.inc"); //系统配置文件,包含数据库配置信息 
//连接数据库 
$link_id=mysql_connect($DBHOST,$DBUSER,$DBPWD); 
mysql_select_db($DBNAME); //选择数据库my_chat 
//查询是否存在登录用户信息 
$str="select name,password from user where name ='$user_name'"; 
$result=mysql_query($str,$link_id); //执行查询 
@$rows=mysql_num_rows($result); //取得查询结果的记录笔数 
$user_name=$_SESSION["user_name"]; 
$password=$_POST["password"]; 
$salt = substr($password, 0, 2); 
$password_en=crypt($password,$salt); //使用crypt()对用户密码进行加密 
//对于老用户 
if($rows!=0) 
{ 
list($name,$pwd)=mysql_fetch_row($result); 
//如果密码输入正确 
if($pwd==$password_en) 
{ 
$str="update user set is_online =1 where name ='$user_name' and password='$password_en'"; 
$result=mysql_query($str, $link_id);//执行查询 
require("main.php"); //转到聊天页面 
} 
//密码输入错误 
else 
{ 
require("relogin.php"); 
} 
} 
//对于新用户,将其信息写入数据库 
else 
{ 
$str="insert into user (name,password,is_online) values('$user_ name','$password_en',1)"; 
$result=mysql_query($str, $link_id); //执行查询 
require("main.php"); //转到聊天页面 
} 
//关闭数据库 
mysql_close($link_id); 
?> 


示例与上一节所介绍的使用XOR加密算法来保护用户信息非常类似,其核心部分在于第16、17行使用crypt()函数获取加密后的密码,而通过在第25行比较数据库中的密码和加密后的密码是否相等来检查用户是否合法。

  下面,通过一个实例来看一下加密后的密码会变成什么样子。

  例如,用户名为rock,密码为123456,则加密后的密码为:

  12tir.zIbWQ3c

  上面就实现了一个简单的用户身份验证系统。在使用crypt()保护重要的机密信息时,需要注意的是,在缺省状态下使用crypt()并不是最安全的,只能用在对安全性要求较低的系统中。
探讨:如何使用PhpDocumentor生成文档
使用Sphinx对索引进行搜索
解析在PHP中使用全局变量的几种方法
关于crontab的使用详解
解析PHPExcel使用的常用说明以及把PHPExcel整合进CI框架的介绍
解析PHP中DIRECTORY_SEPARATOR,PATH_SEPARATOR两个常量的作用
关于查看MSSQL 数据库 用户每个表 占用的空间大小
在yii中新增一个用户验证的方法详解
浅析Yii中使用RBAC的完全指南(用户角色权限控制)
jQuery+php实现ajax文件即时上传的详解
使用session判断用户登录用户权限(超简单)
web站点获取用户IP的安全方法 HTTP_X_FORWARDED_FOR检验
PHP+jQuery实现自动补全功能源码
Zend的Registry机制的使用说明
php 无法加载mcrypt.dll的解决办法
PHP输出数组中重名的元素的几种处理方法
通过缓存数据库结果提高PHP性能的原理介绍
PHP中使用foreach和引用导致程序BUG的问题介绍
PHP获取用户的浏览器与操作系统信息的代码
PHP系列学习之日期函数使用介绍
UCenter 批量添加用户的php代码
注册页面之前先验证用户名是否存在的php代码
PHP中使用unset销毁变量并内存释放问题
PHP Warning: PHP Startup: Unable to load dynamic library \ D:/php5/ext/php_mysqli.dll\
php中使用接口实现工厂设计模式的代码
php中jQuery插件autocomplate的简单使用笔记
php 的加密函数 md5,crypt,base64_encode 等使用介绍
php 计划任务 检测用户连接状态
php提示无法加载或mcrypt没有找到 PHP 扩展 mbstring解决办法
phpMyAdmin出现无法载入 mcrypt 扩展,请检查PHP配置的解决方法
php中使用cookie来保存用户登录信息的实现代码
PHP mcrypt可逆加密算法分析
无法载入 mcrypt 扩展,请检查 PHP 配置终极解决方案
©2014-2024 dbsqp.com