java-otp is a Java library for generating HOTP (RFC 4226) or TOTP (RFC 6238) one-time passwords.
This project is a fork of https://github.com/jchambers/java-otp
The primary purpose of the fork is to compile and republish the binary using Java 8 SDK.
You can download java-otp as a jar file (it has no dependencies) from the GitHub releases page and add it to your project's classpath. If you're using Maven (or something that understands Maven dependencies) to build your project, you can add java-otp as a dependency:
<dependency>
<groupId>com.with98labs</groupId>
<artifactId>java-otp</artifactId>
<version>0.3.0</version>
</dependency>
java-otp works with Java 8 or newer. If you need support for versions of Java older than Java 8, you may try using java-otp v0.1 (although it is no longer supported).
The latest API docs are available at https://jchambers.github.io/java-otp/apidocs/latest/.
To demonstrate generating one-time passwords, we'll focus on the TOTP algorithm. To create a TOTP generator with a default password length (6 digits), time step (30 seconds), and HMAC algorithm (HMAC-SHA1):
final TimeBasedOneTimePasswordGenerator totp = new TimeBasedOneTimePasswordGenerator();
To actually generate time-based one-time passwords, you'll need a key and a timestamp. Secure key management is beyond the scope of this document; for the purposes of an example, though, we'll generate a random key:
final Key key;
{
final KeyGenerator keyGenerator = KeyGenerator.getInstance(totp.getAlgorithm());
// Key length should match the length of the HMAC output (160 bits for SHA-1, 256 bits
// for SHA-256, and 512 bits for SHA-512).
keyGenerator.init(160);
key = keyGenerator.generateKey();
}
Armed with a key, we can deterministically generate one-time passwords for any timestamp:
final Instant now = Instant.now();
final Instant later = now.plus(totp.getTimeStep());
System.out.println("Current password: " + totp.generateOneTimePasswordString(key, now));
System.out.println("Future password: " + totp.generateOneTimePasswordString(key, later));
…which produces (for one randomly-generated key):
Current password: 164092
Future password: 046148
java-otp is published under the MIT License.