Enum block_padding::Pkcs7 [−][src]
pub enum Pkcs7 {}
Expand description
Pad block with bytes with value equal to the number of bytes added.
PKCS#7 described in the RFC 5652.
use block_padding::{Pkcs7, Padding};
let msg = b"test";
let n = msg.len();
let mut buffer = [0xff; 8];
buffer[..n].copy_from_slice(msg);
let padded_msg = Pkcs7::pad(&mut buffer, n, 8).unwrap();
assert_eq!(padded_msg, b"test\x04\x04\x04\x04");
assert_eq!(Pkcs7::unpad(&padded_msg).unwrap(), msg);
let padded_msg = Pkcs7::pad(&mut buffer, n, 2).unwrap();
assert_eq!(padded_msg, b"test\x02\x02");
assert_eq!(Pkcs7::unpad(&padded_msg).unwrap(), msg);
let mut buffer = [0xff; 5];
assert!(Pkcs7::pad(&mut buffer, 4, 2).is_err());
assert!(Pkcs7::unpad(&buffer).is_err());
In addition to conditions stated in the Padding
trait documentation,
pad_block
will return PadError
if block.len() > 255
, and in case of
pad
if block_size > 255
.