@lambo-design/shared 1.0.0-beta.242 → 1.0.0-beta.243
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/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 -204
- 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;
|