我也是PHP新手,通过w3cschool了解了一下php基本原理之后就开写了。但仍是菜鸟。
先不管3DES加密的方法对不对,方法都是网上的,在运行的时候报了个错,把小弟整死了。找来找去终于自己摸出了方法。
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
<?php /** * * PHP版3DES加解密类 * * 可与java的3DES(DESede)加密方式兼容 * * @Author: Luo Hui (farmer.luo at gmail.com) * * @version: V0.1 2008.12.04 * */ class Crypt3Des { public $key = "01234567890123456789012345678912" ; public $iv = "23456789" ; //like java: private static byte[] myIV = { 50, 51, 52, 53, 54, 55, 56, 57 }; //加密 public function encrypt( $input ) { $input = $this ->padding( $input ); $key = base64_decode ( $this ->key); $td = mcrypt_module_open( MCRYPT_3DES, '' , MCRYPT_MODE_CBC, '' ); //使用MCRYPT_3DES算法,cbc模式 mcrypt_generic_init( $td , $key , $this ->iv); //初始处理 $data = mcrypt_generic( $td , $input ); //加密 mcrypt_generic_deinit( $td ); //结束 mcrypt_module_close( $td ); $data = $this ->removeBR( base64_encode ( $data )); return $data ; } //解密 public function decrypt( $encrypted ) { $encrypted = base64_decode ( $encrypted ); $key = base64_decode ( $this ->key); $td = mcrypt_module_open( MCRYPT_3DES, '' ,MCRYPT_MODE_CBC, '' ); //使用MCRYPT_3DES算法,cbc模式 mcrypt_generic_init( $td , $key , $this ->iv); //初始处理 $decrypted = mdecrypt_generic( $td , $encrypted ); //解密 mcrypt_generic_deinit( $td ); //结束 mcrypt_module_close( $td ); $decrypted = $this ->removePadding( $decrypted ); return $decrypted ; } //填充密码,填充至8的倍数 public function padding( $str ) { $len = 8 - strlen ( $str ) % 8; for ( $i = 0; $i < $len ; $i ++ ) { $str .= chr ( 0 ); } return $str ; } //删除填充符 public function removePadding( $str ) { $len = strlen ( $str ); $newstr = "" ; $str = str_split ( $str ); for ( $i = 0; $i < $len ; $i ++ ) { if ( $str [ $i ] != chr ( 0 )) { $newstr .= $str [ $i ]; } } return $newstr ; } //删除回车和换行 public function removeBR( $str ) { $len = strlen ( $str ); $newstr = "" ; $str = str_split ( $str ); for ( $i = 0; $i < $len ; $i ++ ) { if ( $str [ $i ] != '\n' and $str [ $i ] != '\r' ) { $newstr .= $str [ $i ]; } } return $newstr ; } } //test $input = "1qaz2ws" ; echo "plainText:" . $input . "<br/>" ; $crypt = new Crypt3Des(); echo "Encode:" . $crypt ->encrypt( $input ). "<br/>" ; echo "Decode:" . $crypt ->decrypt( $crypt ->encrypt( $input )); ?> |
代码可以不看,就看里面的一句:$td = mcrypt_module_open( MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');报错的就是他。
我搜寻了一大堆解决方法,正确的方法应该是(仅用于windows系统哦):
当运行php的服务器端缺少libmcrypt.dll时使用函数mcrypt_module_open进行解密会出现此错误。
在服务器上做如下设置可解决。
到网上下载一个php的mcrypt模块安装包,只需要libmcrypt.dll文件即可(一般官网上下载的,php目录下已经有的)
1.将libmcrypt.dll复制到system32目录或php安装目录下的extensions目录下
2.将libmcrypt.dll复制到apache安装目录的bin目录下
3.到windows目录下找到php.ini文件,打开它
4.找到; Directory in which the loadable extensions (modules) reside.
extension_dir = "./" 如:extension_dir = "D:\php5\ext"
这两行,要使extension_dir指向的目录下能找到libmcrypt.dll,或系统path下有libmcrypt.dll
5.找到;Windows Extensions 项下面的;extension=php_mcrypt.dll这一行和;extension=php_iconv.dll(我的没有,省略了)这两行,去掉前面的分号
ps:刚开始看网上的解决方法,有的说修改php安装目录下的php.ini,但是修改后是没用的。一定要修改windows目录下的php.ini!