@lambo-design/shared 1.0.0-beta.240 → 1.0.0-beta.242
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/config/config.js +51 -51
- package/config/env.js +4 -4
- package/config/index.js +7 -7
- package/config/themes/atrovirens/atrovirens.less +667 -667
- package/config/themes/atrovirens/var.less +674 -674
- package/config/themes/blue/blue.less +669 -669
- package/config/themes/blue/var.less +677 -677
- package/config/themes/blue-white/blue-white.less +669 -669
- package/config/themes/blue-white/var.less +676 -676
- package/config/themes/blue-white-tight/blue-white-tight.less +672 -672
- package/config/themes/blue-white-tight/var.less +677 -677
- package/config/themes/danqing/danqing.less +668 -668
- package/config/themes/danqing/danqing.wxss +572 -572
- package/config/themes/danqing/var.less +679 -679
- package/config/themes/deep/deep.less +669 -669
- package/config/themes/deep/var.less +677 -677
- package/config/themes/default/default.less +671 -671
- package/config/themes/default/var.less +677 -677
- package/config/themes/eap/eap.less +671 -671
- package/config/themes/eap/var.less +677 -677
- package/config/themes/gold/gold.less +671 -671
- package/config/themes/gold/var.less +677 -677
- package/config/themes/index.js +28 -28
- package/config/themes/lime/lime.less +671 -671
- package/config/themes/lime/var.less +678 -678
- package/config/themes/orange/orange.less +671 -671
- package/config/themes/orange/var.less +678 -678
- package/config/themes/red/red.less +671 -671
- package/config/themes/red/var.less +677 -677
- package/config/themes/theme-atrovirens.js +558 -558
- package/config/themes/theme-blue.js +558 -558
- package/config/themes/theme-bw.js +558 -558
- package/config/themes/theme-bwt.js +559 -559
- package/config/themes/theme-danqing.js +558 -558
- package/config/themes/theme-deep.js +558 -558
- package/config/themes/theme-default.js +558 -558
- package/config/themes/theme-eap.js +558 -558
- package/config/themes/theme-gold.js +558 -558
- package/config/themes/theme-lime.js +558 -558
- package/config/themes/theme-orange.js +559 -559
- package/config/themes/theme-red.js +558 -558
- package/config/themes/theme-white.js +557 -557
- package/config/themes/white/var.less +675 -675
- package/config/themes/white/white.less +668 -668
- package/directives/index.js +23 -23
- package/directives/module/draggable.js +56 -56
- package/directives/module/permission.js +49 -49
- package/directives/module/print.js +1 -1
- package/directives/module/vue-print-nb/README.md +63 -63
- package/directives/module/vue-print-nb/print.js +94 -94
- package/directives/module/vue-print-nb/printarea.js +532 -532
- package/index.js +10 -10
- package/nstyles/common.less +197 -197
- package/nstyles/components/404.less +46 -46
- package/nstyles/components/button.less +34 -34
- package/nstyles/components/date-picker.less +37 -37
- package/nstyles/components/drawer.less +20 -20
- package/nstyles/components/dropdown.less +18 -18
- package/nstyles/components/excel-flow.less +72 -72
- package/nstyles/components/form.less +313 -313
- package/nstyles/components/index.less +23 -23
- package/nstyles/components/layout/collect.less +10 -10
- package/nstyles/components/layout/detail-view.less +107 -107
- package/nstyles/components/layout/full-screen.less +7 -7
- package/nstyles/components/layout/index.less +7 -7
- package/nstyles/components/layout/other-menu.less +142 -142
- package/nstyles/components/layout/page-view.less +101 -101
- package/nstyles/components/layout/sider-trigger.less +41 -41
- package/nstyles/components/layout/tags-nav.less +113 -113
- package/nstyles/components/modal.less +85 -85
- package/nstyles/components/n-button.less +131 -131
- package/nstyles/components/n-image-preview.less +131 -131
- package/nstyles/components/n-model/index.less +19 -19
- package/nstyles/components/n-model/report-index.less +43 -43
- package/nstyles/components/n-panel.less +40 -40
- package/nstyles/components/n-picker.less +37 -37
- package/nstyles/components/n-sign.less +17 -17
- package/nstyles/components/n-tooltip.less +10 -10
- package/nstyles/components/panel.less +31 -31
- package/nstyles/components/select.less +3 -3
- package/nstyles/components/sign.less +27 -27
- package/nstyles/components/table.less +315 -315
- package/nstyles/components/tree.less +158 -158
- package/nstyles/components/upload.less +164 -164
- package/nstyles/index.less +5 -5
- package/nstyles/reset.less +65 -65
- package/nstyles/third/ag.less +174 -174
- package/nstyles/third/index.less +11 -11
- package/nstyles/third/view-design.less +366 -366
- package/nstyles/variables/base.less +143 -143
- package/nstyles/variables/index.less +4 -4
- package/nstyles/variables/theme/default/button.less +7 -7
- package/nstyles/variables/theme/default/common.less +57 -57
- package/nstyles/variables/theme/default/index.less +7 -7
- package/nstyles/variables/theme/default/layout.less +40 -40
- package/nstyles/variables/theme/default/table.less +37 -37
- package/nstyles/variables/theme/default/tag.less +3 -3
- package/nstyles/variables/theme/default/upload.less +3 -3
- package/nstyles/variables/theme/index.less +13 -13
- package/nstyles/variables/theme/small/button.less +7 -7
- package/nstyles/variables/theme/small/common.less +39 -39
- package/nstyles/variables/theme/small/index.less +5 -5
- package/nstyles/variables/theme/small/layout.less +21 -21
- package/nstyles/variables/theme/small/table.less +17 -17
- package/nstyles/variables/theme/small/tag.less +3 -3
- package/package.json +1 -1
- package/plugin/index.js +12 -12
- package/plugin/module/date-format.js +30 -30
- package/plugin/module/loading.js +26 -26
- package/plugin/module/warn-handler.js +11 -11
- package/styles/variables.less +21 -21
- package/utils/ajax/cacheconf.js +19 -19
- package/utils/ajax/content-type.js +30 -30
- package/utils/ajax/index.js +12 -12
- package/utils/ajax/interceptors.js +97 -97
- package/utils/ajax/sseFetchUtil.js +71 -0
- package/utils/assist.js +147 -147
- package/utils/base64.js +126 -126
- package/utils/blob.js +47 -47
- package/utils/bus.js +3 -3
- package/utils/crypto/index.js +48 -48
- package/utils/crypto/md5.js +152 -152
- package/utils/crypto/sm3.js +235 -235
- package/utils/date.js +381 -381
- package/utils/dict/built-in-dict.js +20 -20
- package/utils/dict/index.js +167 -167
- package/utils/dom.js +38 -38
- package/utils/event.js +72 -72
- package/utils/excel.js +655 -655
- package/utils/file.js +19 -19
- package/utils/form/validate.js +29 -29
- package/utils/half-year.js +68 -68
- package/utils/index.js +41 -41
- package/utils/json.js +29 -29
- package/utils/lodop.js +165 -165
- package/utils/menu/before-close.js +17 -17
- package/utils/menu/index.js +395 -395
- package/utils/mime_type.js +67 -67
- package/utils/modelerUtil.js +227 -227
- package/utils/n/api.js +22 -22
- package/utils/n/date.js +57 -57
- package/utils/n/index.js +9 -9
- package/utils/n/is-type.js +176 -176
- package/utils/n/number.js +144 -144
- package/utils/n/permission-cache.js +11 -11
- package/utils/n/reuqest/axiosN.js +17 -17
- package/utils/n/reuqest/content-type.js +19 -19
- package/utils/n/reuqest/interceptors.js +95 -95
- package/utils/n/reuqest/url-params.js +12 -12
- package/utils/n/storage.js +51 -51
- package/utils/n/token.js +51 -51
- package/utils/n/user-cache.js +11 -11
- package/utils/n/user.js +34 -34
- package/utils/n/uuid.js +16 -16
- package/utils/n-generator-routers.js +208 -208
- package/utils/n-router.js +205 -205
- package/utils/n-theme.js +30 -30
- package/utils/number.js +180 -180
- package/utils/oss.js +57 -57
- package/utils/platform.js +1334 -1334
- package/utils/quarter.js +58 -58
- package/utils/storage.js +198 -198
- package/utils/style.js +24 -24
- package/utils/theme.js +138 -138
- package/utils/transfer-queue.js +7 -7
- package/utils/transform.js +204 -205
- package/utils/type.js +102 -102
- package/utils/util.js +795 -795
- package/utils/validator.js +181 -181
- package/utils/vxetable/index.js +25 -25
- package/utils/zoomScroll.js +9 -9
package/utils/crypto/sm3.js
CHANGED
|
@@ -1,235 +1,235 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 左补0到指定长度
|
|
3
|
-
*/
|
|
4
|
-
function leftPad(input, num) {
|
|
5
|
-
if (input.length >= num) return input;
|
|
6
|
-
|
|
7
|
-
return (new Array(num - input.length + 1)).join('0') + input
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* 二进制转化为十六进制
|
|
12
|
-
*/
|
|
13
|
-
function binary2hex(binary) {
|
|
14
|
-
const binaryLength = 8;
|
|
15
|
-
let hex = '';
|
|
16
|
-
for (let i = 0; i < binary.length / binaryLength; i++) {
|
|
17
|
-
hex += leftPad(parseInt(binary.substr(i * binaryLength, binaryLength), 2).toString(16), 2);
|
|
18
|
-
}
|
|
19
|
-
return hex;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* 十六进制转化为二进制
|
|
24
|
-
*/
|
|
25
|
-
function hex2binary(hex) {
|
|
26
|
-
const hexLength = 2;
|
|
27
|
-
let binary = '';
|
|
28
|
-
for (let i = 0; i < hex.length / hexLength; i++) {
|
|
29
|
-
binary += leftPad(parseInt(hex.substr(i * hexLength, hexLength), 16).toString(2), 8);
|
|
30
|
-
}
|
|
31
|
-
return binary;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* 普通字符串转化为二进制
|
|
36
|
-
*/
|
|
37
|
-
function str2binary(str) {
|
|
38
|
-
let binary = '';
|
|
39
|
-
for (const ch of str) {
|
|
40
|
-
binary += leftPad(ch.codePointAt(0).toString(2), 8);
|
|
41
|
-
}
|
|
42
|
-
return binary;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* 循环左移
|
|
47
|
-
*/
|
|
48
|
-
function rol(str, n) {
|
|
49
|
-
return str.substring(n % str.length) + str.substr(0, n % str.length);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* 二进制运算
|
|
54
|
-
*/
|
|
55
|
-
function binaryCal(x, y, method) {
|
|
56
|
-
const a = x || '';
|
|
57
|
-
const b = y || '';
|
|
58
|
-
const result = [];
|
|
59
|
-
let prevResult;
|
|
60
|
-
|
|
61
|
-
for (let i = a.length - 1; i >= 0; i--) { // 大端
|
|
62
|
-
prevResult = method(a[i], b[i], prevResult);
|
|
63
|
-
result[i] = prevResult[0];
|
|
64
|
-
}
|
|
65
|
-
return result.join('');
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* 二进制异或运算
|
|
70
|
-
*/
|
|
71
|
-
function xor(x, y) {
|
|
72
|
-
return binaryCal(x, y, (a, b) => [(a === b ? '0' : '1')]);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* 二进制与运算
|
|
77
|
-
*/
|
|
78
|
-
function and(x, y) {
|
|
79
|
-
return binaryCal(x, y, (a, b) => [(a === '1' && b === '1' ? '1' : '0')]);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* 二进制或运算
|
|
84
|
-
*/
|
|
85
|
-
function or(x, y) {
|
|
86
|
-
return binaryCal(x, y, (a, b) => [(a === '1' || b === '1' ? '1' : '0')]); // a === '0' && b === '0' ? '0' : '1'
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* 二进制与运算
|
|
91
|
-
*/
|
|
92
|
-
function add(x, y) {
|
|
93
|
-
const result = binaryCal(x, y, (a, b, prevResult) => {
|
|
94
|
-
const carry = prevResult ? prevResult[1] : '0' || '0';
|
|
95
|
-
|
|
96
|
-
// a,b不等时,carry不变,结果与carry相反
|
|
97
|
-
// a,b相等时,结果等于原carry,新carry等于a
|
|
98
|
-
if (a !== b) return [carry === '0' ? '1' : '0', carry];
|
|
99
|
-
|
|
100
|
-
return [carry, a];
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
return result;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/**
|
|
107
|
-
* 二进制非运算
|
|
108
|
-
*/
|
|
109
|
-
function not(x) {
|
|
110
|
-
return binaryCal(x, undefined, a => [a === '1' ? '0' : '1']);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
function calMulti(method) {
|
|
114
|
-
return (...arr) => arr.reduce((prev, curr) => method(prev, curr));
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
* 压缩函数中的置换函数 P1(X) = X xor (X <<< 9) xor (X <<< 17)
|
|
119
|
-
*/
|
|
120
|
-
function P0(X) {
|
|
121
|
-
return calMulti(xor)(X, rol(X, 9), rol(X, 17));
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
/**
|
|
125
|
-
* 消息扩展中的置换函数 P1(X) = X xor (X <<< 15) xor (X <<< 23)
|
|
126
|
-
*/
|
|
127
|
-
function P1(X) {
|
|
128
|
-
return calMulti(xor)(X, rol(X, 15), rol(X, 23));
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
function FF(X, Y, Z, j) {
|
|
132
|
-
return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : calMulti(or)(and(X, Y), and(X, Z), and(Y, Z));
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
function GG(X, Y, Z, j) {
|
|
136
|
-
return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : or(and(X, Y), and(not(X), Z));
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
function T(j) {
|
|
140
|
-
return j >= 0 && j <= 15 ? hex2binary('79cc4519') : hex2binary('7a879d8a');
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* 压缩函数
|
|
145
|
-
*/
|
|
146
|
-
function CF(V, Bi) {
|
|
147
|
-
// 消息扩展
|
|
148
|
-
const wordLength = 32;
|
|
149
|
-
const W = [];
|
|
150
|
-
const M = []; // W'
|
|
151
|
-
|
|
152
|
-
// 将消息分组B划分为16个字W0, W1,…… ,W15 (字为长度为32的比特串)
|
|
153
|
-
for (let i = 0; i < 16; i++) {
|
|
154
|
-
W.push(Bi.substr(i * wordLength, wordLength));
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
// W[j] <- P1(W[j−16] xor W[j−9] xor (W[j−3] <<< 15)) xor (W[j−13] <<< 7) xor W[j−6]
|
|
158
|
-
for (let j = 16; j < 68; j++) {
|
|
159
|
-
W.push(calMulti(xor)(
|
|
160
|
-
P1(calMulti(xor)(W[j - 16], W[j - 9], rol(W[j - 3], 15))),
|
|
161
|
-
rol(W[j - 13], 7),
|
|
162
|
-
W[j - 6]
|
|
163
|
-
));
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
// W′[j] = W[j] xor W[j+4]
|
|
167
|
-
for (let j = 0; j < 64; j++) {
|
|
168
|
-
M.push(xor(W[j], W[j + 4]));
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
// 压缩
|
|
172
|
-
const wordRegister = []; // 字寄存器
|
|
173
|
-
for (let j = 0; j < 8; j++) {
|
|
174
|
-
wordRegister.push(V.substr(j * wordLength, wordLength));
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
let A = wordRegister[0];
|
|
178
|
-
let B = wordRegister[1];
|
|
179
|
-
let C = wordRegister[2];
|
|
180
|
-
let D = wordRegister[3];
|
|
181
|
-
let E = wordRegister[4];
|
|
182
|
-
let F = wordRegister[5];
|
|
183
|
-
let G = wordRegister[6];
|
|
184
|
-
let H = wordRegister[7];
|
|
185
|
-
|
|
186
|
-
// 中间变量
|
|
187
|
-
let SS1;
|
|
188
|
-
let SS2;
|
|
189
|
-
let TT1;
|
|
190
|
-
let TT2;
|
|
191
|
-
for (let j = 0; j < 64; j++) {
|
|
192
|
-
SS1 = rol(calMulti(add)(rol(A, 12), E, rol(T(j), j)), 7);
|
|
193
|
-
SS2 = xor(SS1, rol(A, 12));
|
|
194
|
-
|
|
195
|
-
TT1 = calMulti(add)(FF(A, B, C, j), D, SS2, M[j]);
|
|
196
|
-
TT2 = calMulti(add)(GG(E, F, G, j), H, SS1, W[j]);
|
|
197
|
-
|
|
198
|
-
D = C;
|
|
199
|
-
C = rol(B, 9);
|
|
200
|
-
B = A;
|
|
201
|
-
A = TT1;
|
|
202
|
-
H = G;
|
|
203
|
-
G = rol(F, 19);
|
|
204
|
-
F = E;
|
|
205
|
-
E = P0(TT2);
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
return xor([A, B, C, D, E, F, G, H].join(''), V);
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
function sm3(str) {
|
|
212
|
-
const binary = str2binary(str);
|
|
213
|
-
|
|
214
|
-
// 填充
|
|
215
|
-
const len = binary.length;
|
|
216
|
-
|
|
217
|
-
// k是满足len + 1 + k = 448mod512的最小的非负整数
|
|
218
|
-
let k = len % 512;
|
|
219
|
-
|
|
220
|
-
// 如果 448 <= (512 % len) < 512,需要多补充 (len % 448) 比特'0'以满足总比特长度为512的倍数
|
|
221
|
-
k = k >= 448 ? 512 - (k % 448) - 1 : 448 - k - 1;
|
|
222
|
-
|
|
223
|
-
const m = `${binary}1${leftPad('', k)}${leftPad(len.toString(2), 64)}`.toString(); // k个0
|
|
224
|
-
|
|
225
|
-
// 迭代压缩
|
|
226
|
-
const n = (len + k + 65) / 512;
|
|
227
|
-
|
|
228
|
-
let V = hex2binary('7380166f4914b2b9172442d7da8a0600a96f30bc163138aae38dee4db0fb0e4e');
|
|
229
|
-
for (let i = 0; i <= n - 1; i++) {
|
|
230
|
-
const B = m.substr(512 * i, 512);
|
|
231
|
-
V = CF(V, B);
|
|
232
|
-
}
|
|
233
|
-
return binary2hex(V);
|
|
234
|
-
};
|
|
235
|
-
export default sm3;
|
|
1
|
+
/**
|
|
2
|
+
* 左补0到指定长度
|
|
3
|
+
*/
|
|
4
|
+
function leftPad(input, num) {
|
|
5
|
+
if (input.length >= num) return input;
|
|
6
|
+
|
|
7
|
+
return (new Array(num - input.length + 1)).join('0') + input
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* 二进制转化为十六进制
|
|
12
|
+
*/
|
|
13
|
+
function binary2hex(binary) {
|
|
14
|
+
const binaryLength = 8;
|
|
15
|
+
let hex = '';
|
|
16
|
+
for (let i = 0; i < binary.length / binaryLength; i++) {
|
|
17
|
+
hex += leftPad(parseInt(binary.substr(i * binaryLength, binaryLength), 2).toString(16), 2);
|
|
18
|
+
}
|
|
19
|
+
return hex;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* 十六进制转化为二进制
|
|
24
|
+
*/
|
|
25
|
+
function hex2binary(hex) {
|
|
26
|
+
const hexLength = 2;
|
|
27
|
+
let binary = '';
|
|
28
|
+
for (let i = 0; i < hex.length / hexLength; i++) {
|
|
29
|
+
binary += leftPad(parseInt(hex.substr(i * hexLength, hexLength), 16).toString(2), 8);
|
|
30
|
+
}
|
|
31
|
+
return binary;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* 普通字符串转化为二进制
|
|
36
|
+
*/
|
|
37
|
+
function str2binary(str) {
|
|
38
|
+
let binary = '';
|
|
39
|
+
for (const ch of str) {
|
|
40
|
+
binary += leftPad(ch.codePointAt(0).toString(2), 8);
|
|
41
|
+
}
|
|
42
|
+
return binary;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* 循环左移
|
|
47
|
+
*/
|
|
48
|
+
function rol(str, n) {
|
|
49
|
+
return str.substring(n % str.length) + str.substr(0, n % str.length);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* 二进制运算
|
|
54
|
+
*/
|
|
55
|
+
function binaryCal(x, y, method) {
|
|
56
|
+
const a = x || '';
|
|
57
|
+
const b = y || '';
|
|
58
|
+
const result = [];
|
|
59
|
+
let prevResult;
|
|
60
|
+
|
|
61
|
+
for (let i = a.length - 1; i >= 0; i--) { // 大端
|
|
62
|
+
prevResult = method(a[i], b[i], prevResult);
|
|
63
|
+
result[i] = prevResult[0];
|
|
64
|
+
}
|
|
65
|
+
return result.join('');
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* 二进制异或运算
|
|
70
|
+
*/
|
|
71
|
+
function xor(x, y) {
|
|
72
|
+
return binaryCal(x, y, (a, b) => [(a === b ? '0' : '1')]);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* 二进制与运算
|
|
77
|
+
*/
|
|
78
|
+
function and(x, y) {
|
|
79
|
+
return binaryCal(x, y, (a, b) => [(a === '1' && b === '1' ? '1' : '0')]);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* 二进制或运算
|
|
84
|
+
*/
|
|
85
|
+
function or(x, y) {
|
|
86
|
+
return binaryCal(x, y, (a, b) => [(a === '1' || b === '1' ? '1' : '0')]); // a === '0' && b === '0' ? '0' : '1'
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* 二进制与运算
|
|
91
|
+
*/
|
|
92
|
+
function add(x, y) {
|
|
93
|
+
const result = binaryCal(x, y, (a, b, prevResult) => {
|
|
94
|
+
const carry = prevResult ? prevResult[1] : '0' || '0';
|
|
95
|
+
|
|
96
|
+
// a,b不等时,carry不变,结果与carry相反
|
|
97
|
+
// a,b相等时,结果等于原carry,新carry等于a
|
|
98
|
+
if (a !== b) return [carry === '0' ? '1' : '0', carry];
|
|
99
|
+
|
|
100
|
+
return [carry, a];
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
return result;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* 二进制非运算
|
|
108
|
+
*/
|
|
109
|
+
function not(x) {
|
|
110
|
+
return binaryCal(x, undefined, a => [a === '1' ? '0' : '1']);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
function calMulti(method) {
|
|
114
|
+
return (...arr) => arr.reduce((prev, curr) => method(prev, curr));
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
/**
|
|
118
|
+
* 压缩函数中的置换函数 P1(X) = X xor (X <<< 9) xor (X <<< 17)
|
|
119
|
+
*/
|
|
120
|
+
function P0(X) {
|
|
121
|
+
return calMulti(xor)(X, rol(X, 9), rol(X, 17));
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* 消息扩展中的置换函数 P1(X) = X xor (X <<< 15) xor (X <<< 23)
|
|
126
|
+
*/
|
|
127
|
+
function P1(X) {
|
|
128
|
+
return calMulti(xor)(X, rol(X, 15), rol(X, 23));
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
function FF(X, Y, Z, j) {
|
|
132
|
+
return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : calMulti(or)(and(X, Y), and(X, Z), and(Y, Z));
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
function GG(X, Y, Z, j) {
|
|
136
|
+
return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : or(and(X, Y), and(not(X), Z));
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
function T(j) {
|
|
140
|
+
return j >= 0 && j <= 15 ? hex2binary('79cc4519') : hex2binary('7a879d8a');
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* 压缩函数
|
|
145
|
+
*/
|
|
146
|
+
function CF(V, Bi) {
|
|
147
|
+
// 消息扩展
|
|
148
|
+
const wordLength = 32;
|
|
149
|
+
const W = [];
|
|
150
|
+
const M = []; // W'
|
|
151
|
+
|
|
152
|
+
// 将消息分组B划分为16个字W0, W1,…… ,W15 (字为长度为32的比特串)
|
|
153
|
+
for (let i = 0; i < 16; i++) {
|
|
154
|
+
W.push(Bi.substr(i * wordLength, wordLength));
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
// W[j] <- P1(W[j−16] xor W[j−9] xor (W[j−3] <<< 15)) xor (W[j−13] <<< 7) xor W[j−6]
|
|
158
|
+
for (let j = 16; j < 68; j++) {
|
|
159
|
+
W.push(calMulti(xor)(
|
|
160
|
+
P1(calMulti(xor)(W[j - 16], W[j - 9], rol(W[j - 3], 15))),
|
|
161
|
+
rol(W[j - 13], 7),
|
|
162
|
+
W[j - 6]
|
|
163
|
+
));
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
// W′[j] = W[j] xor W[j+4]
|
|
167
|
+
for (let j = 0; j < 64; j++) {
|
|
168
|
+
M.push(xor(W[j], W[j + 4]));
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
// 压缩
|
|
172
|
+
const wordRegister = []; // 字寄存器
|
|
173
|
+
for (let j = 0; j < 8; j++) {
|
|
174
|
+
wordRegister.push(V.substr(j * wordLength, wordLength));
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
let A = wordRegister[0];
|
|
178
|
+
let B = wordRegister[1];
|
|
179
|
+
let C = wordRegister[2];
|
|
180
|
+
let D = wordRegister[3];
|
|
181
|
+
let E = wordRegister[4];
|
|
182
|
+
let F = wordRegister[5];
|
|
183
|
+
let G = wordRegister[6];
|
|
184
|
+
let H = wordRegister[7];
|
|
185
|
+
|
|
186
|
+
// 中间变量
|
|
187
|
+
let SS1;
|
|
188
|
+
let SS2;
|
|
189
|
+
let TT1;
|
|
190
|
+
let TT2;
|
|
191
|
+
for (let j = 0; j < 64; j++) {
|
|
192
|
+
SS1 = rol(calMulti(add)(rol(A, 12), E, rol(T(j), j)), 7);
|
|
193
|
+
SS2 = xor(SS1, rol(A, 12));
|
|
194
|
+
|
|
195
|
+
TT1 = calMulti(add)(FF(A, B, C, j), D, SS2, M[j]);
|
|
196
|
+
TT2 = calMulti(add)(GG(E, F, G, j), H, SS1, W[j]);
|
|
197
|
+
|
|
198
|
+
D = C;
|
|
199
|
+
C = rol(B, 9);
|
|
200
|
+
B = A;
|
|
201
|
+
A = TT1;
|
|
202
|
+
H = G;
|
|
203
|
+
G = rol(F, 19);
|
|
204
|
+
F = E;
|
|
205
|
+
E = P0(TT2);
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
return xor([A, B, C, D, E, F, G, H].join(''), V);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
function sm3(str) {
|
|
212
|
+
const binary = str2binary(str);
|
|
213
|
+
|
|
214
|
+
// 填充
|
|
215
|
+
const len = binary.length;
|
|
216
|
+
|
|
217
|
+
// k是满足len + 1 + k = 448mod512的最小的非负整数
|
|
218
|
+
let k = len % 512;
|
|
219
|
+
|
|
220
|
+
// 如果 448 <= (512 % len) < 512,需要多补充 (len % 448) 比特'0'以满足总比特长度为512的倍数
|
|
221
|
+
k = k >= 448 ? 512 - (k % 448) - 1 : 448 - k - 1;
|
|
222
|
+
|
|
223
|
+
const m = `${binary}1${leftPad('', k)}${leftPad(len.toString(2), 64)}`.toString(); // k个0
|
|
224
|
+
|
|
225
|
+
// 迭代压缩
|
|
226
|
+
const n = (len + k + 65) / 512;
|
|
227
|
+
|
|
228
|
+
let V = hex2binary('7380166f4914b2b9172442d7da8a0600a96f30bc163138aae38dee4db0fb0e4e');
|
|
229
|
+
for (let i = 0; i <= n - 1; i++) {
|
|
230
|
+
const B = m.substr(512 * i, 512);
|
|
231
|
+
V = CF(V, B);
|
|
232
|
+
}
|
|
233
|
+
return binary2hex(V);
|
|
234
|
+
};
|
|
235
|
+
export default sm3;
|