This module implements the interface to NIST'ssecure hash
algorithm,known as SHA. It is used in
the same way as the md5 module: use new()
to create an sha object, then feed this object with arbitrary strings
using the update() method, and at any point you can ask it
for the digest of the concatenation of the strings fed to it
so far. SHA digests are 160 bits instead of
MD5's 128 bits.
Update the sha object with the string arg. Repeated calls are
equivalent to a single call with the concatenation of all the
arguments: m.update(a); m.update(b) is equivalent to
m.update(a+b).
Return the digest of the strings passed to the update()
method so far. This is a 20-byte string which may contain
non-ASCII characters, including null bytes.
Like digest() except the digest is returned as a string of
length 40, containing only hexadecimal digits. This may
be used to exchange the value safely in email or other non-binary
environments.