网站建设
  简约型网页设计套餐998
  实惠型网站建设套餐2580
  综合型网站制作套餐4980
  网站改版与网站维护
  行业网站建设方案
  大型网站建设解决方案
  企业网站建设流程
  帝网科技网站设计与网站制作
建站FAQ
·网站空间问题解答
·企业邮箱问题解答
 
酷站欣赏
·房产酷站(379)
·综合门户(8 9)
·建筑装饰(603)
·手机通讯(354)
·生活购物(376)
·医疗保健(199)
·文化摄影(602)
·休闲体育(399)
>>更多酷站欣赏
网站优化
·Google(谷歌)优化   ·百度(BaiDu)优化
·雅虎(Yahoo)优化    ·Alexa排名优化   
·Google AdSense   ·DMOZ目录提交  
建站知识
·网站建设知识·网站名词解释·网站运营知识
·网络营销知识·搜索引擎知识·实用技术文摘
网站推广
百度网站推广 google网站推广
搜狐网站推广 网易网站推广
新浪网站推广   雅虎网站推广
  您当前位置: 当前位置:帝网科技 >> web开发 >> PHP专栏 >> 浏览文章
 
 
PHP中使用crypt()实现用户身份验证
作者:袁袁整理 来源:帝网科技 日期:2008年09月15日 点击数:


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

了解crypt()

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

stringcrypt(stringinput_string[,stringsalt])

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

print"Mysystemsaltsizeis:".CRYPT_SALT_LENGTH;

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

表crypt()支持四种加密算法

    算法     Salt长度     CRYPT_STD_DES     2-character(Default)     CRYPT_EXT_DES     9-character     CRYPT_MD5     12-characterbeginningwith$1$     CRYPT_BLOWFISH     16-characterbeginningwith$2$
从表面上看,crypt()的函数似乎没有什么用处,但该函数的确被广泛用来保证系统密码的完整性。因为,单向加密的口令即使落入第三方的手里,由于不能被还原为明文,也没有什么大用处。

用crypt()实现用户身份验证

上一部分简单介绍了crypt()函数的功能,下面利用其来实现用户的身份验证,其所要实现的目标同19.2.3节所介绍的一致。

    1<!--check_user_crypt.php:使用crypt()函数验证用户---------------->
2<?php
3$user_name=$_POST["user_name"];
4require_once("sys_conf.inc");//系统配置文件,包含数据库配置信息
5
6//连接数据库
7$link_id=mysql_connect($DBHOST,$DBUSER,$DBPWD);
8mysql_select_db($DBNAME);//选择数据库my_chat
9
10//查询是否存在登录用户信息
11$str="selectname,passwordfromuserwherename='$user_name'";
12$result=mysql_query($str,$link_id);//执行查询
13@$rows=mysql_num_rows($result);//取得查询结果的记录笔数
14$user_name=$_SESSION["user_name"];
15$password=$_POST["password"];
16$salt=substr($password,0,2);
17$password_en=crypt($password,$salt);//使用crypt()对用户密码进行加密
18
19//对于老用户
20if($rows!=0)
21{
22list($name,$pwd)=mysql_fetch_row($result);
23
24//如果密码输入正确
25if($pwd==$password_en)
26{
27$str="updateusersetis_online=1wherename='$user_name'andpassword='$password_en'";
28$result=mysql_query($str,$link_id);//执行查询
29require("main.php");//转到聊天页面
30}
31//密码输入错误
32else
33{
34require("relogin.php");
35}
36
37}
38//对于新用户,将其信息写入数据库
39else
40{
41$str="insertintouser(name,password,is_online)values('$user_name','$password_en',1)";
42$result=mysql_query($str,$link_id);//执行查询
43require("main.php");//转到聊天页面
44}
45//关闭数据库
46mysql_close($link_id);
47?>
示例与上一节所介绍的使用XOR加密算法来保护用户信息非常类似,其核心部分在于第16、17行使用crypt()函数获取加密后的密码,而通过在第25行比较数据库中的密码和加密后的密码是否相等来检查用户是否合法。

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

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

12tir.zIbWQ3c

上面就实现了一个简单的用户身份验证系统。在使用crypt()保护重要的机密信息时,需要注意的是,在缺省状态下使用crypt()并不是最安全的,只能用在对安全性要求较低的系统中。

  相关文章
 
·如何在PHP开启gzip页面压缩实例正文分
·如何正确运用PHP json_encode函数进行
·PHP下载断点续传的代码正文分析错误
·PHP取得客户端IP地址代码正文分析错误
·PHP判断用户IP来路的一个方法正文分析
·PHP+mysql分页代码正文分析错误
·php去除HTML标记正文分析错误
·php轻松快速缓存全站正文分析错误
·php多语言网站解决方案正文分析错误
·php图片验证码函数正文分析错误
·PHP初学者常见问题集(21问答)正文分
·分享PHP技术开发技巧正文分析错误
·cURL库功能简介:抓取网页 POST数据及
·PHP常用函数:过滤HTML字符串正文分析
·php fscanf()函数使用方法详解正文分析
·和php有关的几种常见安全详解正文分析
·php连接mysql出现乱码解决办法正文分析
·PHP非常简单的使用模板制作静态页面正
·非常简单PHP缩略图生成程序源代码正文
·无法载入 mcrypt 扩展,请检查 PHP 配置
 
 

公司环境 | 合作伙伴 | 人才招聘 | 付款方式 | 关于我们

地址:广州市天河区中山大道中120号D805 电话:020-82529556 传真:020-82529556
广州帝网网络科技有限公司 版权所有 粤ICP备08119341号