mirror of
				https://github.com/openpgpjs/openpgpjs.git
				synced 2025-10-14 00:59:29 +00:00 
			
		
		
		
	 23295342fc
			
		
	
	
		23295342fc
		
	
	
	
	
		
			
			work correctly with utf8 strings. Fixeda visibility issue with the testing suite and added relevant unit tests.
		
			
				
	
	
		
			254 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			254 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html lang="en">
 | |
| <head>
 | |
|     <meta charset="utf-8">
 | |
|     <title>JSDoc: Source: ciphers/hash/md5.js</title>
 | |
|     
 | |
|     <script src="scripts/prettify/prettify.js"> </script>
 | |
|     <script src="scripts/prettify/lang-css.js"> </script>
 | |
|     <!--[if lt IE 9]>
 | |
|       <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
 | |
|     <![endif]-->
 | |
|     <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
 | |
|     <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
 | |
| </head>
 | |
| 
 | |
| <body>
 | |
| 
 | |
| <div id="main">
 | |
|     
 | |
|     <h1 class="page-title">Source: ciphers/hash/md5.js</h1>
 | |
|     
 | |
|     
 | |
| 
 | |
| 
 | |
|     
 | |
|     <section>
 | |
|         <article>
 | |
|             <pre class="prettyprint source"><code>/**
 | |
|  * A fast MD5 JavaScript implementation
 | |
|  * Copyright (c) 2012 Joseph Myers
 | |
|  * http://www.myersdaily.org/joseph/javascript/md5-text.html
 | |
|  *
 | |
|  * Permission to use, copy, modify, and distribute this software
 | |
|  * and its documentation for any purposes and without
 | |
|  * fee is hereby granted provided that this copyright notice
 | |
|  * appears in all copies.
 | |
|  *
 | |
|  * Of course, this soft is provided "as is" without express or implied
 | |
|  * warranty of any kind.
 | |
|  */
 | |
| 
 | |
| function MD5(entree) {
 | |
| 	var hex = md5(entree);
 | |
| 	var bin = util.hex2bin(hex);
 | |
| 	return bin;
 | |
| }
 | |
| 
 | |
| function md5cycle(x, k) {
 | |
| var a = x[0], b = x[1], c = x[2], d = x[3];
 | |
| 
 | |
| a = ff(a, b, c, d, k[0], 7, -680876936);
 | |
| d = ff(d, a, b, c, k[1], 12, -389564586);
 | |
| c = ff(c, d, a, b, k[2], 17,  606105819);
 | |
| b = ff(b, c, d, a, k[3], 22, -1044525330);
 | |
| a = ff(a, b, c, d, k[4], 7, -176418897);
 | |
| d = ff(d, a, b, c, k[5], 12,  1200080426);
 | |
| c = ff(c, d, a, b, k[6], 17, -1473231341);
 | |
| b = ff(b, c, d, a, k[7], 22, -45705983);
 | |
| a = ff(a, b, c, d, k[8], 7,  1770035416);
 | |
| d = ff(d, a, b, c, k[9], 12, -1958414417);
 | |
| c = ff(c, d, a, b, k[10], 17, -42063);
 | |
| b = ff(b, c, d, a, k[11], 22, -1990404162);
 | |
| a = ff(a, b, c, d, k[12], 7,  1804603682);
 | |
| d = ff(d, a, b, c, k[13], 12, -40341101);
 | |
| c = ff(c, d, a, b, k[14], 17, -1502002290);
 | |
| b = ff(b, c, d, a, k[15], 22,  1236535329);
 | |
| 
 | |
| a = gg(a, b, c, d, k[1], 5, -165796510);
 | |
| d = gg(d, a, b, c, k[6], 9, -1069501632);
 | |
| c = gg(c, d, a, b, k[11], 14,  643717713);
 | |
| b = gg(b, c, d, a, k[0], 20, -373897302);
 | |
| a = gg(a, b, c, d, k[5], 5, -701558691);
 | |
| d = gg(d, a, b, c, k[10], 9,  38016083);
 | |
| c = gg(c, d, a, b, k[15], 14, -660478335);
 | |
| b = gg(b, c, d, a, k[4], 20, -405537848);
 | |
| a = gg(a, b, c, d, k[9], 5,  568446438);
 | |
| d = gg(d, a, b, c, k[14], 9, -1019803690);
 | |
| c = gg(c, d, a, b, k[3], 14, -187363961);
 | |
| b = gg(b, c, d, a, k[8], 20,  1163531501);
 | |
| a = gg(a, b, c, d, k[13], 5, -1444681467);
 | |
| d = gg(d, a, b, c, k[2], 9, -51403784);
 | |
| c = gg(c, d, a, b, k[7], 14,  1735328473);
 | |
| b = gg(b, c, d, a, k[12], 20, -1926607734);
 | |
| 
 | |
| a = hh(a, b, c, d, k[5], 4, -378558);
 | |
| d = hh(d, a, b, c, k[8], 11, -2022574463);
 | |
| c = hh(c, d, a, b, k[11], 16,  1839030562);
 | |
| b = hh(b, c, d, a, k[14], 23, -35309556);
 | |
| a = hh(a, b, c, d, k[1], 4, -1530992060);
 | |
| d = hh(d, a, b, c, k[4], 11,  1272893353);
 | |
| c = hh(c, d, a, b, k[7], 16, -155497632);
 | |
| b = hh(b, c, d, a, k[10], 23, -1094730640);
 | |
| a = hh(a, b, c, d, k[13], 4,  681279174);
 | |
| d = hh(d, a, b, c, k[0], 11, -358537222);
 | |
| c = hh(c, d, a, b, k[3], 16, -722521979);
 | |
| b = hh(b, c, d, a, k[6], 23,  76029189);
 | |
| a = hh(a, b, c, d, k[9], 4, -640364487);
 | |
| d = hh(d, a, b, c, k[12], 11, -421815835);
 | |
| c = hh(c, d, a, b, k[15], 16,  530742520);
 | |
| b = hh(b, c, d, a, k[2], 23, -995338651);
 | |
| 
 | |
| a = ii(a, b, c, d, k[0], 6, -198630844);
 | |
| d = ii(d, a, b, c, k[7], 10,  1126891415);
 | |
| c = ii(c, d, a, b, k[14], 15, -1416354905);
 | |
| b = ii(b, c, d, a, k[5], 21, -57434055);
 | |
| a = ii(a, b, c, d, k[12], 6,  1700485571);
 | |
| d = ii(d, a, b, c, k[3], 10, -1894986606);
 | |
| c = ii(c, d, a, b, k[10], 15, -1051523);
 | |
| b = ii(b, c, d, a, k[1], 21, -2054922799);
 | |
| a = ii(a, b, c, d, k[8], 6,  1873313359);
 | |
| d = ii(d, a, b, c, k[15], 10, -30611744);
 | |
| c = ii(c, d, a, b, k[6], 15, -1560198380);
 | |
| b = ii(b, c, d, a, k[13], 21,  1309151649);
 | |
| a = ii(a, b, c, d, k[4], 6, -145523070);
 | |
| d = ii(d, a, b, c, k[11], 10, -1120210379);
 | |
| c = ii(c, d, a, b, k[2], 15,  718787259);
 | |
| b = ii(b, c, d, a, k[9], 21, -343485551);
 | |
| 
 | |
| x[0] = add32(a, x[0]);
 | |
| x[1] = add32(b, x[1]);
 | |
| x[2] = add32(c, x[2]);
 | |
| x[3] = add32(d, x[3]);
 | |
| 
 | |
| }
 | |
| 
 | |
| function cmn(q, a, b, x, s, t) {
 | |
| a = add32(add32(a, q), add32(x, t));
 | |
| return add32((a << s) | (a >>> (32 - s)), b);
 | |
| }
 | |
| 
 | |
| function ff(a, b, c, d, x, s, t) {
 | |
| return cmn((b & c) | ((~b) & d), a, b, x, s, t);
 | |
| }
 | |
| 
 | |
| function gg(a, b, c, d, x, s, t) {
 | |
| return cmn((b & d) | (c & (~d)), a, b, x, s, t);
 | |
| }
 | |
| 
 | |
| function hh(a, b, c, d, x, s, t) {
 | |
| return cmn(b ^ c ^ d, a, b, x, s, t);
 | |
| }
 | |
| 
 | |
| function ii(a, b, c, d, x, s, t) {
 | |
| return cmn(c ^ (b | (~d)), a, b, x, s, t);
 | |
| }
 | |
| 
 | |
| function md51(s) {
 | |
| txt = '';
 | |
| var n = s.length,
 | |
| state = [1732584193, -271733879, -1732584194, 271733878], i;
 | |
| for (i=64; i<=s.length; i+=64) {
 | |
| md5cycle(state, md5blk(s.substring(i-64, i)));
 | |
| }
 | |
| s = s.substring(i-64);
 | |
| var tail = [0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0];
 | |
| for (i=0; i<s.length; i++)
 | |
| tail[i>>2] |= s.charCodeAt(i) << ((i%4) << 3);
 | |
| tail[i>>2] |= 0x80 << ((i%4) << 3);
 | |
| if (i > 55) {
 | |
| md5cycle(state, tail);
 | |
| for (i=0; i<16; i++) tail[i] = 0;
 | |
| }
 | |
| tail[14] = n*8;
 | |
| md5cycle(state, tail);
 | |
| return state;
 | |
| }
 | |
| 
 | |
| /* there needs to be support for Unicode here,
 | |
|  * unless we pretend that we can redefine the MD-5
 | |
|  * algorithm for multi-byte characters (perhaps
 | |
|  * by adding every four 16-bit characters and
 | |
|  * shortening the sum to 32 bits). Otherwise
 | |
|  * I suggest performing MD-5 as if every character
 | |
|  * was two bytes--e.g., 0040 0025 = @%--but then
 | |
|  * how will an ordinary MD-5 sum be matched?
 | |
|  * There is no way to standardize text to something
 | |
|  * like UTF-8 before transformation; speed cost is
 | |
|  * utterly prohibitive. The JavaScript standard
 | |
|  * itself needs to look at this: it should start
 | |
|  * providing access to strings as preformed UTF-8
 | |
|  * 8-bit unsigned value arrays.
 | |
|  */
 | |
| function md5blk(s) { /* I figured global was faster.   */
 | |
| var md5blks = [], i; /* Andy King said do it this way. */
 | |
| for (i=0; i<64; i+=4) {
 | |
| md5blks[i>>2] = s.charCodeAt(i)
 | |
| + (s.charCodeAt(i+1) << 8)
 | |
| + (s.charCodeAt(i+2) << 16)
 | |
| + (s.charCodeAt(i+3) << 24);
 | |
| }
 | |
| return md5blks;
 | |
| }
 | |
| 
 | |
| var hex_chr = '0123456789abcdef'.split('');
 | |
| 
 | |
| function rhex(n)
 | |
| {
 | |
| var s='', j=0;
 | |
| for(; j<4; j++)
 | |
| s += hex_chr[(n >> (j * 8 + 4)) & 0x0F]
 | |
| + hex_chr[(n >> (j * 8)) & 0x0F];
 | |
| return s;
 | |
| }
 | |
| 
 | |
| function hex(x) {
 | |
| for (var i=0; i<x.length; i++)
 | |
| x[i] = rhex(x[i]);
 | |
| return x.join('');
 | |
| }
 | |
| 
 | |
| function md5(s) {
 | |
| return hex(md51(s));
 | |
| }
 | |
| 
 | |
| /* this function is much faster,
 | |
| so if possible we use it. Some IEs
 | |
| are the only ones I know of that
 | |
| need the idiotic second function,
 | |
| generated by an if clause.  */
 | |
| 
 | |
| function add32(a, b) {
 | |
| return (a + b) & 0xFFFFFFFF;
 | |
| }
 | |
| 
 | |
| if (md5('hello') != '5d41402abc4b2a76b9719d911017c592') {
 | |
| function add32(x, y) {
 | |
| var lsw = (x & 0xFFFF) + (y & 0xFFFF),
 | |
| msw = (x >> 16) + (y >> 16) + (lsw >> 16);
 | |
| return (msw << 16) | (lsw & 0xFFFF);
 | |
| }
 | |
| }
 | |
| </code></pre>
 | |
|         </article>
 | |
|     </section>
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| </div>
 | |
| 
 | |
| <nav>
 | |
|     <h2><a href="index.html">Index</a></h2><h3>Classes</h3><ul><li><a href="_openpgp_packet.html">_openpgp_packet</a></li><li><a href="JXG.Util.html">Util</a></li><li><a href="openpgp.html">openpgp</a></li><li><a href="openpgp_config.html">openpgp_config</a></li><li><a href="openpgp_keyring.html">openpgp_keyring</a></li><li><a href="openpgp_msg_message.html">openpgp_msg_message</a></li><li><a href="openpgp_msg_privatekey.html">openpgp_msg_privatekey</a></li><li><a href="openpgp_msg_publickey.html">openpgp_msg_publickey</a></li><li><a href="openpgp_packet_compressed.html">openpgp_packet_compressed</a></li><li><a href="openpgp_packet_encrypteddata.html">openpgp_packet_encrypteddata</a></li><li><a href="openpgp_packet_encryptedintegrityprotecteddata.html">openpgp_packet_encryptedintegrityprotecteddata</a></li><li><a href="openpgp_packet_encryptedsessionkey.html">openpgp_packet_encryptedsessionkey</a></li><li><a href="openpgp_packet_keymaterial.html">openpgp_packet_keymaterial</a></li><li><a href="openpgp_packet_literaldata.html">openpgp_packet_literaldata</a></li><li><a href="openpgp_packet_marker.html">openpgp_packet_marker</a></li><li><a href="openpgp_packet_modificationdetectioncode.html">openpgp_packet_modificationdetectioncode</a></li><li><a href="openpgp_packet_onepasssignature.html">openpgp_packet_onepasssignature</a></li><li><a href="openpgp_packet_signature.html">openpgp_packet_signature</a></li><li><a href="openpgp_packet_userattribute.html">openpgp_packet_userattribute</a></li><li><a href="openpgp_packet_userid.html">openpgp_packet_userid</a></li><li><a href="openpgp_type_keyid.html">openpgp_type_keyid</a></li><li><a href="openpgp_type_mpi.html">openpgp_type_mpi</a></li><li><a href="openpgp_type_s2k.html">openpgp_type_s2k</a></li></ul><h3>Global</h3><ul><li><a href="global.html#bin2str">bin2str</a></li><li><a href="global.html#calc_checksum">calc_checksum</a></li><li><a href="global.html#crc_table">crc_table</a></li><li><a href="global.html#decode_utf8">decode_utf8</a></li><li><a href="global.html#encode_utf8">encode_utf8</a></li><li><a href="global.html#get_hashAlgorithmString">get_hashAlgorithmString</a></li><li><a href="global.html#getCheckSum">getCheckSum</a></li><li><a href="global.html#getPGPMessageType">getPGPMessageType</a></li><li><a href="global.html#hash_headers">hash_headers</a></li><li><a href="global.html#hex2bin">hex2bin</a></li><li><a href="global.html#hexidump">hexidump</a></li><li><a href="global.html#hexstrdump">hexstrdump</a></li><li><a href="global.html#MD5">MD5</a></li><li><a href="global.html#openpgp_cfb_decrypt">openpgp_cfb_decrypt</a></li><li><a href="global.html#openpgp_cfb_encrypt">openpgp_cfb_encrypt</a></li><li><a href="global.html#openpgp_cfb_mdc">openpgp_cfb_mdc</a></li><li><a href="global.html#openpgp_crypto_asymetricDecrypt">openpgp_crypto_asymetricDecrypt</a></li><li><a href="global.html#openpgp_crypto_asymetricEncrypt">openpgp_crypto_asymetricEncrypt</a></li><li><a href="global.html#openpgp_crypto_generateKeyPair">openpgp_crypto_generateKeyPair</a></li><li><a href="global.html#openpgp_crypto_generateSessionKey">openpgp_crypto_generateSessionKey</a></li><li><a href="global.html#openpgp_crypto_getHashByteLength">openpgp_crypto_getHashByteLength</a></li><li><a href="global.html#openpgp_crypto_getPrefixRandom">openpgp_crypto_getPrefixRandom</a></li><li><a href="global.html#openpgp_crypto_getPseudoRandom">openpgp_crypto_getPseudoRandom</a></li><li><a href="global.html#openpgp_crypto_getRandomBigInteger">openpgp_crypto_getRandomBigInteger</a></li><li><a href="global.html#openpgp_crypto_getRandomBytes">openpgp_crypto_getRandomBytes</a></li><li><a href="global.html#openpgp_crypto_getSecureRandom">openpgp_crypto_getSecureRandom</a></li><li><a href="global.html#openpgp_crypto_hashData">openpgp_crypto_hashData</a></li><li><a href="global.html#openpgp_crypto_MDCSystemBytes">openpgp_crypto_MDCSystemBytes</a></li><li><a href="global.html#openpgp_crypto_signData">openpgp_crypto_signData</a></li><li><a href="global.html#openpgp_crypto_symmetricDecrypt">openpgp_crypto_symmetricDecrypt</a></li><li><a href="global.html#openpgp_crypto_symmetricEncrypt">openpgp_crypto_symmetricEncrypt</a></li><li><a href="global.html#openpgp_crypto_verifySignature">openpgp_crypto_verifySignature</a></li><li><a href="global.html#openpgp_encoding_armor">openpgp_encoding_armor</a></li><li><a href="global.html#openpgp_encoding_armor_addheader">openpgp_encoding_armor_addheader</a></li><li><a href="global.html#openpgp_encoding_base64_decode">openpgp_encoding_base64_decode</a></li><li><a href="global.html#openpgp_encoding_base64_encode">openpgp_encoding_base64_encode</a></li><li><a href="global.html#openpgp_encoding_deArmor">openpgp_encoding_deArmor</a></li><li><a href="global.html#openpgp_encoding_eme_pkcs1_decode">openpgp_encoding_eme_pkcs1_decode</a></li><li><a href="global.html#openpgp_encoding_eme_pkcs1_encode">openpgp_encoding_eme_pkcs1_encode</a></li><li><a href="global.html#openpgp_encoding_emsa_pkcs1_decode">openpgp_encoding_emsa_pkcs1_decode</a></li><li><a href="global.html#openpgp_encoding_emsa_pkcs1_encode">openpgp_encoding_emsa_pkcs1_encode</a></li><li><a href="global.html#openpgp_encoding_html_encode">openpgp_encoding_html_encode</a></li><li><a href="global.html#print_debug">print_debug</a></li><li><a href="global.html#print_debug_hexstr_dump">print_debug_hexstr_dump</a></li><li><a href="global.html#print_error">print_error</a></li><li><a href="global.html#print_info">print_info</a></li><li><a href="global.html#shiftRight">shiftRight</a></li><li><a href="global.html#str2bin">str2bin</a></li><li><a href="global.html#str2Uint8Array">str2Uint8Array</a></li><li><a href="global.html#Uint8Array2str">Uint8Array2str</a></li><li><a href="global.html#util">util</a></li><li><a href="global.html#verifyCheckSum">verifyCheckSum</a></li></ul>
 | |
| </nav>
 | |
| 
 | |
| <br clear="both">
 | |
| 
 | |
| <footer>
 | |
|     Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.2.0-dev</a> on Tue Apr 16 2013 10:42:39 GMT+0200 (CEST)
 | |
| </footer>
 | |
| 
 | |
| <script> prettyPrint(); </script>
 | |
| </body>
 | |
| </html>
 |