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) 
 
     }); 
 
     }; 
 
    }

+1

你是很模糊有关*模糊的错误*“来调用加密呼叫时添加哈希场”。它是什么? –

+0

**错误**。如果我深入了解对象,那么我会发现**无法获取未定义或空引用**消息的属性“消息”,但我不相信这与此问题有任何关系。如果您在运行上面的代码片段时没有在IE11中遇到同样的问题,请告诉我。 – chimon

回答