PHP/Java的DES加密解密

2023-09-25 7 0

保证双方使用DES加密、解密结果一致的方法(使用DES、ECB和PKCS5 Padding)

Java DES加密解密程序:

public class EncDec {
SecretKey desKey;

public void setKey(String key){
byte[] staticKey = key.getBytes();
try {
SecretKeyFactory keyfact = SecretKeyFactory.getInstance("DES");
DESKeySpec dks = new DESKeySpec(staticKey);
desKey = keyfact.generateSecret(dks);
}catch(Exception e){
Log.log("Set DES Key failed.");
Log.log(e.getMessage());
e.printStackTrace();
}
}

public String encode(String src) {
String str = "";
Log.log("Trying encoding string: " + src);
try{
Cipher c1 = Cipher.getInstance("DES/ECB/PKCS5Padding");
c1.init(Cipher.ENCRYPT_MODE, desKey);
byte[] encoded = c1.doFinal(src.getBytes());
for(int i=0;i>4&0X0F)];
ch[1] = Digest[b&0X0F];
return new String(ch);
}
}

PHP DES加密解密程序

<?php
$key = "somekeyy";

function encrypt($encrypt) {
global $key;
$encrypt = pkcs5_pad($encrypt);
$iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_DES, MCRYPT_MODE_ECB), MCRYPT_RAND);
$passcrypt = mcrypt_encrypt(MCRYPT_DES, $key, $encrypt, MCRYPT_MODE_ECB, $iv);
// $encode = base64_encode($encode);
// return $encode;
return bin2hex($passcrypt);
}

function decrypt($decrypt) {
global $key;
// $decoded = base64_decode($decrypt);
$decoded = pack("H*", $decrypt);
$iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_DES, MCRYPT_MODE_ECB), MCRYPT_RAND);
$decrypted = mcrypt_decrypt(MCRYPT_DES, $key, $decoded, MCRYPT_MODE_ECB, $iv);
return pkcs5_unpad($decrypted);
}

function pkcs5_unpad($text)
{
$pad = ord($text{strlen($text)-1});

if ($pad > strlen($text)) return $text;
if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return $text;
return substr($text, 0, -1 * $pad);
}

function pkcs5_pad($text)
{
$len = strlen($text);
$mod = $len % 8;
$pad = 8 - $mod;
return $text.str_repeat(chr($pad),$pad);
}

 

//截中文英文子串

function msubstr($str, $start, $len) {
    $tmpstr = "";
    $strlen = $start + $len;
    for($i = 0; $i < $strlen; $i++) {
        if(ord(substr($str, $i, 1)) > 0xa0) {
            $tmpstr .= substr($str, $i, 2);
            $i++;
        } else
            $tmpstr .= substr($str, $i, 1);
    }
    return $tmpstr;
}

 

echo encrypt("123456789abcdefg");
echo "/n";
echo decrypt("129E91B969FA1FAA72D8567F2E5B22A7EFFC71AE977814B8");
echo "/n";

?>

代码编程
赞赏

相关文章

小议怎么保证系统线上安全
JMS 与 AMQP 区别
数据库优化之innodb_flush_log_at_trx_commit参数性能优化
java代码优化的小建议
SpringCloud 链路追踪应用
各种文件系统特性说明以及对比