Sample code for 30+ languages & platforms
PHP Extension

HOTP Algorithm: HMAC-Based One-Time Password Algorithm

See more Encryption Examples

Demonstrates how to generate an HMAC one-time password (HOTP) as specified in RFC 4226.

Note: This example requires Chilkat v9.5.0.77 or greater.

Chilkat PHP Extension Downloads

PHP Extension
<?php

include("chilkat.php");

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

$crypt = new CkCrypt2();

// Duplicate the following results from RFC 4226

// Appendix D - HOTP Algorithm: Test Values
// 
//   The following test data uses the ASCII string
//   "12345678901234567890" for the secret:
// 
//   Secret = 0x3132333435363738393031323334353637383930
// 
//                     Truncated
//   Count    Hexadecimal    Decimal        HOTP
//   0        4c93cf18       1284755224     755224
//   1        41397eea       1094287082     287082
//   2         82fef30        137359152     359152
//   3        66ef7655       1726969429     969429
//   4        61c5938a       1640338314     338314
//   5        33c083d4        868254676     254676
//   6        7256c032       1918287922     287922
//   7         4e5b397         82162583     162583
//   8        2823443f        673399871     399871
//   9        2679dc69        645520489     520489

$secret = '12345678901234567890';

for ($count = 0; $count <= 9; $count++) {
    $counterHex = $crypt->encodeInt($count,8,false,'hex');
    $hotp = $crypt->hotp($secret,'ascii',$counterHex,6,-1,'sha1');
    print $count . '  HOTP = ' . $hotp . "\n";
}

// Output is:
// 0  HOTP = 755224
// 1  HOTP = 287082
// 2  HOTP = 359152
// 3  HOTP = 969429
// 4  HOTP = 338314
// 5  HOTP = 254676
// 6  HOTP = 287922
// 7  HOTP = 162583
// 8  HOTP = 399871
// 9  HOTP = 520489

?>