php做DES加密,仿PKCS5填充方式做自定义字符填充
2010-08-17 18:43
471 查看
首先,我们来看手册(只有很旧的手册上有)上的这一段代码,剖析了PKCS5填充过程。
PKCS5填充的是要填充的字节数,下面看我据此改造的可以填充任意字符的DES加密。
<?php function encrypt_something($input) { $size = mcrypt_get_block_size('des', 'ecb'); $input = pkcs5_pad($input, $size); $key = 'YOUR SECRET KEY HERE'; $td = mcrypt_module_open('des', '', '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); $data = base64_encode($data); return $data; } //填充部分,如果block为8字节,注意当加密字节数刚好是8的整数倍,也要在结尾填充8个字节 function pkcs5_pad ($text, $blocksize) { $pad = $blocksize - (strlen($text) % $blocksize); return $text . str_repeat(chr($pad), $pad); } function pkcs5_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); } ?>
PKCS5填充的是要填充的字节数,下面看我据此改造的可以填充任意字符的DES加密。
<?php function makePattern( $key, $text ) { $blocksize = mcrypt_get_block_size( 'des', 'ecb' ); $padn = $blocksize - ( strlen( $text ) % $blocksize ); $pad = substr( strrev( $text ), 0, 1 ); //注意此处为我自定义的填充字符 $text = $text.str_repeat( $pad, $padn ); $td = mcrypt_module_open( 'des', '', 'ecb', '' ); $iv = mcrypt_create_iv ( mcrypt_enc_get_iv_size( $td ), MCRYPT_RAND ); mcrypt_generic_init( $td, $key, $iv ); $data = mcrypt_generic( $td, $text ); mcrypt_generic_deinit( $td ); mcrypt_module_close( $td ); return base64_encode( $data ); } ?>
相关文章推荐
- 自定义PHP错误报告处理方式
- Android中 MD5、RC4、DES、DESede (3DES)、RSA、AES、自定义填充方式的 AES加密/解密算法
- php自定义函数替换超长文本中的特殊字符
- php自定义session存储方式
- 自定义VFP主窗口背景图片填充方式
- 如何通过非数字与字符的方式实现PHP WebShell详解
- PHP 自定义DES算法(跟PHP内部函数DES加密好像不通,找时间研究一下)
- Java版适用于PHP版3DES加密解密(PHP语言开发的MCRYPT_3DES算法、MCRYPT_MODE_ECB模式、PKCS7填充方式)
- php实现Mongodb自定义方式生成自增ID的方法
- 自定义PHP的错误报告处理方式
- php 实现自定义session存储方式
- 自定义PHP的错误报告处理方式
- php基础系列之字符串——字符的四种方式表达
- PHP 自定义session储存 FILE 方式类 高洛峰 细说PHP
- php使用DES加密方式对图片内容进行加密处理
- 在PHP中自定义session的存储方式
- 通过非数字和字符的方式实现PHP WebShell
- PHP 自定义session储存 数据库 方式类 高洛峰 细说PHP
- PHP 自定义session储存 MEMCACHE 方式类 高洛峰 细说PHP
- php递归方式的对变量中的特殊字符进行转义