2
我一直无法在IE11中找到任何RSA-OAEP加密的例子。ie11中的RSA-OEP加密
这里是我的实现的一个片段,其中给出了一个非常模糊的错误。
function convertStringToArrayBufferView(str) {
var bytes = new Uint8Array(str.length);
for (var iii = 0; iii < str.length; iii++) {
bytes[iii] = str.charCodeAt(iii);
}
return bytes;
}
var crypto = window.crypto || window.msCrypto;
var config = {
name: 'RSA-OAEP',
modulusLength: 2048,
publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
hash: {
name: 'SHA-256'
}
};
var keyOp = crypto.subtle.generateKey(config, false, ['encrypt', 'decrypt']);
keyOp.onerror = function(e) {
console.error(e);
};
keyOp.oncomplete = function(e) {
encrypt(e.target.result);
};
function encrypt(keypair) {
var data = "abc1234444"
var encOp = crypto.subtle.encrypt({
name: config.name,
iv: config.iv || crypto.getRandomValues(new Uint8Array(16)),
key: keypair.publicKey
}, keypair.publicKey, convertStringToArrayBufferView(data));
encOp.onerror = function(e) {
console.error(e);
};
encOp.oncomplete = function(e) {
console.log({
data: new Uint8Array(e.target.result)
});
};
}
当我改变算法RSAES-PKCS1-v1_5中,一切都完美的作品
function convertStringToArrayBufferView(str) {
var bytes = new Uint8Array(str.length);
for (var iii = 0; iii < str.length; iii++) {
bytes[iii] = str.charCodeAt(iii);
}
return bytes;
}
var crypto = window.crypto || window.msCrypto;
var config = {
name: 'RSAES-PKCS1-v1_5',
modulusLength: 2048,
publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
hash: {
name: 'SHA-256'
}
};
var keyOp = crypto.subtle.generateKey(config, false, ['encrypt', 'decrypt']);
keyOp.onerror = function(e) {
console.error(e);
};
keyOp.oncomplete = function(e) {
encrypt(e.target.result);
};
function encrypt(keypair) {
var data = "abc1234444"
var encOp = crypto.subtle.encrypt({
name: config.name,
iv: config.iv || crypto.getRandomValues(new Uint8Array(16)),
key: keypair.publicKey
}, keypair.publicKey, convertStringToArrayBufferView(data));
encOp.onerror = function(e) {
console.error(e);
};
encOp.oncomplete = function(e) {
console.log({
data: new Uint8Array(e.target.result)
});
};
}
你是很模糊有关*模糊的错误*“来调用加密呼叫时添加哈希场”。它是什么? –
**错误**。如果我深入了解对象,那么我会发现**无法获取未定义或空引用**消息的属性“消息”,但我不相信这与此问题有任何关系。如果您在运行上面的代码片段时没有在IE11中遇到同样的问题,请告诉我。 – chimon