PHP使用DES进行加密和解密

DES是一种标准的数据加密算法,关于这个算法的详细介绍可以参考wiki和百度百科:
wiki百科百度百科

php中有一个扩展可以支持DES的加密算法,是:extension=php_mcrypt.dll
在配置文件中将这个扩展打开还不能够在windows环境下使用需要将PHP文件夹下的 libmcrypt.dll 拷贝到系统的 system32 目录下,这是通过phpinfo可以查看到mcrypt表示这个模块可以正常试用了。

下面是PHP中使用DES加密解密的一个例子:

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
//$input - stuff to decrypt
    //$key - the secret key to use

    function do_mencrypt($input$key)
    {
        $input = str_replace(""n", "", $input);
        $input = str_replace(""t"""$input);
        $input = str_replace(""r", "", $input);
        $key = substr(md5($key), 0, 24);
        $td = mcrypt_module_open('tripledes', '', 'ecb', '');
        $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
        mcrypt_generic_init($td$key$iv);
        $encrypted_data = mcrypt_generic($td$input);
        mcrypt_generic_deinit($td);
        mcrypt_module_close($td);
        return trim(chop(base64_encode($encrypted_data)));
    }
    
    //$input - stuff to decrypt
    //$key - the secret key to use
    
    function do_mdecrypt($input$key)
    {
        $input = str_replace(""n"""$input);
        $input = str_replace(""t", "", $input);
        $input = str_replace(""r"""$input);
        $input = trim(chop(base64_decode($input)));
        $td = mcrypt_module_open('tripledes''''ecb''');
        $key = substr(md5($key), 024);
        $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
        mcrypt_generic_init($td$key$iv);
        $decrypted_data = mdecrypt_generic($td$input);
        mcrypt_generic_deinit($td);
        mcrypt_module_close($td);
        return trim(chop($decrypted_data));

    }

cocowool

A FULL STACK DREAMER!