manpagez: man pages & more
man Crypt::Checksum::CRC32(3)
Home | html | info | man
Crypt::Checksum::CRC32(3)                  User Contributed Perl Documentation



NAME

       Crypt::Checksum::CRC32 - Compute CRC32 checksum


SYNOPSIS

          ### Functional interface:
          use Crypt::Checksum::CRC32 ':all';

          # calculate CRC32 checksum from string/buffer
          my $data = 'data string';
          my $checksum_raw  = crc32_data($data);
          my $checksum_hex  = crc32_data_hex($data);
          my $checksum_int  = crc32_data_int($data);
          # or from file
          my $checksum_file_raw  = crc32_file('filename.dat');
          my $checksum_file_hex  = crc32_file_hex('filename.dat');
          my $checksum_file_int  = crc32_file_int('filename.dat');
          # or from filehandle
          my $filehandle = ...; # existing binary-mode filehandle
          my $checksum_fh_raw  = crc32_file($filehandle);
          my $checksum_fh_hex  = crc32_file_hex($filehandle);
          my $checksum_fh_int  = crc32_file_int($filehandle);

          ### OO interface:
          use Crypt::Checksum::CRC32;

          my $d = Crypt::Checksum::CRC32->new;
          $d->add('any data');
          $d->add('another data');
          my $checksum_raw = $d->digest;     # raw 4 bytes
          my $checksum_hex = $d->hexdigest;  # hexadecimal form
          my $checksum_int = $d->intdigest;  # 32-bit unsigned integer

          # or checksum a file instead
          my $checksum_file_raw = Crypt::Checksum::CRC32->new->addfile('filename.dat')->digest;


DESCRIPTION

       Computes CRC-32 checksums using the ISO 3309 / ITU-T V.42 polynomial
       (0xEDB88320, also known as CRC-32/ISO-HDLC). This is the same variant
       used by Ethernet (IEEE 802.3), PKZIP, gzip, and PNG.

       Updated: v0.057


EXPORT

       Nothing is exported by default.

       You can export selected functions:

        use Crypt::Checksum::CRC32 qw(crc32_data crc32_data_hex crc32_data_int crc32_file crc32_file_hex crc32_file_int);

       Or all of them at once:

        use Crypt::Checksum::CRC32 ':all';


FUNCTIONS

   crc32_data
       Returns the checksum as raw octets.

        my $checksum_raw = crc32_data('data string');
        #or
        my $checksum_raw = crc32_data('any data', 'more data', 'even more data');

   crc32_data_hex
       Returns checksum as a hexadecimal string.

        my $checksum_hex = crc32_data_hex('data string');
        #or
        my $checksum_hex = crc32_data_hex('any data', 'more data', 'even more data');

   crc32_data_int
       Returns checksum as unsigned 32-bit integer.

        my $checksum_int = crc32_data_int('data string');
        #or
        my $checksum_int = crc32_data_int('any data', 'more data', 'even more data');

       Each "crc32_data*" function converts its data arguments to bytes using
       Perl's usual scalar stringification. Defined scalars, including numbers
       and string-overloaded objects, are accepted. "undef" is treated as an
       empty string and may emit Perl's usual "uninitialized value" warning.

   crc32_file
       Returns the checksum as raw octets.

        my $checksum_raw = crc32_file('filename.dat');
        #or
        my $filehandle = ...; # existing binary-mode filehandle
        my $checksum_raw = crc32_file($filehandle);

   crc32_file_hex
       Returns checksum as a hexadecimal string.

        my $checksum_hex = crc32_file_hex('filename.dat');
        #or
        my $filehandle = ...; # existing binary-mode filehandle
        my $checksum_hex = crc32_file_hex($filehandle);

   crc32_file_int
       Returns checksum as unsigned 32-bit integer.

        my $checksum_int = crc32_file_int('filename.dat');
        #or
        my $filehandle = ...; # existing binary-mode filehandle
        my $checksum_int = crc32_file_int($filehandle);


METHODS

       Unless noted otherwise, assume $d is an existing checksum object
       created via "new".

   new
       Constructor, returns a reference to the checksum object.

        my $d = Crypt::Checksum::CRC32->new;

   clone
       Creates a copy of the checksum object state and returns a reference to
       the copy.

        $d->clone();

   reset
       Reinitialize the checksum object state and returns a reference to the
       checksum object.

        $d->reset();

   add
       All arguments are appended to the message we calculate checksum for.
       The return value is the checksum object itself.

       Each argument is converted to bytes using Perl's usual scalar
       stringification.  Defined scalars, including numbers and
       string-overloaded objects, are accepted.  "undef" is treated as an
       empty string and may emit Perl's usual "uninitialized value" warning.

        $d->add('any data');
        #or
        $d->add('any data', 'more data', 'even more data');

   addfile
       The content of the file (or filehandle) is appended to the message we
       calculate checksum for.  The return value is the checksum object
       itself.

        $d->addfile('filename.dat');
        #or
        my $filehandle = ...; # existing binary-mode filehandle
        $d->addfile($filehandle);

       Note: The filehandle must be in binary mode before you pass it to
       addfile().

   digest
       Returns the binary checksum (raw bytes).  This method does not alter
       the object state, so you can call it repeatedly and continue with add()
       or addfile() afterwards.

        my $result_raw = $d->digest();

   hexdigest
       Returns the checksum encoded as a hexadecimal string.  Like digest(),
       this method does not alter the object state.

        my $result_hex = $d->hexdigest();

   intdigest
       Returns the checksum encoded as unsigned 32-bit integer.  Like
       digest(), this method does not alter the object state.

        my $result_int = $d->intdigest();


SEE ALSO

       o   CryptX(3)

       o   <https://en.wikipedia.org/wiki/Cyclic_redundancy_check>

perl v5.34.3                      2026-05-11         Crypt::Checksum::CRC32(3)

cryptx 0.89.0 - Generated Mon May 11 08:06:01 CDT 2026
© manpagez.com 2000-2026
Individual documents may contain additional copyright information.