Sample code for 30+ languages & platforms
Tcl

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 Tcl Downloads

Tcl

load ./chilkat.dll

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

set 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

set secret "12345678901234567890"

for {set count 0} {$count <= 9} {incr count} {
    set counterHex [CkCrypt2_encodeInt $crypt $count 8 0 "hex"]
    set hotp [CkCrypt2_hotp $crypt $secret "ascii" $counterHex 6 -1 "sha1"]
    puts "$count  HOTP = $hotp"
}

# 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

delete_CkCrypt2 $crypt