Class PrfAesCmac

  • All Implemented Interfaces:
    Prf

    @Immutable
    public final class PrfAesCmac
    extends java.lang.Object
    implements Prf
    An implementation of CMAC following RFC 4493.
    • Method Detail

      • create

        public static Prf create​(AesCmacPrfKey key)
                          throws java.security.GeneralSecurityException
        Throws:
        java.security.GeneralSecurityException
      • compute

        public byte[] compute​(byte[] data,
                              int outputLength)
                       throws java.security.GeneralSecurityException
        Description copied from interface: Prf
        Computes the PRF selected by the underlying key on input and returns the first outputLength bytes.
        Specified by:
        compute in interface Prf
        Parameters:
        data - the input to compute the PRF on.
        outputLength - the desired length of the output in bytes. When choosing this parameter keep the birthday paradox in mind. If you have 2^n different inputs that your system has to handle set the output length to ceil(n/4 + 4) This corresponds to 2*n + 32 bits, meaning a collision will occur with a probability less than 1:2^32. When in doubt, request a security review.
        Throws:
        java.security.GeneralSecurityException - if the algorithm fails or if the output of algorithm is less than outputLength.