java desede_java DESede加密解密 php版本

class STD3Des {

private $key  = "";

private $iv   = "";

private $mode = MCRYPT_MODE_ECB;

/**

* 构造,传递二个已经进行base64_encode的KEY与IV

*

* @param string $key

* @param string $iv

*/

function __construct($key, $iv = null) {

if (empty($key)) {

echo 'key is not valid';

exit();

}

if ($iv == null) {

$iv         = $key;

$this->mode = MCRYPT_MODE_ECB;

}

$this->key = $key;

$this->iv  = $iv;

}

/**

* 加密

* @param $value

* @return

*/

public function encrypt($value) {

$td    = mcrypt_module_open(MCRYPT_3DES, '', $this->mode, '');

$iv    = $this->mode == MCRYPT_MODE_CBC ? base64_decode($this->iv) : mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

$value = $this->PaddingPKCS7($value);

$key   = base64_decode($this->key);

mcrypt_generic_init($td, $key, $iv);

$dec   = mcrypt_generic($td, $value);

$ret   = base64_encode($dec);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $ret;

}

/**

* 解密

* @param $value

* @return

*/

public function decrypt($value) {

$td  = mcrypt_module_open(MCRYPT_3DES, '', $this->mode, '');

$iv  = $this->mode == MCRYPT_MODE_CBC ? base64_decode($this->iv) : mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

$key = base64_decode($this->key);

mcrypt_generic_init($td, $key, $iv);

$ret = trim(mdecrypt_generic($td, base64_decode($value)));

$ret = $this->UnPaddingPKCS7($ret);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $ret;

}

private function PaddingPKCS7($data) {

$block_size   = mcrypt_get_block_size('tripledes', $this->mode);

$padding_char = $block_size - (strlen($data) % $block_size);

$data .= str_repeat(chr($padding_char), $padding_char);

return $data;

}

private function UnPaddingPKCS7($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);

}

}

传入的key 需要base64下

$des = new STD3Des(base64_encode('886b4DXf0F329XC34b4b57Sd'));

$data = $des->encrypt(json_encode(array('username' => $username, 'password' => md5($password))));

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值