mitao
2024-04-30 ab4ea7b8f10c9b66aed9c2ea161a08b25c3851a7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/*!
 * Crypto-JS v1.1.0
 * http://code.google.com/p/crypto-js/
 * Copyright (c) 2009, Jeff Mott. All rights reserved.
 * http://code.google.com/p/crypto-js/wiki/License
 */
(function(){
 
// Shortcut
var util = Crypto.util;
 
Crypto.PBKDF2 = function (password, salt, keylen, options) {
 
    // Defaults
    var hasher = options && options.hasher || Crypto.SHA1,
        iterations = options && options.iterations || 1;
 
    // Pseudo-random function
    function PRF(password, salt) {
        return Crypto.HMAC(hasher, salt, password, { asBytes: true });
    }
 
    // Generate key
    var derivedKeyBytes = [],
        blockindex = 1;
    while (derivedKeyBytes.length < keylen) {
 
        var block = PRF(password, salt + util.bytesToString(
                                         util.wordsToBytes([blockindex])));
 
        for (var u = block, i = 1; i < iterations; i++) {
            u = PRF(password, util.bytesToString(u));
            for (var j = 0; j < block.length; j++) block[j] ^= u[j];
        }
 
        derivedKeyBytes = derivedKeyBytes.concat(block);
        blockindex++;
 
    }
 
    // Truncate excess bytes
    derivedKeyBytes.length = keylen;
 
    return options && options.asBytes ? derivedKeyBytes :
           options && options.asString ? util.bytesToString(derivedKeyBytes) :
           util.bytesToHex(derivedKeyBytes);
 
};
 
})();