PHP编程:PHP中的加密功效(1)
学习了六个多月PHP了,还是个新手,在这里受到了很多人的帮助,谢谢你们!数据加密在咱们生涯中的位置已愈来愈主要了,特别是思索到在收集上产生的大批买卖和传输的大批数据。假如关于采取平安办法有乐趣的话,也必定会有乐趣懂得PHP供应的一系列平安功效。在本篇文章中,咱们将引见这些功效,供应一些根基的用法,以便你可以为本人的使用软件中增添平安功效。
准备常识
在具体引见PHP的平安功效之前,咱们需求花点工夫来向没有接触过这方面内容的读者引见一些有关暗码学的根基常识,假如对暗码学的根基概念已十分熟习,就能够跳曩昔这一局部。
暗码学可以浅显地被描写为对加/解密的研讨和实行,加密是将易懂的材料转换为不容易懂材料的进程,解密则是将不容易懂的材料转换为本来易懂材料的进程。不容易懂的材料被称作暗码,易懂的材料被称作密码。
数据的加/解密都需求必定的算法,这些算法可以十分地复杂,如有名的凯撒码,但以后的加密算法要绝对庞杂很多,个中一些使用现有的办法乃至是没法破译的。
PHP的加密功效
只需有一点利用非Windows平台经历的人能够对crypt()也相当熟习,这一函数完成被称作单向加密的功效,它可以加密一些密码,但不克不及够将暗码转换为本来的密码。虽然从外表下去看这仿佛是一个没有甚么用途的功效,但它切实其实被普遍用来包管体系暗码的完全性。由于,单向加密的口令一旦落入第三方人的手里,因为不克不及被复原为明文,因而也没有甚么大用途。在验证用户输出的口令时,用户的输出采取的也是单向算法,假如输出与存储的经加密后的口令相婚配,则输出的口信必定是准确的。
PHP一样供应了利用其crypt()函数完成单向加密功效的能够性。我将在这里扼要地引见该函数:
string crypt (string input_string [, string salt])
个中的input_string参数是需求加密的字符串,第二个可选的salt是一个位字串,它可以影响加密的密码,进一步地扫除被称作估计算进击的能够性。缺省情形下,PHP利用一个2个字符的DES搅扰串,假如你的体系利用的是MD5(我将在今后引见MD5算法),它会利用一个12个字符的搅扰串。特地说一下,可以经由过程履行上面的号令发明体系将要利用的搅扰串的长度:
print "My system salt size is: ". CRYPT_SALT_LENGTH;
体系也能够撑持其他的加密算法。crypt()撑持四种算法,上面是它撑持的算法和响应的salt参数的长度:
算法 Salt长度
CRYPT_STD_DES 2-character (Default)
CRYPT_EXT_DES 9-character
CRYPT_MD5 12-character beginning with $1$
CRYPT_BLOWFISH 16-character beginning with $2$
用crypt()完成用户身份验证
作为crypt()函数的一个例子,思索如许一种情形,你但愿创立一段PHP剧本法式限制对一个目次的会见,只答应可以供应准确的用户名和口令的用户会见这一目次。我将把材料存储在我喜好的数据库MySQL的一个表中。上面咱们以创立这个被称作members的表入手下手咱们的例子:
mysql>CREATE TABLE members (
->username CHAR(14) NOT NULL,
->password CHAR(32) NOT NULL,
->PRIMARY KEY(username)
->);
然后,咱们假定上面的数据已存储在该表中:
用户名 暗码
clark keloD1C377lKE
bruce ba1T7vnz9AWgk
peter paLUvRWsRLZ4U
这些加密的口令对应的密码分离是kent、banner和parker。注重一下每一个口令的前二个字母,这是由于我利用了上面的代码,依据口令的前二个字母创立搅扰串的:
$enteredPassword.
$salt = substr($enteredPassword, 0, 2);
$userPswd = crypt($enteredPassword, $salt);
// $userPswd然后就和用户名一同存储在MySQL中
我将利用Apache的口令-应对认证设置装备摆设提醒用户输出用户名和口令,一个不为人知的有关PHP的信息是,它可以把Apache的口令-应对体系输出的用户名和口令辨认为$PHP_AUTH_USER和$PHP_AUTH_PW,我将在身份验证剧本顶用到这二个变量。花一些工夫细心浏览上面的剧本,多注重一下个中的注释,以便更好地舆解上面的代码:
crypt()和Apache的口令-应对验证体系的使用
<?php
$host = "localhost";
$user = "zorro";
$pswd = "hellodolly";
$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;
?>
下面就是一个核适用户会见权限的复杂身份验证体系。在利用crypt()回护主要的秘密材料时,记住在缺省形态下利用的crypt()并非最平安的,只能用在对平安性请求较低的体系中,假如需求较高的平安功能,就需求我在本篇文章的前面引见的算法。
上面我将引见另外一个PHP撑持的函数━━md5(),这一函数利用MD5散列算法,它有几种很风趣的用法值得一提:
混编
一个混编函数可以将一个可变长度的信息变换为具有固定长度被混编过的输入,也被称作“信息文摘”。这是非常有效的,由于一个固定长度的字符串可以用来反省文件的完全性和验证数字签名和用户身份验证。因为它合适于PHP,PHP内置的md5()混编函数将把一个可变长度的信息转换为128位(32个字符)的信息文摘。混编的一个风趣的特色是不克不及经由过程剖析混编后的信息失掉本来的密码,由于混编后的了局与本来的密码内容没有依附关系。 即使只改动一个字符串中的一个字符,也将使得MD5混编算法盘算出二个一模一样的了局。咱们起首来看下表的内容及其响应的了局:
利用md5()混编字符串
<?php
$msg = "This is some message that I just wrote";
$enc_msg = md5($msg);
print "hash: $enc_msg ";
?>
了局:
hash: 81ea092649ca32b5ba375e81d8f4972c
注重,了局的长度为32个字符。再来看一下上面的表,个中的$msg的值有了一点巨大的变更:
利用md5()对一个略微变更的字符串停止混编
<?php
//注重,message中少了一个s
$msg = "This is some mesage that I just wrote";
$enc_msg = md5($msg);
print "hash2: $enc_msg <br /><br />";
?>
《PHP+MYSQL WEB开发(第三版)》号称圣经级,(也许是个不错的选择(声明:作者没给我啥好处费,我也不是书托,隔着大老远,我连他老兄的面都没见过的说-_-) 学习php的目的往往是为了开发动态网站,phper就业的要求也涵盖了很多。我大致总结为:精通php和mysql 曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线\\\\\\\'_\\\\\\\' ; 首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。 作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。 本人接触php时间不长,算是phper中的小菜鸟一只吧。由于刚开始学的时候没有名师指,碰过不少疙瘩,呗很多小问题卡过很久,白白浪费不少宝贵的时间,在次分享一些子的学习的心得。 我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。 这些都是最基本最常用功能,我们这些菜鸟在系统学习后,可以先对这些功能深入研究。 如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了, 最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。 兴趣是最好的老师,百度是最好的词典。 使用 jquery 等js框架的时候,要随时注意浏览器的更新情况,不然很容易发生框架不能使用。 作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。 最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。 首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。 当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标, Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81 曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线\\\\\\\'_\\\\\\\' ; 首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。
页:
[1]