 
- Cryptography - Home
- Cryptography - Origin
- Cryptography - History
- Cryptography - Principles
- Cryptography - Applications
- Cryptography - Benefits & Drawbacks
- Cryptography - Modern Age
- Cryptography - Traditional Ciphers
- Cryptography - Need for Encryption
- Cryptography - Double Strength Encryption
- Cryptosystems
- Cryptosystems
- Cryptosystems - Components
- Attacks On Cryptosystem
- Cryptosystems - Rainbow table attack
- Cryptosystems - Dictionary attack
- Cryptosystems - Brute force attack
- Cryptosystems - Cryptanalysis Techniques
- Types of Cryptography
- Cryptosystems - Types
- Public Key Encryption
- Modern Symmetric Key Encryption
- Cryptography Hash functions
- Key Management
- Cryptosystems - Key Generation
- Cryptosystems - Key Storage
- Cryptosystems - Key Distribution
- Cryptosystems - Key Revocation
- Block Ciphers
- Cryptosystems - Stream Cipher
- Cryptography - Block Cipher
- Cryptography - Feistel Block Cipher
- Block Cipher Modes of Operation
- Block Cipher Modes of Operation
- Electronic Code Book (ECB) Mode
- Cipher Block Chaining (CBC) Mode
- Cipher Feedback (CFB) Mode
- Output Feedback (OFB) Mode
- Counter (CTR) Mode
- Classic Ciphers
- Cryptography - Reverse Cipher
- Cryptography - Caesar Cipher
- Cryptography - ROT13 Algorithm
- Cryptography - Transposition Cipher
- Cryptography - Encryption Transposition Cipher
- Cryptography - Decryption Transposition Cipher
- Cryptography - Multiplicative Cipher
- Cryptography - Affine Ciphers
- Cryptography - Simple Substitution Cipher
- Cryptography - Encryption of Simple Substitution Cipher
- Cryptography - Decryption of Simple Substitution Cipher
- Cryptography - Vigenere Cipher
- Cryptography - Implementing Vigenere Cipher
- Modern Ciphers
- Base64 Encoding & Decoding
- Cryptography - XOR Encryption
- Substitution techniques
- Cryptography - MonoAlphabetic Cipher
- Cryptography - Hacking Monoalphabetic Cipher
- Cryptography - Polyalphabetic Cipher
- Cryptography - Playfair Cipher
- Cryptography - Hill Cipher
- Polyalphabetic Ciphers
- Cryptography - One-Time Pad Cipher
- Implementation of One Time Pad Cipher
- Cryptography - Transposition Techniques
- Cryptography - Rail Fence Cipher
- Cryptography - Columnar Transposition
- Cryptography - Steganography
- Symmetric Algorithms
- Cryptography - Data Encryption
- Cryptography - Encryption Algorithms
- Cryptography - Data Encryption Standard
- Cryptography - Triple DES
- Cryptography - Double DES
- Advanced Encryption Standard
- Cryptography - AES Structure
- Cryptography - AES Transformation Function
- Cryptography - Substitute Bytes Transformation
- Cryptography - ShiftRows Transformation
- Cryptography - MixColumns Transformation
- Cryptography - AddRoundKey Transformation
- Cryptography - AES Key Expansion Algorithm
- Cryptography - Blowfish Algorithm
- Cryptography - SHA Algorithm
- Cryptography - RC4 Algorithm
- Cryptography - Camellia Encryption Algorithm
- Cryptography - ChaCha20 Encryption Algorithm
- Cryptography - CAST5 Encryption Algorithm
- Cryptography - SEED Encryption Algorithm
- Cryptography - SM4 Encryption Algorithm
- IDEA - International Data Encryption Algorithm
- Public Key (Asymmetric) Cryptography Algorithms
- Cryptography - RSA Algorithm
- Cryptography - RSA Encryption
- Cryptography - RSA Decryption
- Cryptography - Creating RSA Keys
- Cryptography - Hacking RSA Cipher
- Cryptography - ECDSA Algorithm
- Cryptography - DSA Algorithm
- Cryptography - Diffie-Hellman Algorithm
- Data Integrity in Cryptography
- Data Integrity in Cryptography
- Message Authentication
- Cryptography Digital signatures
- Public Key Infrastructure
- Hashing
- MD5 (Message Digest Algorithm 5)
- SHA-1 (Secure Hash Algorithm 1)
- SHA-256 (Secure Hash Algorithm 256-bit)
- SHA-512 (Secure Hash Algorithm 512-bit)
- SHA-3 (Secure Hash Algorithm 3)
- Hashing Passwords
- Bcrypt Hashing Module
- Modern Cryptography
- Quantum Cryptography
- Post-Quantum Cryptography
- Cryptographic Protocols
- Cryptography - SSL/TLS Protocol
- Cryptography - SSH Protocol
- Cryptography - IPsec Protocol
- Cryptography - PGP Protocol
- Image & File Cryptography
- Cryptography - Image
- Cryptography - File
- Steganography - Image
- File Encryption and Decryption
- Cryptography - Encryption of files
- Cryptography - Decryption of files
- Cryptography in IoT
- IoT security challenges, Threats and Attacks
- Cryptographic Techniques for IoT Security
- Communication Protocols for IoT Devices
- Commonly Used Cryptography Techniques
- Custom Building Cryptography Algorithms (Hybrid Cryptography)
- Cloud Cryptography
- Quantum Cryptography
- DNA Cryptography
- One Time Password (OTP) algorithm in Cryptography
- Difference Between
- Cryptography - MD5 vs SHA1
- Cryptography - RSA vs DSA
- Cryptography - RSA vs Diffie-Hellman
- Cryptography vs Cryptology
- Cryptography - Cryptology vs Cryptanalysis
- Cryptography - Classical vs Quantum
- Cryptography vs Steganography
- Cryptography vs Encryption
- Cryptography vs Cyber Security
- Cryptography - Stream Cipher vs Block Cipher
- Cryptography - AES vs DES ciphers
- Cryptography - Symmetric vs Asymmetric
One Time Password (OTP) Algorithm in Cryptography
Enhancing the security of your online apps has become important due to the rising number of cyber security threats. You have to make sure that the accounts of your users are safe.
Nowadays, many online web applications need users to add an additional layer of security to their accounts. They meet this by enabling two-factor authentication. There are multiple options for implementing 2-factor authentication, one of them is TOTP (Time-based One-Time Password).
In this chapter we will learn what it is and how and why you should use it. But first, let us define two-factor authentication.
Two Factor Authentication
So we can say two-factor authentication, often known as multi-factor authentication, gives a user's account an additional layer of security. This means that after turning on two factor authentication, the user still needs to finish one more step in order to log in successfully. For example, below are the standard procedures for accessing an account without one time password and witth one time password −
 
So the login process needs an additional step. Because a hacker cannot get to the user's account without knowing both the regular password and the one-time password so we can say this technique is more secure.
There are now two popular methos for getting the one-time password −
- SMS-based − With this method, a text message with a One Time Password is sent to the registered phone number of the user each time they log in.
- TOTP-based − This method needs the user to use a specific smartphone application to scan a QR image in order to turn on 2-factor authentication. The One Time Password of user is then continuously generated by that program.
There's no explanation needed for the SMS-based method. While it is simple, there are some disadvantages, like having to wait for an SMS each time you want to log in and security concerns. The advantages of the TOTP-based approach over the SMS-based approach are making it more and more popular. Now we will analyse the operation of the TOTP-based method.
How TOTP(Time-Based One-Time Password) Works?
The Time-Based One-Time Password (TOTP) method works by generating temporary passwords that expire in an interval of seconds, usually thirty or fewer. It improves authentication security by allowing users to input both a static password (something they know) and a temporary password generated by a device. Basically, the TOTP-based method works is as follows −
- Initialization: − The user and the service provider (website or application) choose a shared secret key at the initial step. Both the server and the user's device maintain the security of this key.
- 
Time-Based Generation
- To create a TOTP, the current time is used as a source of uniqueness.
- Using the shared secret key and the current time, the TOTP technique creates a one-time password.
- In order to ensure synchronisation between the user's device and the server, time is typically divided into predefined intervals, like increments of 30 seconds or one minute.
 
- 
Password Presentation
- The produced TOTP is sent to the user using a trustworthy device-a smartphone app or hardware token.
- The user enters the TOTP and their static password during the authentication process.
 
- 
Validation
- The service provider independently generates a TOTP and verifies it with the one provided by the user using the shared secret key that has been stored.
- If both the static password and the two TOTP values match, the user gets access.
- The TOTP has a 30-second maximum validity period before it expires and needs to be refreshed.
 
- 
Continuous Authentication
- Each time an attempt to log in is made, a new TOTP is given for each authentication session.
- As the TOTP is time-based and changes frequently even if an attacker were to intercept a previous attempt at authentication, it would have no effect on future attempts.
 
- 
Security Measures
- By adding a second factor-something the user owns-to the authentication process, TOTP improves security by making it less vulnerable to various threats, like replay attacks and phishing attempts.
- As TOTPs are short-lived, attackers have a smaller window of opportunity to intercept and manipulate them.
- The shared secret key allows users to generate valid TOTPs, but only if they own the relevant device and know the static password.
 
Security of TOTP
Unlike passwords, compromised credentials have a limited lifespan because TOTP codes are one-time only. Phishing attempts are more likely when users are required to input their TOTP codes into an authentication page. Since TOTP codes have a limited validity time, attackers have to quickly proxy the credentials.
The TOTP credentials are based on the shared secret that both the client and the server know, which offers more locations from which a secret can be retrieved. If an attacker knew this shared secret, they are able to generate new, valid TOTP codes. This becomes particularly dangerous if an attacker is able to gain access to a large authentication database.
Implementation of OTP Algorithm
Now we are going to implement the One time Password algorithm with the help of different programming languages like python, Java. So let us see the below programs for better understanding of this algorithm.
OTP Using Python
Here we will implement OTP using Python's secrets module which provides functions for creating cryptographically strong random numbers suitable for managing data like passwords, account authentication, and secure tokens. It is also a part of the Python Standard Library which was introduced in Python 3.6.
This code shows a basic OTP authentication process and show both OTP generation and verification. By using Python's secrets module, we will make sure the creation of secure and unpredictable OTPs to enhance the security of our authentication system.
So the Python code using secret module to implement OTP is as follow −
import secrets
# Function to generate a random secret key
def generate_random_key():
   return secrets.token_hex(16)  # 16 bytes (32 hex characters)
# Function to generate a One Time Password (OTP) using the secret key
def generate_otp(secret_key, length=6):
   # Define the characters allowed in the OTP
   allowed_characters = "0123456789"
   # Generate a random OTP using the secret key and allowed characters
   otp = ''.join(secrets.choice(allowed_characters) for _ in range(length))
   return otp
# Generate a random secret key (this should be kept secure)
secret_key = generate_random_key()
# Simulate sending the OTP to the user
otp = generate_otp(secret_key)
print("Generated OTP:", otp)
# Simulate user input for OTP verification
user_input = input("Please enter the received OTP: ")
# Verify the OTP entered by the user
if user_input == otp:
   print("OTP verification successful. Access granted!")
else:
   print("OTP verification failed. Access denied!")
Output
After running the above program we will get the below output. So by entering the correct otp code will show the message as access granted! and if the otp is wrong then it will show as access denied.
 
OTP Using Java
In this Java code we will use the java.security.SecureRandom class which is part of the Java Standard Library and provides a cryptographically strong random number generator (RNG). The SecureRandom class is used to generat cryptographically secure random numbers. The OTP is created by randomly selecting characters from the allowed set (0 to 9) using SecureRandom. The generated OTP is displayed to the user. The user is prompted to enter the received OTP. The entered OTP is compared with the generated OTP to verify its correctness. If the entered OTP is matched the generated OTP, access is granted; otherwise, access is denied.
So the implementation using Java is as follows −
import java.security.SecureRandom;
// Driver Class
public class OTPGenerator {
   // Function to generate a random secret key
   public static String generateSecretKey() {
      SecureRandom secureRandom = new SecureRandom();
      byte[] bytes = new byte[16];
      secureRandom.nextBytes(bytes);
      StringBuilder secretKey = new StringBuilder();
      for (byte b : bytes) {
         secretKey.append(String.format("%02x", b));
      }
      return secretKey.toString();
   }
   // Function to generate a One Time Password (OTP) using
   // the secret key
   public static String generateOTP(String secretKey, int length) {
      String allowedCharacters = "0123456789";
      StringBuilder otp = new StringBuilder();
      SecureRandom secureRandom = new SecureRandom();
      for (int i = 0; i < length; i++) {
         int randomIndex = secureRandom.nextInt(allowedCharacters.length());
         otp.append(allowedCharacters.charAt(randomIndex));
      }
      return otp.toString();
   }
   public static void main(String[] args) {
      // Generate a random secret key 
      // (this should be kept secure)
      String secretKey = generateSecretKey();
      // Generate the OTP
      int otpLength = 6;
      String otp = generateOTP(secretKey, otpLength);
      System.out.println("Generated OTP: " + otp);
      // Simulating user input for OTP verification
      java.util.Scanner scanner = new java.util.Scanner(System.in);
      System.out.print("Please enter the received OTP: ");
      String userInput = scanner.next();
      // Verify the OTP entered by the user
      if (userInput.equals(otp)) {
         System.out.println("OTP verification successful. Access granted!");
      } else {
         System.out.println("OTP verification failed. Access denied!");
      }
   }
}
Output
