php 3des key 不足24位,关于3DES加密的问题

我现在这边需要跟.NET那边进行数据交互,数据是需要进行加密处理的,但是现在的问题是,我用PHP的加密处理之后和.net加密处理之后的数据不相等,他们那边的代码是没有问题的,这个是可以确认的,那么我这边的加密就有问题了,现在具体的问题不是很清楚,求各位大神指教,下面是我这边的代码:

/**

* 3DES加密处理类

*

* @author fbbin fbbin@gmail.com

* @version 1.0 beta

* @created 2014/01/07

* @logs

*/

class Crypt3Des {

/**

* 加密需要的key

* @var intval

*/

protected static $key = "";

/**

* 静态构造初始化

*

* @return Crypt3Des

*/

public static function instance($key = '') {

self::$key = $key;

return new static;

}

/**

* 对字符串进行加密

*

* @return string

*/

public function encrypt($input) {

$size = mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_ECB);

$input = $this->paddingPKCS7($input);

$key = str_pad(self::$key, 24, '0');

$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_ECB, '');

$iv = @mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

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

$data = mcrypt_generic($td, $input);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return base64_encode($data);

}

/**

* 对字符串进行解密

*

* @return string

*/

public function decrypt($encrypted) {

$encrypted = base64_decode($encrypted);

$key = str_pad(self::$key, 24, '0');

$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_ECB, '');

$iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td),MCRYPT_RAND);

$ks = mcrypt_enc_get_key_size($td);

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

$decrypted = mdecrypt_generic($td, $encrypted);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $this->pkcs5Unpad($decrypted);

}

/**

* 对字符串按照规则打包

*

* @return string

*/

public function paddingPKCS7($data) {

$block_size = mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_ECB);

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

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

return $data;

}

/**

* 对字符串按照规则解包

*

* @return string

*/

public function pkcs5Unpad($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);

}

}

使用方式:

echo Crypt3Des::instance(base64_encode('FD3BCD75678B4BABB6E8948149CA6C91'))->encrypt('1');

我这边得出的结果是:mzbVH6DmUXI=, 而正确的值应该是:sztImTSd0o;

求指教,万分感谢。

回复内容:

我现在这边需要跟.NET那边进行数据交互,数据是需要进行加密处理的,但是现在的问题是,我用PHP的加密处理之后和.net加密处理之后的数据不相等,他们那边的代码是没有问题的,这个是可以确认的,那么我这边的加密就有问题了,现在具体的问题不是很清楚,求各位大神指教,下面是我这边的代码:

/**

* 3DES加密处理类

*

* @author fbbin fbbin@gmail.com

* @version 1.0 beta

* @created 2014/01/07

* @logs

*/

class Crypt3Des {

/**

* 加密需要的key

* @var intval

*/

protected static $key = "";

/**

* 静态构造初始化

*

* @return Crypt3Des

*/

public static function instance($key = '') {

self::$key = $key;

return new static;

}

/**

* 对字符串进行加密

*

* @return string

*/

public function encrypt($input) {

$size = mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_ECB);

$input = $this->paddingPKCS7($input);

$key = str_pad(self::$key, 24, '0');

$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_ECB, '');

$iv = @mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

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

$data = mcrypt_generic($td, $input);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return base64_encode($data);

}

/**

* 对字符串进行解密

*

* @return string

*/

public function decrypt($encrypted) {

$encrypted = base64_decode($encrypted);

$key = str_pad(self::$key, 24, '0');

$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_ECB, '');

$iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td),MCRYPT_RAND);

$ks = mcrypt_enc_get_key_size($td);

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

$decrypted = mdecrypt_generic($td, $encrypted);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $this->pkcs5Unpad($decrypted);

}

/**

* 对字符串按照规则打包

*

* @return string

*/

public function paddingPKCS7($data) {

$block_size = mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_ECB);

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

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

return $data;

}

/**

* 对字符串按照规则解包

*

* @return string

*/

public function pkcs5Unpad($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);

}

}

使用方式:

echo Crypt3Des::instance(base64_encode('FD3BCD75678B4BABB6E8948149CA6C91'))->encrypt('1');

我这边得出的结果是:mzbVH6DmUXI=, 而正确的值应该是:sztImTSd0o;

求指教,万分感谢。

相关标签:php

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值