# jsSHA
A JavaScript implementation of the complete Secure Hash Standard family
(SHA-1, SHA-224, SHA-256, SHA-384, and SHA-512) as well as HMAC by
Brian Turek
## About
jsSHA is a javaScript implementation of the complete Secure Hash Algorithm
family as defined by FIPS PUB 180-2
(http://csrc.nist.gov/publications/fips/fips180-2/fips180-2withchangenotice.pdf).
It also includes the HMAC algorithm with SHA support as defined by FIPS PUB 198-1
(http://csrc.nist.gov/publications/fips/fips198-1/FIPS-198-1_final.pdf)
With the slow phasing out of MD5 as the standard hash to use in web
applications, a client-side implementation of the complete Secure Hash Standard
family was needed. Due to SHA-384 and SHA-512's use of 64-bit values throughout
the algorithm, JavaScript can not easily natively support the calculation of
these hashes. As a result, a bit of hacking had to be done to make sure the
values behaved themselves. SHA-224 was added to the Secure Hash Standard family
on 25 February 2004 so it was also included in this package.
## Files
**src/sha_dev.js**
A commented implementation of the entire SHA family of hashes. Not to be used
in production.
**src/sha.js**
A Google Closure Compiler optimized version of the entire library
**src/sha1.js**
A Google Closure Compiler optimized version the library with non SHA-1
functionality removed
**src/sha256.js**
A Google Closure Compiler optimized version the library with non SHA-224/SHA-256
functionality removed
**src/sha512.js**
A Google Closure Compiler optimized version the library with non SHA-384/SHA-512
functionality removed
**test/test.html**
A test page that calculates various hashes and has their correct values
**test/genHashRounds.py**
A Python2 script that generates multi-round hash values
**build/make-release**
A Bash script that runs the various Google Closure Compiler commands to build
a release
**build/externs.js**
File needed solely to make the Google Closure Compilter work
## Usage
### Browser
Include the desired JavaScript file (sha.js, sha1.js, sha256.js, or sha512.js)
in your header (sha.js used below):
Instantiate a new jsSHA object with your string to be hashed and its format
(HEX or TEXT) as the parameters. Then, call getHash with the desired hash
variant (SHA-1, SHA-224, SHA-256, SHA-384, or SHA-512) and output type
(HEX or B64).
In the example below, "This is a Test" and "SHA-512" were used
as the string to be hashed and variant respectively. Also, the HMAC using TEXT
key "SecretKey" and hashing algorithm SHA-512 was calculated.
var shaObj = new jsSHA("This is a Test", "TEXT");
var hash = shaObj.getHash("SHA-512", "HEX");
var hmac = shaObj.getHMAC("SecretKey", "TEXT", "SHA-512", "HEX");
The constructor takes an optional parameter, encoding, that specifies the
encoding used to encode TEXT-type inputs. Valid options are "UTF8" and "UTF16"
and it defaults to "UTF8"
getHash takes two optional parameters, a numRounds integer and an outputFormatOpts
hashlist. numRounds controls the number of hashing iterations/rounds performed
and defaults to a value of "1" if not specified. outputFormatOpts dictates
some formatting options for the output. By default,
`outputFormatOpts = {"outputUpper" : false, "b64Pad" : "="}`. These
options are intelligently interpreted based upon the chosen output format.
getHMAC also takes an optional outputFormatOpts hashlist which operates the exact
same way as above.
### Node.js
jsSHA is available through NPM and be installed by simply doing
npm install jssha
To use the module, first require it using:
jsSHA = require("jssha");
The rest of the instructions are identical to the [Browser](#browser) section above.
## Compiling
This library makes use of the Google Closure Compiler
(https://developers.google.com/closure/compiler) to both boost performance
and reduce filesizes. To compile sha_dev.js into a customized output file, use
a command like the following:
java -jar compiler.jar --define="SUPPORTED_ALGS=" \
--externs /path/to/build/externs.js --warning_level VERBOSE \
--compilation_level ADVANCED_OPTIMIZATIONS \
--js /path/to/sha_dev.js --js_output_file /path/to/sha.js
where is a bitwise OR of the following values:
* 4 for SHA-384/SHA-512
* 2 for SHA-224/256
* 1 for SHA-1
##Contact Info
The project's website is located at [http://caligatio.github.com/jsSHA/](http://caligatio.github.com/jsSHA/)