PHP/Java的DES加密解密

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";

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值