implementazione MD5 più veloce in JavaScript


236

Ci sono molte implementazioni JavaScript MD5 là fuori. Qualcuno sa quale è il più avanzato, il più corretto e il più veloce?

Ne ho bisogno per questo strumento.


2
Perché hai bisogno di un'implementazione MD5 "veloce"?
AnthonyWJones,

3
@AnthonyWJones è necessario qualche altro tipo di funzione md5? Non è come se una funzione md5 "lenta" avesse davvero qualche scopo ... vero?
Lee Olayvar

5
@LeeOlayvar Più lenta è una funzione di crittografia, più tempo ci vorrebbe per rinforzare un determinato hash usando quella funzione.
Mathias Bynens,

45
@MathiasBynens Sì, ma in base alla progettazione, md5 è un hash veloce. Vale a dire, è progettato per consumare grandi quantità di dati e generare un hash molto, molto velocemente. Questa è essenzialmente l'ultima cosa che vuoi per archiviare dati sicuri come password / etc, ed è più adatta / progettata per identificare i dati. Gli hash lenti invece sono progettati per essere lenti da zero. Forzare brutalmente un hash lento, con un grande valore di lavoro, non è un compito facile. Pertanto, gli hash lenti sono ideali per le password. MD5 è dannoso per le password in molti (la maggior parte?) Casi. Non sono un esperto in questo campo, quindi prendilo con il sale. :)
Lee Olayvar

16
Sì, ma poiché esiste una specifica che impone l'aspetto di un hash MD5, non importa se lo si calcola rapidamente o lentamente. Il risultato finale è lo stesso e sarà altrettanto difficile / facile da potenziare. Quindi fa ha senso utilizzare l'implementazione più veloce.
Stijn de Witt,

Risposte:


168

Ho sentito che l'implementazione di Joseph Myers è piuttosto veloce. Inoltre, ha un lungo articolo sull'ottimizzazione di Javascript che descrive ciò che ha imparato mentre scriveva la sua implementazione. È una buona lettura per chiunque sia interessato a javascript performante.

http://www.webreference.com/programming/javascript/jkm3/

La sua implementazione MD5 può essere trovata qui


123
"Per rendere il mio codice JavaScript MD5 più veloce di tutti gli altri, ho dovuto sfruttare le variabili di funzione locali." Che svolta!
Glenn Maynard,

11
Una dimostrazione di questa libreria md5 può essere trovata qui: jsfiddle.net/v28gq
Anderson Green

15
Qual è la licenza per il codice Myers? Non indica che sia autorizzato (o meno) sul suo sito Web, per quanto ne so.
JeroenHoek, l'

25
Mi dà fastidio che questa implementazione crei un mucchio di funzioni globali, quindi ho racchiuso il tutto in una chiusura, reso ogni funzione una variabile e assegnato la funzione md5 all'oggetto window. Ciò ovviamente presuppone che esista un oggetto window, ma manterrà private tutte le funzioni di supporto. Non sono sicuro di come (se non del tutto) influirà sulle prestazioni, ma dovrebbe essere molto più sicuro per l'uso in applicazioni di grandi dimensioni. gist.github.com/jhoff/7680711
jhoff,

6
@jhoff Your Gist è stato modificato e migliorato un paio di volte, penso anche che il var add32185 on line dovrebbe essere proprio add32così ho trovato il fork migliore che potevo e l'ho aggiornato a questa nuova versione: gist.github.com/MichaelPote/3f0cefaaa9578d7e30be
Mikepote,

73

Suggerirei di usare CryptoJS in questo caso.

Fondamentalmente CryptoJS è una raccolta crescente di algoritmi crittografici standard e sicuri implementati in JavaScript usando le migliori pratiche e modelli. Sono veloci e hanno un'interfaccia coerente e semplice.

Quindi, se vuoi calcolare l'hash MD5 della tua stringa di password, fai come segue:

<script src="https://cdnjs.cloudflare.com/ajax/libs/crypto-js/3.1.9-1/core.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/crypto-js/3.1.9-1/md5.js"></script>
<script>
    var passhash = CryptoJS.MD5(password).toString();

    $.post(
      'includes/login.php', 
      { user: username, pass: passhash },
      onLogin, 
      'json' );
</script>

Quindi questo script pubblicherà l'hash della stringa della password sul server.

Per ulteriori informazioni e supporto su altri algoritmi di calcolo dell'hash è possibile visitare:

http://code.google.com/p/crypto-js/


59
Non dovresti usare md5 per le password.
Lukas Liesis,

3
Sembra che questo rimarrà presto orfano, ancora su "codice google". Nessuno mantiene?
MrYellow,

2
md5 è veloce e se qualcuno rompe il tuo sito e il tuo db & code è trapelato puoi sempre generare db con hash e decodificare le password. Dammi il tuo database live con 10 milioni di utenti e codice. Mi divertirò e pubblicherò su Internet i miei risultati decodificati. Saluti.
Lukas Liesis,

2
Il collegamento porta ora a una Pagina 404
Adam F,


29

Durante la selezione della libreria è anche importante vedere se supporta framework moderni come Bower, passa jslint, supporta il modello di plug-in per JQuery o sistemi di moduli come AMD / RequireJS oltre a essere in sviluppo attivo e avere più di 1 collaboratori. Esistono un paio di opzioni che soddisfano alcuni o tutti questi criteri aggiuntivi:

  • CryptoJS : questa è forse la libreria più estesa in cui ogni algoritmo può essere usato separatamente senza aggiungere grasso al tuo codice JS. Inoltre, come codificatore / decodificatore per UTF8, UTF16 e Base64. Io sostengo repository github registrato come pacchetto Bower, più le istruzioni su come usarlo con RequireJS.
  • Spark MD5 : si basa sul codice JKM a cui altre risposte menzionano che è anche l'implementazione più rapida. Tuttavia, l'implementazione Spark aggiunge il supporto AMD, passa jslint plus ha modalità incrementale. Non ha base64 o / p ma ha raw o / p (cioè array di int a 32 bit anziché stringa).
  • Plugin JQuery MD5 : molto semplice verso terra ma non sembra avere la modalità raw.
  • JavaScript-MD5 : non elegante o veloce come Spark ma più semplice.

Esempio da CryptoJS:

//just include md5.js from the CryptoJS rollups folder
var hash = CryptoJS.MD5("Message");
console.log(hash.toString()); 

Esiste un confronto delle prestazioni tra le librerie sopra riportate su http://jsperf.com/md5-shootout/7 . Sulla mia macchina i test attuali (che sono certamente vecchi) mostrano che se stai cercando la velocità, Spark MD5 è la soluzione migliore (e quindi anche il semplice codice JKM). Tuttavia, se stai cercando una libreria più completa, CryptoJS è la soluzione migliore anche se è più lenta del 79% rispetto a Spark MD5. Tuttavia, immagino che CryptoJS alla fine raggiungerà la stessa velocità in quanto è un progetto un po 'più attivo.


Il link al "plugin jQuery MD5" mi porta a un sito di malware. EEP!
Raffi,

1
Sembra che il sito Web originale del plug-in jQuery MD5 sia stato chiuso e ora reindirizza al venditore di domini generico. Ho aggiornato al plug-in ospitato su GitHub ora.
Shital Shah,

14

MD5 = function(e) {
    function h(a, b) {
        var c, d, e, f, g;
        e = a & 2147483648;
        f = b & 2147483648;
        c = a & 1073741824;
        d = b & 1073741824;
        g = (a & 1073741823) + (b & 1073741823);
        return c & d ? g ^ 2147483648 ^ e ^ f : c | d ? g & 1073741824 ? g ^ 3221225472 ^ e ^ f : g ^ 1073741824 ^ e ^ f : g ^ e ^ f
    }

    function k(a, b, c, d, e, f, g) {
        a = h(a, h(h(b & c | ~b & d, e), g));
        return h(a << f | a >>> 32 - f, b)
    }

    function l(a, b, c, d, e, f, g) {
        a = h(a, h(h(b & d | c & ~d, e), g));
        return h(a << f | a >>> 32 - f, b)
    }

    function m(a, b, d, c, e, f, g) {
        a = h(a, h(h(b ^ d ^ c, e), g));
        return h(a << f | a >>> 32 - f, b)
    }

    function n(a, b, d, c, e, f, g) {
        a = h(a, h(h(d ^ (b | ~c), e), g));
        return h(a << f | a >>> 32 - f, b)
    }

    function p(a) {
        var b = "",
            d = "",
            c;
        for (c = 0; 3 >= c; c++) d = a >>> 8 * c & 255, d = "0" + d.toString(16), b += d.substr(d.length - 2, 2);
        return b
    }
    var f = [],
        q, r, s, t, a, b, c, d;
    e = function(a) {
        a = a.replace(/\r\n/g, "\n");
        for (var b = "", d = 0; d < a.length; d++) {
            var c = a.charCodeAt(d);
            128 > c ? b += String.fromCharCode(c) : (127 < c && 2048 > c ? b += String.fromCharCode(c >> 6 | 192) : (b += String.fromCharCode(c >> 12 | 224), b += String.fromCharCode(c >> 6 & 63 | 128)), b += String.fromCharCode(c & 63 | 128))
        }
        return b
    }(e);
    f = function(b) {
        var a, c = b.length;
        a = c + 8;
        for (var d = 16 * ((a - a % 64) / 64 + 1), e = Array(d - 1), f = 0, g = 0; g < c;) a = (g - g % 4) / 4, f = g % 4 * 8, e[a] |= b.charCodeAt(g) << f, g++;
        a = (g - g % 4) / 4;
        e[a] |= 128 << g % 4 * 8;
        e[d - 2] = c << 3;
        e[d - 1] = c >>> 29;
        return e
    }(e);
    a = 1732584193;
    b = 4023233417;
    c = 2562383102;
    d = 271733878;
    for (e = 0; e < f.length; e += 16) q = a, r = b, s = c, t = d, a = k(a, b, c, d, f[e + 0], 7, 3614090360), d = k(d, a, b, c, f[e + 1], 12, 3905402710), c = k(c, d, a, b, f[e + 2], 17, 606105819), b = k(b, c, d, a, f[e + 3], 22, 3250441966), a = k(a, b, c, d, f[e + 4], 7, 4118548399), d = k(d, a, b, c, f[e + 5], 12, 1200080426), c = k(c, d, a, b, f[e + 6], 17, 2821735955), b = k(b, c, d, a, f[e + 7], 22, 4249261313), a = k(a, b, c, d, f[e + 8], 7, 1770035416), d = k(d, a, b, c, f[e + 9], 12, 2336552879), c = k(c, d, a, b, f[e + 10], 17, 4294925233), b = k(b, c, d, a, f[e + 11], 22, 2304563134), a = k(a, b, c, d, f[e + 12], 7, 1804603682), d = k(d, a, b, c, f[e + 13], 12, 4254626195), c = k(c, d, a, b, f[e + 14], 17, 2792965006), b = k(b, c, d, a, f[e + 15], 22, 1236535329), a = l(a, b, c, d, f[e + 1], 5, 4129170786), d = l(d, a, b, c, f[e + 6], 9, 3225465664), c = l(c, d, a, b, f[e + 11], 14, 643717713), b = l(b, c, d, a, f[e + 0], 20, 3921069994), a = l(a, b, c, d, f[e + 5], 5, 3593408605), d = l(d, a, b, c, f[e + 10], 9, 38016083), c = l(c, d, a, b, f[e + 15], 14, 3634488961), b = l(b, c, d, a, f[e + 4], 20, 3889429448), a = l(a, b, c, d, f[e + 9], 5, 568446438), d = l(d, a, b, c, f[e + 14], 9, 3275163606), c = l(c, d, a, b, f[e + 3], 14, 4107603335), b = l(b, c, d, a, f[e + 8], 20, 1163531501), a = l(a, b, c, d, f[e + 13], 5, 2850285829), d = l(d, a, b, c, f[e + 2], 9, 4243563512), c = l(c, d, a, b, f[e + 7], 14, 1735328473), b = l(b, c, d, a, f[e + 12], 20, 2368359562), a = m(a, b, c, d, f[e + 5], 4, 4294588738), d = m(d, a, b, c, f[e + 8], 11, 2272392833), c = m(c, d, a, b, f[e + 11], 16, 1839030562), b = m(b, c, d, a, f[e + 14], 23, 4259657740), a = m(a, b, c, d, f[e + 1], 4, 2763975236), d = m(d, a, b, c, f[e + 4], 11, 1272893353), c = m(c, d, a, b, f[e + 7], 16, 4139469664), b = m(b, c, d, a, f[e + 10], 23, 3200236656), a = m(a, b, c, d, f[e + 13], 4, 681279174), d = m(d, a, b, c, f[e + 0], 11, 3936430074), c = m(c, d, a, b, f[e + 3], 16, 3572445317), b = m(b, c, d, a, f[e + 6], 23, 76029189), a = m(a, b, c, d, f[e + 9], 4, 3654602809), d = m(d, a, b, c, f[e + 12], 11, 3873151461), c = m(c, d, a, b, f[e + 15], 16, 530742520), b = m(b, c, d, a, f[e + 2], 23, 3299628645), a = n(a, b, c, d, f[e + 0], 6, 4096336452), d = n(d, a, b, c, f[e + 7], 10, 1126891415), c = n(c, d, a, b, f[e + 14], 15, 2878612391), b = n(b, c, d, a, f[e + 5], 21, 4237533241), a = n(a, b, c, d, f[e + 12], 6, 1700485571), d = n(d, a, b, c, f[e + 3], 10, 2399980690), c = n(c, d, a, b, f[e + 10], 15, 4293915773), b = n(b, c, d, a, f[e + 1], 21, 2240044497), a = n(a, b, c, d, f[e + 8], 6, 1873313359), d = n(d, a, b, c, f[e + 15], 10, 4264355552), c = n(c, d, a, b, f[e + 6], 15, 2734768916), b = n(b, c, d, a, f[e + 13], 21, 1309151649), a = n(a, b, c, d, f[e + 4], 6, 4149444226), d = n(d, a, b, c, f[e + 11], 10, 3174756917), c = n(c, d, a, b, f[e + 2], 15, 718787259), b = n(b, c, d, a, f[e + 9], 21, 3951481745), a = h(a, q), b = h(b, r), c = h(c, s), d = h(d, t);
    return (p(a) + p(b) + p(c) + p(d)).toLowerCase()
};
<!DOCTYPE html>
<html>
<body onload="md5.value=MD5(a.value);">

<form oninput="md5.value=MD5(a.value)">Enter String:
<input type="string" id="a" name="a" value="https://www.zibri.org"></br></br>MD5:<output id="md5" name="md5" for="a"></output>
</form>

</body>
</html>


ma sembra che l'implementazione più veloce sia questa: myersdaily.org/joseph/javascript/jkm-md5.js
Zibri

questo link non funziona myersdaily.org/joseph/javascript/jkm-md5.js
Giggs

@Giggs usa solo google e lo troverai: pajhome.org.uk/crypt/md5/contrib/jkm-md5.js
Zibri

11

Ho trovato un numero di articoli su questo argomento. Tutti hanno suggerito l'implementazione di Joseph Meyers.

vedi: http://jsperf.com/md5-shootout su alcuni test

nella mia ricerca della massima velocità ho guardato questo codice e ho visto che poteva essere migliorato. Quindi ho creato un nuovo script JS basato sul codice Joseph Meyers.

vedi il codice Jospeh Meyers migliorato


11
perché fork, invece di semplicemente inviare la patch al manutentore?
Nick Jennings,


5

Devo solo supportare i browser HTML5 che supportano array digitati (DataView, ArrayBuffer, ecc.) Penso di aver preso il codice Joseph Myers e di averlo modificato per supportare il passaggio in un Uint8Array. Non ho riscontrato tutti i miglioramenti e probabilmente ci sono ancora alcuni artefatti char () che possono essere migliorati. Ne avevo bisogno per aggiungere al progetto PouchDB.

var PouchUtils = {};
PouchUtils.Crypto = {};
(function () {
    PouchUtils.Crypto.MD5 = function (uint8Array) {
        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.subarray(i - 64, i)));
            }
            s = s.subarray(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[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[i]
                + (s[i + 1] << 8)
                + (s[i + 2] << 16)
                + (s[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));
        }

        function add32(a, b) {
            return (a + b) & 0xFFFFFFFF;
        }

        return md5(uint8Array);
    };
})();

1
Sono interessato alle prestazioni totali del sistema, quindi la mia demo include download xhr2 e negozi PouchDB (IDB). Puoi provarlo e vedere i risultati delle prestazioni su codepen.io/DrYSG/pen/kdzft . Quello che vorrei che una persona con algoritmo MD5 guardasse è le funzioni add32 () e md5blks () e vedere se non possono essere velocizzate da array di tipo binario Uint32Array ()
Dr.YSG

1
Cosa txt = ''significa veramente?
Makarov Sergey,

5

Ho scritto dei test per confrontare diverse implementazioni di hash JavaScript, inclusa la maggior parte delle implementazioni MD5 menzionate qui. Per eseguire i test, vai su http://brillout.github.io/test-javascript-hash-implementations/ e attendi un po '.

Sembra che l' implementazione YaMD5 della risposta di R. Hill sia la più veloce.


Grazie per l'ottimo punto di riferimento !! YaMD5 con caratteri ampi sembra lento, quindi mi atterrerò a FastMD5 per un uso generico.
Alfonso Nishikawa,

4

Mi dava fastidio non riuscire a trovare un'implementazione che sia veloce e supportasse le stringhe Unicode.

Quindi ne ho creato uno che supporta ancora le stringhe Unicode mostra più veloce (al momento della stesura) delle implementazioni delle stringhe solo ASCII attualmente più veloci:

https://github.com/gorhill/yamd5.js

Basato sul codice di Joseph Myers, ma utilizza TypedArrays, oltre ad altri miglioramenti.


Complimenti a te. Questo è in realtà l'unico finora che ho trovato che produce esattamente lo stesso hash dell'utilità md5 su un server Unix. Ben fatto davvero.
Jacques,

4

Solo per divertimento,

questo è lungo 42 righe, si adatta a 120 caratteri in orizzontale e ha un bell'aspetto. È veloce? Bene - è abbastanza veloce ed è approssimativamente uguale a tutte le altre implementazioni JS.

Volevo solo qualcosa che non fosse brutto nel mio file helpers.js e che non rallentasse il mio SublimeText con una linea minuta lunga 20 miglia.

Quindi ecco la mia md5 preferita.

//  A formatted version of a popular md5 implementation.
//  Original copyright (c) Paul Johnston & Greg Holt.
//  The function itself is now 42 lines long.

function md5(inputString) {
    var hc="0123456789abcdef";
    function rh(n) {var j,s="";for(j=0;j<=3;j++) s+=hc.charAt((n>>(j*8+4))&0x0F)+hc.charAt((n>>(j*8))&0x0F);return s;}
    function ad(x,y) {var l=(x&0xFFFF)+(y&0xFFFF);var m=(x>>16)+(y>>16)+(l>>16);return (m<<16)|(l&0xFFFF);}
    function rl(n,c)            {return (n<<c)|(n>>>(32-c));}
    function cm(q,a,b,x,s,t)    {return ad(rl(ad(ad(a,q),ad(x,t)),s),b);}
    function ff(a,b,c,d,x,s,t)  {return cm((b&c)|((~b)&d),a,b,x,s,t);}
    function gg(a,b,c,d,x,s,t)  {return cm((b&d)|(c&(~d)),a,b,x,s,t);}
    function hh(a,b,c,d,x,s,t)  {return cm(b^c^d,a,b,x,s,t);}
    function ii(a,b,c,d,x,s,t)  {return cm(c^(b|(~d)),a,b,x,s,t);}
    function sb(x) {
        var i;var nblk=((x.length+8)>>6)+1;var blks=new Array(nblk*16);for(i=0;i<nblk*16;i++) blks[i]=0;
        for(i=0;i<x.length;i++) blks[i>>2]|=x.charCodeAt(i)<<((i%4)*8);
        blks[i>>2]|=0x80<<((i%4)*8);blks[nblk*16-2]=x.length*8;return blks;
    }
    var i,x=sb(inputString),a=1732584193,b=-271733879,c=-1732584194,d=271733878,olda,oldb,oldc,oldd;
    for(i=0;i<x.length;i+=16) {olda=a;oldb=b;oldc=c;oldd=d;
        a=ff(a,b,c,d,x[i+ 0], 7, -680876936);d=ff(d,a,b,c,x[i+ 1],12, -389564586);c=ff(c,d,a,b,x[i+ 2],17,  606105819);
        b=ff(b,c,d,a,x[i+ 3],22,-1044525330);a=ff(a,b,c,d,x[i+ 4], 7, -176418897);d=ff(d,a,b,c,x[i+ 5],12, 1200080426);
        c=ff(c,d,a,b,x[i+ 6],17,-1473231341);b=ff(b,c,d,a,x[i+ 7],22,  -45705983);a=ff(a,b,c,d,x[i+ 8], 7, 1770035416);
        d=ff(d,a,b,c,x[i+ 9],12,-1958414417);c=ff(c,d,a,b,x[i+10],17,     -42063);b=ff(b,c,d,a,x[i+11],22,-1990404162);
        a=ff(a,b,c,d,x[i+12], 7, 1804603682);d=ff(d,a,b,c,x[i+13],12,  -40341101);c=ff(c,d,a,b,x[i+14],17,-1502002290);
        b=ff(b,c,d,a,x[i+15],22, 1236535329);a=gg(a,b,c,d,x[i+ 1], 5, -165796510);d=gg(d,a,b,c,x[i+ 6], 9,-1069501632);
        c=gg(c,d,a,b,x[i+11],14,  643717713);b=gg(b,c,d,a,x[i+ 0],20, -373897302);a=gg(a,b,c,d,x[i+ 5], 5, -701558691);
        d=gg(d,a,b,c,x[i+10], 9,   38016083);c=gg(c,d,a,b,x[i+15],14, -660478335);b=gg(b,c,d,a,x[i+ 4],20, -405537848);
        a=gg(a,b,c,d,x[i+ 9], 5,  568446438);d=gg(d,a,b,c,x[i+14], 9,-1019803690);c=gg(c,d,a,b,x[i+ 3],14, -187363961);
        b=gg(b,c,d,a,x[i+ 8],20, 1163531501);a=gg(a,b,c,d,x[i+13], 5,-1444681467);d=gg(d,a,b,c,x[i+ 2], 9,  -51403784);
        c=gg(c,d,a,b,x[i+ 7],14, 1735328473);b=gg(b,c,d,a,x[i+12],20,-1926607734);a=hh(a,b,c,d,x[i+ 5], 4,    -378558);
        d=hh(d,a,b,c,x[i+ 8],11,-2022574463);c=hh(c,d,a,b,x[i+11],16, 1839030562);b=hh(b,c,d,a,x[i+14],23,  -35309556);
        a=hh(a,b,c,d,x[i+ 1], 4,-1530992060);d=hh(d,a,b,c,x[i+ 4],11, 1272893353);c=hh(c,d,a,b,x[i+ 7],16, -155497632);
        b=hh(b,c,d,a,x[i+10],23,-1094730640);a=hh(a,b,c,d,x[i+13], 4,  681279174);d=hh(d,a,b,c,x[i+ 0],11, -358537222);
        c=hh(c,d,a,b,x[i+ 3],16, -722521979);b=hh(b,c,d,a,x[i+ 6],23,   76029189);a=hh(a,b,c,d,x[i+ 9], 4, -640364487);
        d=hh(d,a,b,c,x[i+12],11, -421815835);c=hh(c,d,a,b,x[i+15],16,  530742520);b=hh(b,c,d,a,x[i+ 2],23, -995338651);
        a=ii(a,b,c,d,x[i+ 0], 6, -198630844);d=ii(d,a,b,c,x[i+ 7],10, 1126891415);c=ii(c,d,a,b,x[i+14],15,-1416354905);
        b=ii(b,c,d,a,x[i+ 5],21,  -57434055);a=ii(a,b,c,d,x[i+12], 6, 1700485571);d=ii(d,a,b,c,x[i+ 3],10,-1894986606);
        c=ii(c,d,a,b,x[i+10],15,   -1051523);b=ii(b,c,d,a,x[i+ 1],21,-2054922799);a=ii(a,b,c,d,x[i+ 8], 6, 1873313359);
        d=ii(d,a,b,c,x[i+15],10,  -30611744);c=ii(c,d,a,b,x[i+ 6],15,-1560198380);b=ii(b,c,d,a,x[i+13],21, 1309151649);
        a=ii(a,b,c,d,x[i+ 4], 6, -145523070);d=ii(d,a,b,c,x[i+11],10,-1120210379);c=ii(c,d,a,b,x[i+ 2],15,  718787259);
        b=ii(b,c,d,a,x[i+ 9],21, -343485551);a=ad(a,olda);b=ad(b,oldb);c=ad(c,oldc);d=ad(d,oldd);
    }
    return rh(a)+rh(b)+rh(c)+rh(d);
}

Ma davvero, l'ho pubblicato solo per considerazioni estetiche. Inoltre, con i commenti è esattamente 4000 byte. Per favore, non chiedere perché. Non riesco a trovare una spiegazione adeguata per il mio comportamento da DOC / ribelle. Inoltre, grazie Paul Johnston, grazie Greg Holt. (Nota a margine: voi ragazzi avete omesso alcune parole chiave var così mi sono preso la libertà di aggiungerle.)


@dkelner Cool. Vorrei copiare / incollare la tua funzione da utilizzare nella mia app. Per favore, potresti concedere una licenza
pinoyyid

Non è necessario, è assolutamente gratuito da usare, è un'opera derivata da un'altra implementazione gratuita. Quindi basta usarlo e forse commentare gli autori come ho fatto io.
dkellner,

3

Node.js ha il supporto integrato

const crypto = require('crypto')
crypto.createHash('md5').update('hello world').digest('hex')

Lo snippet di codice sopra calcola la stringa esadecimale MD5 per la stringa hello world

Il vantaggio di questa soluzione è che non è necessario installare libreria aggiuntiva.

Penso che la soluzione integrata dovrebbe essere la più veloce. In caso contrario, dovremmo creare il problema / PR per il progetto Node.js.



1

Forse questo pacchetto è stato utile
https://www.npmjs.com/package/pure-md5

console.time('latin');
const latin = md5('hello');
console.timeEnd('latin');

console.log('Привет: ', md5('Привет'));
console.log('嘿: ', md5('嘿'));
<script src="https://unpkg.com/pure-md5@latest/lib/index.js"></script>


0

Perché non provare http://phpjs.org/functions/md5/ ?

Sfortunatamente le prestazioni sono limitate con qualsiasi script emulato, tuttavia questo può rendere un vero hash md5. Anche se consiglierei di non usare md5 per le password, dato che si tratta di un hash con rendering veloce.



-3

Puoi anche controllare la mia implementazione di md5 . Dovrebbe essere di ca. lo stesso dell'altro pubblicato sopra. Sfortunatamente, le prestazioni sono limitate dal circuito interno che è impossibile ottimizzare di più.


-4

Se le prestazioni della tua applicazione sono limitate da un'implementazione Javascript di MD5, allora stai davvero facendo qualcosa di sbagliato. Considera un cambiamento architettonico (suggerimento: usa MD5 meno spesso)


3
Non sto usando MD5 in un'applicazione "nativa" con JS, è uno strumento di controllo MD5 online: bruechner.de/md5file/js non c'è più bisogno di un'app nativa per MD5;)
powtac,
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.