You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

48 lines
1.9 KiB
C#

using System;
namespace Renci.SshNet.Security.Cryptography.Ciphers.Paddings
{
/// <summary>
/// Implements PKCS5 cipher padding
/// </summary>
public class PKCS5Padding : CipherPadding
{
/// <summary>
/// Pads the specified input to match the block size.
/// </summary>
/// <param name="blockSize">The size of the block.</param>
/// <param name="input">The input.</param>
/// <param name="offset">The zero-based offset in <paramref name="input"/> at which the data to pad starts.</param>
/// <param name="length">The number of bytes in <paramref name="input"/> to take into account.</param>
/// <returns>
/// The padded data array.
/// </returns>
public override byte[] Pad(int blockSize, byte[] input, int offset, int length)
{
var numOfPaddedBytes = blockSize - (length % blockSize);
return Pad(input, offset, length, numOfPaddedBytes);
}
/// <summary>
/// Pads the specified input with a given number of bytes.
/// </summary>
/// <param name="input">The input.</param>
/// <param name="offset">The zero-based offset in <paramref name="input"/> at which the data to pad starts.</param>
/// <param name="length">The number of bytes in <paramref name="input"/> to take into account.</param>
/// <param name="paddinglength">The number of bytes to pad the input with.</param>
/// <returns>
/// The padded data array.
/// </returns>
public override byte[] Pad(byte[] input, int offset, int length, int paddinglength)
{
var output = new byte[length + paddinglength];
Buffer.BlockCopy(input, offset, output, 0, length);
for (var i = 0; i < paddinglength; i++)
{
output[length + i] = (byte) paddinglength;
}
return output;
}
}
}