pkcs5填充

Posted 落叶成冰

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pkcs5填充相关的知识,希望对你有一定的参考价值。

<?php
/**
 * pkcs5 padding
 */
function pkcs5_pad($text, $blocksize = 8) 
	// $pad 既是要填充的值也是要填充的长度
	$pad = $blocksize - (strlen($text) % $blocksize);
	return $text . str_repeat(chr($pad), $pad);


/**
 * pkcs5 unpadding
 */
function pkcs5_unpad($text) 
	$byte_len = strlen($text);
	$pad = ord($text$byte_len-1);
	if($pad > $byte_len) 
		return false;
	
	// int strspn ( string $subject , string $mask [, int $start [, int $length ]] )
	// 计算字符串 $subject 中全部字符都存在于指定字符集合 $mask 中的第一段子串的长度
	if(strspn($text, chr($pad), $byte_len - $pad) != $pad) 
		return false;
	
	return substr($text, 0, -1 * $pad);


以上是关于pkcs5填充的主要内容,如果未能解决你的问题,请参考以下文章

PHP 3DES 加解密(CBC模式,pkcs5padding填充)

AES/CBC/PKCS5 填充 |替代 PHP OpenSSL 中的 mcrypt_get_block_size()

三种填充模式的区别(PKCS7Padding/PKCS5Padding/ZeroPadding)

PKCS5Padding 可以处于 AES/GCM 模式吗?

钛 AES/CBC/PKCS5Padding

Androidpkcs#5填充和pkcs#7填充比较