puzhibing
2024-03-07 e6da970f74e5674c3acbe05c51bd34b27882e3e4
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
;(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) {
 
    /** @preserve
     * Counter block mode compatible with  Dr Brian Gladman fileenc.c
     * derived from CryptoJS.mode.CTR
     * Jan Hruby jhruby.web@gmail.com
     */
    CryptoJS.mode.CTRGladman = (function () {
        var CTRGladman = CryptoJS.lib.BlockCipherMode.extend();
 
        function incWord(word)
        {
            if (((word >> 24) & 0xff) === 0xff) { //overflow
            var b1 = (word >> 16)&0xff;
            var b2 = (word >> 8)&0xff;
            var b3 = word & 0xff;
 
            if (b1 === 0xff) // overflow b1
            {
            b1 = 0;
            if (b2 === 0xff)
            {
                b2 = 0;
                if (b3 === 0xff)
                {
                    b3 = 0;
                }
                else
                {
                    ++b3;
                }
            }
            else
            {
                ++b2;
            }
            }
            else
            {
            ++b1;
            }
 
            word = 0;
            word += (b1 << 16);
            word += (b2 << 8);
            word += b3;
            }
            else
            {
            word += (0x01 << 24);
            }
            return word;
        }
 
        function incCounter(counter)
        {
            if ((counter[0] = incWord(counter[0])) === 0)
            {
                // encr_data in fileenc.c from  Dr Brian Gladman's counts only with DWORD j < 8
                counter[1] = incWord(counter[1]);
            }
            return counter;
        }
 
        var Encryptor = CTRGladman.Encryptor = CTRGladman.extend({
            processBlock: function (words, offset) {
                // Shortcuts
                var cipher = this._cipher
                var blockSize = cipher.blockSize;
                var iv = this._iv;
                var counter = this._counter;
 
                // Generate keystream
                if (iv) {
                    counter = this._counter = iv.slice(0);
 
                    // Remove IV for subsequent blocks
                    this._iv = undefined;
                }
 
                incCounter(counter);
 
                var keystream = counter.slice(0);
                cipher.encryptBlock(keystream, 0);
 
                // Encrypt
                for (var i = 0; i < blockSize; i++) {
                    words[offset + i] ^= keystream[i];
                }
            }
        });
 
        CTRGladman.Decryptor = Encryptor;
 
        return CTRGladman;
    }());
 
 
 
 
    return CryptoJS.mode.CTRGladman;
 
}));