Gisle Aas > Digest-HMAC-1.03 > Digest::HMAC

Download:
Digest-HMAC-1.03.tar.gz

Dependencies

Annotate this POD

Related Modules

Apache::Session
XML::Parser
Net::SNMP
Digest::SHA1
Crypt::CBC
Crypt::RandPasswd
Digest::EMAC
Crypt::DES
Net::SSLeay
Authen::SASL
more...
By perlmonks.org

CPAN RT

New  3
Open  1
View/Report Bugs
Module Version: 1.03   Source  

NAME ^

Digest::HMAC - Keyed-Hashing for Message Authentication

SYNOPSIS ^

 # Functional style
 use Digest::HMAC qw(hmac hmac_hex);
 $digest = hmac($data, $key, \&myhash);
 print hmac_hex($data, $key, \&myhash);

 # OO style
 use Digest::HMAC;
 $hmac = Digest::HMAC->new($key, "Digest::MyHash");

 $hmac->add($data);
 $hmac->addfile(*FILE);

 $digest = $hmac->digest;
 $digest = $hmac->hexdigest;
 $digest = $hmac->b64digest;

DESCRIPTION ^

HMAC is used for message integrity checks between two parties that share a secret key, and works in combination with some other Digest algorithm, usually MD5 or SHA-1. The HMAC mechanism is described in RFC 2104.

HMAC follow the common Digest:: interface, but the constructor takes the secret key and the name of some other simple Digest:: as argument.

The hmac() and hmac_hex() functions and the Digest::HMAC->new() constructor takes an optional $blocksize argument as well. The HMAC algorithm assumes the digester to hash by iterating a basic compression function on blocks of data and the $blocksize should match the byte-length of such blocks.

The default $blocksize is 64 which is suitable for the MD5 and SHA-1 digest functions. For stronger algorithms the blocksize probably needs to be increased.

SEE ALSO ^

Digest::HMAC_MD5, Digest::HMAC_SHA1

RFC 2104

AUTHORS ^

Graham Barr <gbarr@ti.com>, Gisle Aas <gisle@aas.no>

syntax highlighting: