PHP函数crypt()的功能介绍

开发 后端
党你想创建一个PHP脚本来限制一个目录的访问权限,实现数据加密功能时,你将会用到PHP函数crypt(),下面我们就来具体分析一下它的用法。

我们知道在PHP中有实现数据加密的功能,我们今天将为大家介绍的是其中一个可以实现数据加密功能的函数——PHP函数crypt()。 作为PHP函数crypt()的一个例子,考虑这样一种情况,你希望创建一段PHP脚本程序限 制对一个目录的访问,只允许能够提供正确的用户名和口令的用户访问这一目录。

我将把资料存储在我喜欢的数据库MySQL的一个表中。下面我 们以创建这个被称作members的表开始我们的例子:

 

mysql>CREATE TABLE members (   
->username CHAR(14) NOT NULL,   
->password CHAR(32) NOT NULL,   
->PRIMARY KEY(username)   
->);  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.

#t#然后,我们假定下面的数据已经存储在该表中:

用户名 密码
clark keloD1C377lKE
bruce ba1T7vnz9AWgk
peter paLUvRWsRLZ4U

PHP函数crypt()中的这些加密的口令对应的明码分别是kent、banner和parker。注意一下每个口令的前二个字母, 这是因为我使用了下面的代码,根据口令的前二个字母创建干扰串的:

 

$enteredPassword.   
$salt = substr($enteredPassword, 0, 2);   
$userPswd = crypt($enteredPassword, $salt);   
// $userPswd然后就和用户名一起存储在MySQL 中  
  • 1.
  • 2.
  • 3.
  • 4.

 

我将使用Apache的口令-应答认证配置提示用户输入用户名和口令,一个鲜为人知的有关PHP的信息是,它可以把Apache 的口令-应答系统输入的用户名和口令识别为$PHP_AUTH_USER和$PHP_AUTH_PW,我将在身份验证脚本中用到这二个变量。花一些时间仔细阅读下 面的脚本,多注意一下其中的解释,以便更好地理解下面的代码:

PHP函数crypt()和Apache的口令-应答验证系统的应用

< ?php   
$host = "localhost";   
$user = "zorro";   
$pswd = "hell odolly";   
$db = "users";   
// Set authorization to False   
$authorization = 0;   
// Verify that user has entered
 username and password   
if (isset($PHP_AUTH_USER) && 
isset($PHP_AUTH_PW)) :   
mysql_pconnect($host, $user, 
$pswd) or die("Can\'t connect to MySQL   
server!");    mysql_select_db($db) or die
("Can\'t select database!");   
// Perform the encryption    $salt = substr($PHP_AUTH_PW, 0, 2);    $encrypted_pswd = crypt($PHP_AUTH_PW, $salt);    // Build the query    $query = "SELECT username FROM members WHERE    username = \'$PHP_AUTH_USER\' AND    password = \'$encrypted_pswd\'";    // Execute the query    if (mysql_numrows(mysql_query($query)) == 1) :    $authorization = 1;    endif;    endif;    // confirm authorization    if (! $authorization) :    header(\'WWW-Authenticate: 
Basic 
realm="Private"\');    header(\'HTTP/1.0 401 Unauthorized\');    print "You are unauthorized 
to enter this area.";   
exit;    else :    print "This is the secret data!";    endif;    ?>  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.

 

上面就是一个核实用户访问权限的简单身份验证系统。在使用PHP函数crypt()保护重要的机密资料时,记住在缺省状态下使用的PHP函数crypt()并不是最安全的,只能用在对安全性要求较低的系统中,如果需要较高的安全性能,就需要我在本篇文章的后面介绍的算法。

责任编辑:曹凯 来源: CSDN
相关推荐

2009-12-01 15:14:32

PHP Substr库

2011-07-07 14:14:41

PHP模版

2010-12-22 09:56:24

PHP

2009-12-11 17:39:47

PHP String函

2009-12-02 20:15:12

PHP header函

2009-11-25 14:06:53

PHP函数arsort

2009-12-10 09:59:49

PHP读取目录函数

2009-12-04 13:54:11

PHP JSON互转函

2009-11-27 13:14:07

PHP函数strist

2009-11-26 10:23:17

2009-11-26 18:28:07

PHP函数trim()

2009-11-18 13:11:29

PHP核心

2010-05-31 09:19:53

PHP

2009-11-30 15:10:46

PHP substr函

2011-07-07 17:16:43

PHP

2009-11-26 15:42:18

PHP函数mail()

2009-11-30 18:21:21

PHP删除数组元素

2009-11-26 13:50:11

PHP函数str_re

2009-11-25 17:48:18

PHP文件系统相关函数

2009-11-30 17:49:51

PHP函数preg_s
点赞
收藏

51CTO技术栈公众号