pkcs7padding.java

来自「《移动Agent技术》一书的所有章节源代码。」· Java 代码 · 共 72 行

JAVA
72
字号
package org.bouncycastle.crypto.paddings;import java.security.SecureRandom;import java.lang.IllegalStateException;import org.bouncycastle.crypto.CipherParameters;import org.bouncycastle.crypto.InvalidCipherTextException;/** * A padder that adds PKCS7/PKCS5 padding to a block. */public class PKCS7Padding    implements BlockCipherPadding{    /**     * Initialise the padder.     *     * @param random - a SecureRandom if available.     */    public void init(SecureRandom random)        throws IllegalArgumentException    {        // nothing to do.    }    /**     * Return the name of the algorithm the cipher implements.     *     * @return the name of the algorithm the cipher implements.     */    public String getPaddingName()    {        return "PKCS7";    }    /**     * add the pad bytes to the passed in block, returning the     * number of bytes added.     */    public int addPadding(        byte[]  in,        int     inOff)    {        byte code = (byte)(in.length - inOff);        while (inOff < in.length)        {            in[inOff] = code;            inOff++;        }        return code;    }    /**     * return the number of pad bytes present in the block.     */    public int padCount(byte[] in)        throws InvalidCipherTextException    {        int count = in[in.length - 1] & 0xff;        if (count > in.length)        {            throw new InvalidCipherTextException("pad block corrupted");        }        return count;    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?