php解密之DES/3DES

<?php
date_default_timezone_set('Asia/Shanghai');
/**
 * 3DES加密解密
 * Created on 2010-03-12 by caixudong
 *
 */
//if (class_exists('DesCrypt'))
// return NULL;

class DesCrypt {
    var $key = '';
    var $deviceid = '';
    var $user = '';
    var $lsh = '';
    var $ciphertext = '';
    var $hciphertext = '';
    var $decrypted_data = '';

    /**
     * 加密
     * @param $str
     * @return string
     */
    public function en($str) {
        $cipher = mcrypt_module_open(MCRYPT_DES, '', MCRYPT_MODE_ECB, '');
        $iv     = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_DES, MCRYPT_MODE_ECB), MCRYPT_RAND);

        if (mcrypt_generic_init($cipher, substr($this->key, 0, 8), $iv) != -1) {
            $this->ciphertext = mcrypt_generic($cipher, $this->pad($str));
            mcrypt_generic_deinit($cipher);
            // 以十六进制字符显示加密后的字符
            $this->hciphertext = bin2hex($this->ciphertext);
            printf("<p>3DES encrypted:\n%s</p>", $this->ciphertext);
            printf("<p>3DES HexEncrypted:\n%s</p>", $this->hciphertext);
        }
        mcrypt_module_close($cipher);
        return $this->ciphertext;
    }

    /**
     * 解密
     * @param $str
     * @return string
     */
    public function de($str) {
        $str    = pack('H*', $str);
        $cipher = mcrypt_module_open(MCRYPT_DES, '', MCRYPT_MODE_ECB, '');
        $iv     = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_DES, MCRYPT_MODE_ECB), MCRYPT_RAND);
        if (mcrypt_generic_init($cipher, substr($this->key, 0, 8), $iv) != -1) {
            $this->decrypted_data = mdecrypt_generic($cipher, $str);
            mcrypt_generic_deinit($cipher);
        }
        mcrypt_module_close($cipher);
        return $this->unpad($this->decrypted_data);
    }

    private function pad($data) {
        $data = str_replace("\n", "", $data);
        $data = str_replace("\t", "", $data);
        $data = str_replace("\r", "", $data);
        return $data;
    }

    private function unpad($text) {
        $pad = ord($text{strlen($text) - 1});
        if ($pad > strlen($text)) {
            return false;
        }
        if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) {
            return false;
        }
        return substr($text, 0, -1 * $pad);

    }

}
如果是3des,将MCRYPT_DES修改为MCRYPT_3DES,个人笔记
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值