分类: Mysql/postgreSQL
2008-04-01 19:34:36
4_3_Y7+E
(1)根据其提交的用户名(明文)和密码(密钥)信息重新加密,并使用加密后的信息与数据库中存储的密码信息进行比较,如果相等,则用户合法,否则,为非法用户。 qBv/r M
! /rI6ly
(2)根据数据库中存储的密码信息(明文)和用户输入的密码(密钥)信息进行解密,并把加密后的信息与用户提交的用户名进行比较,如果相等,则用户合法,否则,为非法用户。 mcUb?fVsc
oTqKDG nv
两种方式都可以实现第3个目的,本例,将采用第2种方式。本例的实现代码可在18.4.1节“用户登录”和18.4.2节“检查用户”的实现基础之上实现,其中“用户登录”页面无需变化,“检查用户”的实现参考如下。 |0 #Uix
)J, U qE
1 <?php za 6xKIL
2 session_start(); //装载Session库,一定要放在首行 !}GI<
3 $user_name=$_POST["user_name"]; ; L!19 8ak
4 session_register("user_name"); //注册$user_name变量,注意没有$符号 RYXUycz:
5 &HYU0h
6 require_once("sys_conf.inc"); //系统配置文件,包含数据库配置信息 BkT.5*UHk
7 require_once("encrypy_xor.php"); //包含xor加密函数文件 G""=@G7
8 >hTmtIS
9 //连接数据库 "h1{kym4
10 $link_id=mysql_connect($DBHOST,$DBUSER,$DBPWD); YaU/ _V4
11 mysql_select_db($DBNAME); //选择数据库my_chat 6ELX+.nwb!
12 y!z2dlA /
13 //查询是否存在登录用户信息 44d >)3"`]
14 $str="select name,password from user where name ='$user_name'"; AS(FX};}
15 $result=mysql_query($str,$link_id); //执行查询 "sFw8(8y
16 @$rows=mysql_num_rows($result); //取得查询结果的记录笔数 R}|3\L`R
17 $user_name=$_SESSION["user_name"]; Vl*N2jn
18 $password=$_POST["password"]; D KpI2
19 $password_en=myEncrypt($user_name,$password); //加密用户信息 Jb"j/akp
20 UVrOPEOV
21 //对于老用户 tyLj0L/
22 if($rows!=0) W'iok3abA
23 { +j8_,u
24 list($name,$pwd)=mysql_fetch_row($result); 5usP-9/!^
25 $password_de=myDecrypt($pwd,$password); //解密用户信息 HND[Fhr
26 4[!@| R'a|
27 //如果密码输入正确 Q$]OM0
28 if($user_name==$password_de) ~B{Q
29 { eZ Wo6O
30 $str="update user set is_online =1 where name ='$user_name' and password='$password_en'"; 6JB+t3xT/
31 $result=mysql_query($str, $link_id); //执行查询 x) 0n"j
32 require("main.php"); //转到聊天页面 |gfR[F|Y
33 } AeV~^A+!3
34 //密码输入错误 "[08G^xU
35 else E s g)b 6
36 { z_sj>B?h
37 require("relogin.php"); YjpKg9ar
38 } r`%YAHh
39 } ^b? &z\
40 //对于新用户,将其信息写入数据库 KPpXwg H*
41 else D|'X)bs
42 { ] 6Izh
43 $str="insert into user (name,password,is_online) values('$user_name', '$password_en',1)"; F4]>)x_
44 $result=mysql_query($str, $link_id); //执行查询 "[Shc>
45 require("main.php"); //转到聊天页面 o`lI{VsLJu
46 } \F4 ;8 E%l
47 //关闭数据库 O uissYJH
48 mysql_close($link_id); oV{ jka
49 ?> O%H5[
&ge?hP.Y&
第7行引入了加密函数文件encrypy_xor.php,包括上一小节介绍的两个函数。 {G 6,"GR
;r{pp[rV
第19行,使用用户提交的用户名和密码得到加密后的密码值,并且对于新用户,在第44行将这个加密后的值存储在数据库中。 o5+@r
=Ai NF
另外,对于老用户,在第24获取数据库中用户名和加密后的密码信息,并在25行利用这两个值进行解密,然后在第28行通过比较解密后的值与用户提交的用户名信息来检查用户的合法性。 XXt,
z]2Gr$y
自动生成密钥 | snig4N
>R; ZG7
上一部分介绍了如何使用XOR加密算法进行对用户信息的加密,其中,用户所输入的口令信息实际上成为了加密算法中的密钥,而用户名作为明文使用,虽然这能很好地完成功能,但是在逻辑上,这种方法似乎有些不合理。 dn"q[|pM
Lb IR# *
本文将介绍一种自动生成密钥的技术,可以使用自动生成的密钥对用户提交的密码明文加密,使逻辑更加合理一些。
o *qHt3va
本例,假设生成的密钥为512位。代码如下。 77&wzrW
q}v(cw3C
1 <!--keygen.php:自动生成密钥------------------------------------> bRgk|bwg
2 <?php Owgu0Uf)
3 \L<,gx8y
4 //自动生成长度为$len的密钥 2D{/d
5 function generate_key($len) BueQy
6 { x.7GzW){
7 $lowerbound = 35 ; Gh~EG[\
8 $upperbound = 96 ; "[]DJ
9 $strMyKey = ""; zZ2v^(P`}D
10 _:he
11 for($i=1;$i<=$len;$i ) lXHXZQ?Z'
12 { s<7p ])}}
13 $rnd=rand(0,100); //产生随机数 .]tou(7
14 $k = (($upperbound - $lowerbound) 1) * $rnd $lowerbound; K_Ls1,]
15 $strMyKey=$strMyKey.$k; )xrC/14i
16 } B,KY_=;
17 return $strMyKey; O2+WZN@Tw9
18 } pYcx!pR
19 Aw<[}p|}gw
20 //将密钥写入文件$file_name jwW.tf9x \
21 function write_key($key,$file_name) 3?$@A+*D
22 { hHHlN}q.lu
23 $filename="C:\key.txt"; ;LmRZ
24 $key=generate_key($key,512); pf*%Dn2y
25 }}S`Meh O
26 //使用添加模式打开$filename,文件指针将会在文件的末尾 N,k.j2K
27 if(!$handle=fopen($filename,'w')) ^g>brFaws
28 { =^SF(xk{
29 print"不能打开文件$filename"; uy3'v%
30 exit; 5%C~\nA0VZ
31 } g ]s&l
32 abp7$*
33 //将$key写入到我们打开的文件中。 ovIJ`hv Xx
34 if(!fwrite($handle,$key)) 't?l{JK%
35 { >NM?C
36 print"不能写入到文件$filename"; kIx.4>D
37 exit; 9vX*:/<x
38 } J'RfLoh^&-
39 fclose($handle); m:]#
40 } a (hm_Klt
41 =rnhkD$_)
42 //读取密钥文件中的密钥 I'=R)=u=
43 function get_key($file_name) Ei(nk]
44 { ^pe_ Q1Q2
45 //打开文件 F='QTU1_
46 $fp = fopen ($file_name, "r"); w:a"|@j
47 $result="";
48 //逐行读取 Y>'C6_oc
49 while (!feof($fp)) <*O;:hZpS]
50 { p.:7VDIr
51 $buffer = fgets($fp, 4096); w<`[:Q[QpN
52 $result=$result.$buffer; YIBG>9o
53 } ]1y! *
54 return $result; gD,* %(H
55 } 5T;9wAZ
56 ;n-zx%lzb
57 ///* kXM7j+Zo
58 $KeyLocation = "C:\key.txt"; //保存密钥的文件 )zMZ_&8s=
59 $key="123456"; vC, .)h
60 write_key($key,$KeyLocation); q6@Zy vyV
61 echo get_key($KeyLocation); @Z[xmdP(
62 //*/ jL&]X
63 ?> ~{:IH&vE
}ZwY;A)
代码包括3个函数。 dYLb?
1 zM~L)@
·generate_key($len):自动生成长度为$len的密钥 %vjY*&nM
jIrj,KK
·write_key($key,$file_name):将密钥写入文件$file_name .}R9lx XL
vO?/>KL+
·get_key($file_name):读取密钥文件$file_name中的密钥值 BEB $yU'H
39./0h\
在使用时,当用户第一次登录系统时,自动为其生成密钥值,对于这个密钥值,可以有两种方式来处理。 hs36'
Lj1et_w$.
(1)将其存入数据库的某个字段中,这种方法的缺点是密钥在数据库中的安全性无法得到保证; .7!w, /@9@
,eE$wu
(2)将这个密钥保存在用户本地的文件中,这样就可以避免密钥被别人获取,但这种方式的缺点是,当用户使用其他机器访问系统时,就无法登录。 d9rMP
-R)+Nm2#
本例中,将使用第2种方式。 q5(Q pw
Dr^64p6
具体地,上面代码第11~18行通过生成随机数的方式来不断生成密钥,并通过一个计算来增强其复杂性。其中的lowerbound和upperbound的数值其实就是你想使用来加密的ASCII字符范围。下面是生成的一个密钥文件示例。 kUr 9
[Ig6u - y>
208123915925183361116049369344372701567721435181102718332639307390344373445407 [ac-YFHE
x1+=y>7
524316475863232913993383189547474747394154915312639841226741894189965623523913 nsF|{5_-!t
iq+JvQ :F
011164730113445201935692839710274127251577929493941487145611337531549110895367 hKl%ZLcA
+q
593586318332391170941272701152344371709270125776235313540032267139933835677407 _wuN28y}
NCsR%p0O
617384135696111239130732949469623520815987524358635491542913374933524334454251 v7vz'" b^
y-byONIo8
400327015367133759324537171709152357391089524342514685239122673135531363151191 l_(I#4f
R5QB5@JNH
833412771743139654… rZc"xp"
Lca# )K ]=
最后,需要把密钥保存在服务器上一个安全的地方,然后就可以利用其和诸如XOR这样的加密算法来对用户信息进行加密/解密了。