MrShi
2025-04-18 d236644c792463102b566463c4f06dc2ddfa5e0e
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
;(function (root, factory, undef) {
    if (typeof exports === "object") {
        // CommonJS
        module.exports = exports = factory(require("./core"), require("./cipher-core"));
    }
    else if (typeof define === "function" && define.amd) {
        // AMD
        define(["./core", "./cipher-core"], factory);
    }
    else {
        // Global (browser)
        factory(root.CryptoJS);
    }
}(this, function (CryptoJS) {
 
    /**
     * Cipher Feedback block mode.
     */
    CryptoJS.mode.CFB = (function () {
        var CFB = CryptoJS.lib.BlockCipherMode.extend();
 
        CFB.Encryptor = CFB.extend({
            processBlock: function (words, offset) {
                // Shortcuts
                var cipher = this._cipher;
                var blockSize = cipher.blockSize;
 
                generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);
 
                // Remember this block to use with next block
                this._prevBlock = words.slice(offset, offset + blockSize);
            }
        });
 
        CFB.Decryptor = CFB.extend({
            processBlock: function (words, offset) {
                // Shortcuts
                var cipher = this._cipher;
                var blockSize = cipher.blockSize;
 
                // Remember this block to use with next block
                var thisBlock = words.slice(offset, offset + blockSize);
 
                generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);
 
                // This block becomes the previous block
                this._prevBlock = thisBlock;
            }
        });
 
        function generateKeystreamAndEncrypt(words, offset, blockSize, cipher) {
            var keystream;
 
            // Shortcut
            var iv = this._iv;
 
            // Generate keystream
            if (iv) {
                keystream = iv.slice(0);
 
                // Remove IV for subsequent blocks
                this._iv = undefined;
            } else {
                keystream = this._prevBlock;
            }
            cipher.encryptBlock(keystream, 0);
 
            // Encrypt
            for (var i = 0; i < blockSize; i++) {
                words[offset + i] ^= keystream[i];
            }
        }
 
        return CFB;
    }());
 
 
    return CryptoJS.mode.CFB;
 
}));