blob: f2555545741a62c8fe0ee50b2b18d9ca240b0590 [file] [log] [blame]
Georg Brandl8ec7f652007-08-15 14:28:01 +00001
2:mod:`hashlib` --- Secure hashes and message digests
3====================================================
4
5.. module:: hashlib
6 :synopsis: Secure hash and message digest algorithms.
7.. moduleauthor:: Gregory P. Smith <greg@users.sourceforge.net>
8.. sectionauthor:: Gregory P. Smith <greg@users.sourceforge.net>
9
10
11.. versionadded:: 2.5
12
13.. index::
14 single: message digest, MD5
15 single: secure hash algorithm, SHA1, SHA224, SHA256, SHA384, SHA512
16
17This module implements a common interface to many different secure hash and
18message digest algorithms. Included are the FIPS secure hash algorithms SHA1,
19SHA224, SHA256, SHA384, and SHA512 (defined in FIPS 180-2) as well as RSA's MD5
20algorithm (defined in Internet :rfc:`1321`). The terms secure hash and message
21digest are interchangeable. Older algorithms were called message digests. The
22modern term is secure hash.
23
24.. warning::
25
26 Some algorithms have known hash collision weaknesses, see the FAQ at the end.
27
28There is one constructor method named for each type of :dfn:`hash`. All return
29a hash object with the same simple interface. For example: use :func:`sha1` to
30create a SHA1 hash object. You can now feed this object with arbitrary strings
31using the :meth:`update` method. At any point you can ask it for the
32:dfn:`digest` of the concatenation of the strings fed to it so far using the
33:meth:`digest` or :meth:`hexdigest` methods.
34
35.. index:: single: OpenSSL
36
37Constructors for hash algorithms that are always present in this module are
38:func:`md5`, :func:`sha1`, :func:`sha224`, :func:`sha256`, :func:`sha384`, and
39:func:`sha512`. Additional algorithms may also be available depending upon the
40OpenSSL library that Python uses on your platform.
41
42For example, to obtain the digest of the string ``'Nobody inspects the spammish
43repetition'``::
44
45 >>> import hashlib
46 >>> m = hashlib.md5()
47 >>> m.update("Nobody inspects")
48 >>> m.update(" the spammish repetition")
49 >>> m.digest()
50 '\xbbd\x9c\x83\xdd\x1e\xa5\xc9\xd9\xde\xc9\xa1\x8d\xf0\xff\xe9'
51
52More condensed::
53
54 >>> hashlib.sha224("Nobody inspects the spammish repetition").hexdigest()
55 'a4337bc45a8fc544c03f52dc550cd6e1e87021bc896588bd79e901e2'
56
57A generic :func:`new` constructor that takes the string name of the desired
58algorithm as its first parameter also exists to allow access to the above listed
59hashes as well as any other algorithms that your OpenSSL library may offer. The
60named constructors are much faster than :func:`new` and should be preferred.
61
62Using :func:`new` with an algorithm provided by OpenSSL::
63
64 >>> h = hashlib.new('ripemd160')
65 >>> h.update("Nobody inspects the spammish repetition")
66 >>> h.hexdigest()
67 'cc4a5ce1b3df48aec5d22d1f16b894a0b894eccc'
68
69The following values are provided as constant attributes of the hash objects
70returned by the constructors:
71
72
73.. data:: digest_size
74
75 The size of the resulting digest in bytes.
76
77A hash object has the following methods:
78
79
80.. method:: hash.update(arg)
81
82 Update the hash object with the string *arg*. Repeated calls are equivalent to
83 a single call with the concatenation of all the arguments: ``m.update(a);
84 m.update(b)`` is equivalent to ``m.update(a+b)``.
85
86
87.. method:: hash.digest()
88
89 Return the digest of the strings passed to the :meth:`update` method so far.
90 This is a string of :attr:`digest_size` bytes which may contain non-ASCII
91 characters, including null bytes.
92
93
94.. method:: hash.hexdigest()
95
96 Like :meth:`digest` except the digest is returned as a string of double length,
97 containing only hexadecimal digits. This may be used to exchange the value
98 safely in email or other non-binary environments.
99
100
101.. method:: hash.copy()
102
103 Return a copy ("clone") of the hash object. This can be used to efficiently
104 compute the digests of strings that share a common initial substring.
105
106
107.. seealso::
108
109 Module :mod:`hmac`
110 A module to generate message authentication codes using hashes.
111
112 Module :mod:`base64`
113 Another way to encode binary hashes for non-binary environments.
114
115 http://csrc.nist.gov/publications/fips/fips180-2/fips180-2.pdf
116 The FIPS 180-2 publication on Secure Hash Algorithms.
117
118 http://www.cryptography.com/cnews/hash.html
119 Hash Collision FAQ with information on which algorithms have known issues and
120 what that means regarding their use.
121