All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.nimbusds.openid.connect.sdk.Nonce Maven / Gradle / Ivy

package com.nimbusds.openid.connect.sdk;


import net.jcip.annotations.Immutable;

import org.apache.commons.lang3.StringUtils;

import com.nimbusds.oauth2.sdk.id.Identifier;


/**
 * Nonce. This is a random, unique string value to associate a user-session 
 * with an ID Token and to mitigate replay attacks.
 *
 * 

Example generation of a nonce with eight random mixed-case alphanumeric * characters: * *

 * Nonce nonce = new Nonce(8);
 * 
* *

Related specifications: * *

    *
  • OpenID Connect Core 1.0, section 3.1.2.1. and 15.5.2. *
*/ @Immutable public final class Nonce extends Identifier { /** * Creates a new nonce with the specified value. * * @param value The nonce value. Must not be {@code null} or empty * string. */ public Nonce(final String value) { super(value); } /** * Creates a new nonce with a randomly generated value of the specified * byte length, Base64URL-encoded. * * @param byteLength The byte length of the value to generate. Must be * greater than one. */ public Nonce(final int byteLength) { super(byteLength); } /** * Creates a new nonce with a randomly generated 256-bit (32-byte) * value, Base64URL-encoded. */ public Nonce() { super(); } @Override public boolean equals(final Object object) { return object instanceof Nonce && this.toString().equals(object.toString()); } /** * Parses a nonce from the specified string. * * @param s The string to parse, {@code null} or empty if no nonce is * specified. * * @return The nonce, {@code null} if the parsed string was * {@code null} or empty. */ public static Nonce parse(final String s) { if (StringUtils.isBlank(s)) return null; return new Nonce(s); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy