1999-11-07 04:14:55 +00:00
|
|
|
.\" $FreeBSD$
|
2021-06-29 07:01:13 +00:00
|
|
|
.Dd June 29, 2021
|
1997-03-02 21:43:10 +00:00
|
|
|
.Dt MD5 1
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
2018-07-09 08:19:04 +00:00
|
|
|
.Nm md5 , sha1 , sha224 , sha256 , sha384 , sha512 , sha512t256 , rmd160 ,
|
2021-05-19 17:26:20 +00:00
|
|
|
.Nm skein256 , skein512 , skein1024 ,
|
|
|
|
.Nm md5sum , sha1sum , sha224sum , sha256sum , sha384sum , sha512sum ,
|
|
|
|
.Nm sha512t256sum , rmd160sum , skein256sum , skein512sum , skein1024sum
|
1997-03-02 21:43:10 +00:00
|
|
|
.Nd calculate a message-digest fingerprint (checksum) for a file
|
|
|
|
.Sh SYNOPSIS
|
2018-07-09 08:19:04 +00:00
|
|
|
.Nm
|
2017-01-07 19:43:40 +00:00
|
|
|
.Op Fl pqrtx
|
|
|
|
.Op Fl c Ar string
|
|
|
|
.Op Fl s Ar string
|
|
|
|
.Op Ar
|
2021-06-25 06:54:36 +00:00
|
|
|
.Pp
|
2021-06-19 11:27:16 +00:00
|
|
|
.Nm md5sum
|
|
|
|
.Op Fl pqrtx
|
|
|
|
.Op Fl c Ar file
|
|
|
|
.Op Fl s Ar string
|
|
|
|
.Op Ar
|
2018-07-09 08:19:04 +00:00
|
|
|
.Pp
|
|
|
|
(All other hashes have the same options and usage.)
|
1997-03-02 21:43:10 +00:00
|
|
|
.Sh DESCRIPTION
|
2004-07-07 19:57:16 +00:00
|
|
|
The
|
2020-06-15 10:08:02 +00:00
|
|
|
.Nm md5 , sha1 , sha224 , sha256 , sha384 , sha512 , sha512t256 , rmd160 ,
|
|
|
|
.Nm skein256 , skein512 ,
|
2004-06-11 16:07:02 +00:00
|
|
|
and
|
2017-01-07 19:43:40 +00:00
|
|
|
.Nm skein1024
|
2004-06-11 16:07:02 +00:00
|
|
|
utilities take as input a message of arbitrary length and produce as
|
|
|
|
output a
|
1997-03-02 21:43:10 +00:00
|
|
|
.Dq fingerprint
|
|
|
|
or
|
|
|
|
.Dq message digest
|
2001-09-04 09:28:48 +00:00
|
|
|
of the input.
|
2021-05-19 17:26:20 +00:00
|
|
|
The
|
|
|
|
.Nm md5sum , sha1sum , sha224sum , sha256sum , sha384sum , sha512sum ,
|
|
|
|
.Nm sha512t256sum , rmd160sum , skein256sum , skein512sum ,
|
|
|
|
and
|
|
|
|
.Nm skein1024sum
|
|
|
|
utilities do the same, but default to the reversed format of
|
|
|
|
the
|
|
|
|
.Fl r
|
|
|
|
flag.
|
2001-09-04 09:28:48 +00:00
|
|
|
It is conjectured that it is computationally infeasible to
|
1997-03-02 21:43:10 +00:00
|
|
|
produce two messages having the same message digest, or to produce any
|
1994-10-29 23:58:02 +00:00
|
|
|
message having a given prespecified target message digest.
|
2020-06-15 10:08:02 +00:00
|
|
|
The SHA-224 , SHA-256 , SHA-384 , SHA-512, RIPEMD-160,
|
|
|
|
and SKEIN
|
2004-06-11 16:07:02 +00:00
|
|
|
algorithms are intended for digital signature applications, where a
|
1997-03-02 21:43:10 +00:00
|
|
|
large file must be
|
|
|
|
.Dq compressed
|
|
|
|
in a secure manner before being encrypted with a private
|
2001-08-07 15:48:51 +00:00
|
|
|
(secret)
|
2020-06-15 10:08:02 +00:00
|
|
|
key under a public-key cryptosystem such as RSA.
|
1997-03-02 21:43:10 +00:00
|
|
|
.Pp
|
2020-06-15 10:08:02 +00:00
|
|
|
The MD5 and SHA-1 algorithms have been proven to be vulnerable to practical
|
|
|
|
collision attacks and should not be relied upon to produce unique outputs,
|
2018-07-09 08:19:04 +00:00
|
|
|
.Em nor should they be used as part of a cryptographic signature scheme.
|
2017-03-02 14:50:01 +00:00
|
|
|
As of 2017-03-02, there is no publicly known method to
|
2017-03-02 00:27:21 +00:00
|
|
|
.Em reverse
|
2020-06-15 10:08:02 +00:00
|
|
|
either algorithm, i.e., to find an input that produces a specific
|
2017-03-02 00:27:21 +00:00
|
|
|
output.
|
2009-01-06 19:25:24 +00:00
|
|
|
.Pp
|
2020-06-15 10:08:02 +00:00
|
|
|
SHA-512t256 is a version of SHA-512 truncated to only 256 bits.
|
|
|
|
On 64-bit hardware, this algorithm is approximately 50% faster than SHA-256 but
|
|
|
|
with the same level of security.
|
2016-05-28 16:06:07 +00:00
|
|
|
The hashes are not interchangeable.
|
|
|
|
.Pp
|
2020-06-15 10:08:02 +00:00
|
|
|
It is recommended that all new applications use SHA-512 or SKEIN-512
|
2009-01-06 19:25:24 +00:00
|
|
|
instead of one of the other hash functions.
|
2001-09-04 01:01:07 +00:00
|
|
|
.Pp
|
2001-06-19 03:34:03 +00:00
|
|
|
The following options may be used in any combination and must
|
2001-09-04 09:28:48 +00:00
|
|
|
precede any files named on the command line.
|
2004-06-11 16:07:02 +00:00
|
|
|
The hexadecimal checksum of each file listed on the command line is printed
|
|
|
|
after the options are processed.
|
1998-07-06 07:04:50 +00:00
|
|
|
.Bl -tag -width indent
|
2021-05-19 17:26:20 +00:00
|
|
|
.It Fl b
|
2021-06-29 07:01:13 +00:00
|
|
|
Make the
|
2021-05-19 17:26:20 +00:00
|
|
|
.Nm -sum
|
2021-06-29 07:01:13 +00:00
|
|
|
programs separate hash and digest with a blank followed by an asterisk instead
|
|
|
|
of by 2 blank characters for full compatibility with the output generated by the
|
|
|
|
coreutils versions of these programs.
|
2011-11-13 16:35:47 +00:00
|
|
|
.It Fl c Ar string
|
2021-06-25 06:54:36 +00:00
|
|
|
If the program was called with a name that does not end in
|
|
|
|
.Nm sum ,
|
|
|
|
compare the digest of the file against this string.
|
2014-05-18 21:16:59 +00:00
|
|
|
.Pq Note that this option is not yet useful if multiple files are specified.
|
2021-06-25 06:54:36 +00:00
|
|
|
.It Fl c Ar file
|
|
|
|
If the program was called with a name that does end in
|
|
|
|
.Nm sum ,
|
2021-06-29 07:01:13 +00:00
|
|
|
the file passed as argument must contain digest lines generated by the same
|
|
|
|
digest algorithm with or without the
|
2021-06-25 06:54:36 +00:00
|
|
|
.Fl r
|
|
|
|
option
|
|
|
|
.Pq i.e. in either classical BSD format or in GNU coreutils format .
|
2021-06-29 07:01:13 +00:00
|
|
|
A line with the file name followed by a colon
|
|
|
|
.Dq ":"
|
2021-06-25 06:54:36 +00:00
|
|
|
and either OK or FAILED is written for each well-formed line in the digest file.
|
|
|
|
If applicable, the number of failed comparisons and the number of lines that were
|
|
|
|
skipped since they were not well-formed are printed at the end.
|
|
|
|
The
|
|
|
|
.Fl q
|
|
|
|
option can be used to quiesce the output unless there are mismatched entries in
|
|
|
|
the digest.
|
|
|
|
.Pp
|
1997-12-29 03:40:37 +00:00
|
|
|
.It Fl s Ar string
|
1998-07-06 07:04:50 +00:00
|
|
|
Print a checksum of the given
|
1997-12-29 03:40:37 +00:00
|
|
|
.Ar string .
|
1997-03-02 21:43:10 +00:00
|
|
|
.It Fl p
|
2004-06-11 16:07:02 +00:00
|
|
|
Echo stdin to stdout and append the checksum to stdout.
|
1999-12-04 01:29:43 +00:00
|
|
|
.It Fl q
|
2014-05-18 21:16:59 +00:00
|
|
|
Quiet mode \(em only the checksum is printed out.
|
2001-09-04 09:28:48 +00:00
|
|
|
Overrides the
|
1999-12-04 01:29:43 +00:00
|
|
|
.Fl r
|
|
|
|
option.
|
1999-11-07 04:14:55 +00:00
|
|
|
.It Fl r
|
2001-09-04 09:28:48 +00:00
|
|
|
Reverses the format of the output.
|
|
|
|
This helps with visual diffs.
|
|
|
|
Does nothing
|
2001-07-15 07:53:42 +00:00
|
|
|
when combined with the
|
1999-11-11 11:59:03 +00:00
|
|
|
.Fl ptx
|
1999-11-07 04:14:55 +00:00
|
|
|
options.
|
1997-03-02 21:43:10 +00:00
|
|
|
.It Fl t
|
1998-07-06 07:04:50 +00:00
|
|
|
Run a built-in time trial.
|
2021-05-19 17:26:20 +00:00
|
|
|
For the
|
|
|
|
.Nm -sum
|
|
|
|
versions, this is a nop for compatibility with coreutils.
|
1997-03-02 21:43:10 +00:00
|
|
|
.It Fl x
|
1998-07-06 07:04:50 +00:00
|
|
|
Run a built-in test script.
|
1997-03-02 21:43:10 +00:00
|
|
|
.El
|
2005-01-17 07:44:44 +00:00
|
|
|
.Sh EXIT STATUS
|
2003-11-02 23:12:08 +00:00
|
|
|
The
|
2018-07-09 08:19:04 +00:00
|
|
|
.Nm md5 , sha1 , sha224 , sha256 , sha512 , sha512t256 , rmd160 ,
|
2020-06-15 10:08:02 +00:00
|
|
|
.Nm skein256 , skein512 ,
|
2004-06-11 16:07:02 +00:00
|
|
|
and
|
2017-01-07 19:43:40 +00:00
|
|
|
.Nm skein1024
|
2004-06-11 16:07:02 +00:00
|
|
|
utilities exit 0 on success,
|
2011-11-13 16:35:47 +00:00
|
|
|
1 if at least one of the input files could not be read,
|
2014-05-18 21:16:59 +00:00
|
|
|
and 2 if at least one file does not have the same hash as the
|
|
|
|
.Fl c
|
|
|
|
option.
|
2020-06-19 06:23:55 +00:00
|
|
|
.Sh EXAMPLES
|
|
|
|
Calculate the MD5 checksum of the string
|
|
|
|
.Dq Hello .
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
$ md5 -s Hello
|
|
|
|
MD5 ("Hello") = 8b1a9953c4611296a827abf8c47804d7
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Same as above, but note the absence of the newline character in the input
|
|
|
|
string:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
$ echo -n Hello | md5
|
|
|
|
8b1a9953c4611296a827abf8c47804d7
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Calculate the checksum of multiple files reversing the output:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
$ md5 -r /boot/loader.conf /etc/rc.conf
|
2021-06-29 07:01:13 +00:00
|
|
|
ada5f60f23af88ff95b8091d6d67bef6 /boot/loader.conf
|
|
|
|
d80bf36c332dc0fdc479366ec3fa44cd /etc/rc.conf
|
|
|
|
.Pd
|
|
|
|
The
|
|
|
|
.Nm -sum
|
|
|
|
variants put 2 blank characters between hash and file name for full compatibilty
|
|
|
|
with the coreutils versions of these commands.
|
2020-06-19 06:23:55 +00:00
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Write the digest for
|
|
|
|
.Pa /boot/loader.conf
|
|
|
|
in a file named
|
|
|
|
.Pa digest .
|
|
|
|
Then calculate the checksum again and validate it against the checksum string
|
|
|
|
extracted from the
|
|
|
|
.Pa digest
|
|
|
|
file:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
$ md5 /boot/loader.conf > digest && md5 -c $(cut -f2 -d= digest) /boot/loader.conf
|
|
|
|
MD5 (/boot/loader.conf) = ada5f60f23af88ff95b8091d6d67bef6
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Same as above but comparing the digest against an invalid string
|
|
|
|
.Pq Dq randomstring ,
|
|
|
|
which results in a failure.
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
$ md5 -c randomstring /boot/loader.conf
|
|
|
|
MD5 (/boot/loader.conf) = ada5f60f23af88ff95b8091d6d67bef6 [ Failed ]
|
|
|
|
.Ed
|
2021-06-25 06:54:36 +00:00
|
|
|
.Pp
|
|
|
|
If invoked with a name ending in
|
|
|
|
.Nm -sum
|
|
|
|
the
|
|
|
|
.Fl c
|
|
|
|
option does not compare against a hash string passed as parameter.
|
|
|
|
Instead, it expects a digest file, as created under the name
|
|
|
|
.Pa digest
|
|
|
|
for
|
|
|
|
.Pa /boot/loader.conf
|
|
|
|
in the example above.
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
$ md5 -c digest /boot/loader.conf
|
|
|
|
/boot/loader.conf: OK
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
The digest file may contain any number of lines in the format generated with or without the
|
|
|
|
.Fl r
|
|
|
|
option
|
|
|
|
.Pq i.e. in either classical BSD format or in GNU coreutils format .
|
|
|
|
If a hash value does not match the file, FAILED is printed instead of OK.
|
1997-03-02 21:43:10 +00:00
|
|
|
.Sh SEE ALSO
|
2004-06-11 16:07:02 +00:00
|
|
|
.Xr cksum 1 ,
|
|
|
|
.Xr md5 3 ,
|
|
|
|
.Xr ripemd 3 ,
|
2005-03-10 09:56:39 +00:00
|
|
|
.Xr sha 3 ,
|
2012-08-01 00:36:12 +00:00
|
|
|
.Xr sha256 3 ,
|
2015-12-27 17:33:59 +00:00
|
|
|
.Xr sha384 3 ,
|
2017-01-07 19:43:40 +00:00
|
|
|
.Xr sha512 3 ,
|
|
|
|
.Xr skein 3
|
1997-03-02 21:43:10 +00:00
|
|
|
.Rs
|
|
|
|
.%A R. Rivest
|
|
|
|
.%T The MD5 Message-Digest Algorithm
|
|
|
|
.%O RFC1321
|
|
|
|
.Re
|
2004-06-11 16:07:02 +00:00
|
|
|
.Rs
|
|
|
|
.%A J. Burrows
|
|
|
|
.%T The Secure Hash Standard
|
2005-03-10 09:56:39 +00:00
|
|
|
.%O FIPS PUB 180-2
|
2004-06-11 16:07:02 +00:00
|
|
|
.Re
|
|
|
|
.Rs
|
|
|
|
.%A D. Eastlake and P. Jones
|
|
|
|
.%T US Secure Hash Algorithm 1
|
|
|
|
.%O RFC 3174
|
|
|
|
.Re
|
|
|
|
.Pp
|
|
|
|
RIPEMD-160 is part of the ISO draft standard
|
|
|
|
.Qq ISO/IEC DIS 10118-3
|
|
|
|
on dedicated hash functions.
|
|
|
|
.Pp
|
|
|
|
Secure Hash Standard (SHS):
|
|
|
|
.Pa http://csrc.nist.gov/cryptval/shs.html .
|
|
|
|
.Pp
|
|
|
|
The RIPEMD-160 page:
|
|
|
|
.Pa http://www.esat.kuleuven.ac.be/~bosselae/ripemd160.html .
|
2021-05-19 17:26:20 +00:00
|
|
|
.Sh BUGS
|
|
|
|
All of the utilities that end in
|
|
|
|
.Sq sum
|
|
|
|
are intended to be compatible with the GNU coreutils programs.
|
2021-06-25 06:54:36 +00:00
|
|
|
However, the long option functionality is not provided.
|
1998-07-06 07:04:50 +00:00
|
|
|
.Sh ACKNOWLEDGMENTS
|
1994-10-29 23:58:02 +00:00
|
|
|
This program is placed in the public domain for free general use by
|
|
|
|
RSA Data Security.
|
2004-06-11 16:07:02 +00:00
|
|
|
.Pp
|
|
|
|
Support for SHA-1 and RIPEMD-160 has been added by
|
2014-06-20 09:40:43 +00:00
|
|
|
.An Oliver Eikemeier Aq Mt eik@FreeBSD.org .
|