PHP 版本 DES 加解密

<?php

namespace App\Utilities;

class DES
{
    public $key;
    public $iv;

    function __construct($key, $iv = 0)
    {
        $this->key = $key;
        if ($iv == 0) {
            $this->iv = $key;
        } else {
            $this->iv = $iv;
        }
    }

    function encrypt($str)
    {
        return base64_encode(openssl_encrypt($str, 'DES-CBC', $this->key, OPENSSL_RAW_DATA, $this->iv));
    }

    function decrypt($str) {
        $str = openssl_decrypt(base64_decode($str), 'DES-CBC', $this->key, OPENSSL_RAW_DATA | OPENSSL_NO_PADDING, $this->iv);
        return rtrim($str, "\x1\x2\x3\x4\x5\x6\x7\x8");
    }
}

$res = "MDQGx7yYdmYEDXNWr5rzDvsvT3eVG91rvnkdDZi8y2Y%3D";
$crypt = new DES($key);
var_dump($crypt->decrypt(urldecode($res)));
?>
  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP中的3DES加密解密可以使用mcrypt扩展库实现。下面是一个使用3DES ECB模式进行加密解密的示例代码: ```php // 加密函数 function encrypt($data, $key) { $key = substr($key, 0, 24); $data = pkcs5_pad($data, 8); $mcrypt = mcrypt_module_open('tripledes', '', 'ecb', ''); $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($mcrypt), MCRYPT_RAND); mcrypt_generic_init($mcrypt, $key, $iv); $encrypted = mcrypt_generic($mcrypt, $data); mcrypt_generic_deinit($mcrypt); mcrypt_module_close($mcrypt); return base64_encode($encrypted); } // 解密函数 function decrypt($data, $key) { $key = substr($key, 0, 24); $data = base64_decode($data); $mcrypt = mcrypt_module_open('tripledes', '', 'ecb', ''); $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($mcrypt), MCRYPT_RAND); mcrypt_generic_init($mcrypt, $key, $iv); $decrypted = mdecrypt_generic($mcrypt, $data); mcrypt_generic_deinit($mcrypt); mcrypt_module_close($mcrypt); return pkcs5_unpad($decrypted); } // PKCS5填充函数 function pkcs5_pad($data, $blocksize) { $pad = $blocksize - (strlen($data) % $blocksize); return $data . str_repeat(chr($pad), $pad); } // PKCS5去填充函数 function pkcs5_unpad($data) { $pad = ord($data[strlen($data) - 1]); if ($pad > strlen($data)) { return false; } if (strspn($data, chr($pad), strlen($data) - $pad) != $pad) { return false; } return substr($data, 0, -1 * $pad); } // 使用示例 $key = '123456789012345678901234'; $data = 'Hello World!'; $encrypted = encrypt($data, $key); echo '加密后的数据:' . $encrypted . "\n"; $decrypted = decrypt($encrypted, $key); echo '解密后的数据:' . $decrypted . "\n"; ``` 在上述代码中,encrypt()函数用于加密数据,decrypt()函数用于解密数据。其中,$data表示待加密的数据,$key表示加密密钥。在加密过程中,需要先对数据进行PKCS5填充。解密时,需要先将密文进行base64解码,然后再进行解密操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值