小编AUs*_*532的帖子

Javascript RSA-OAEP 不适用于任意输入长度

我正在尝试使用 SubtleCrypto 加密 javascript (firefox) 中的字符串。问题在于,加密仅适用于短输入。一旦字符串 (testdata) 超过 190 个字符,它将失败并出现操作错误。为什么 SubtleCrypto 会有这样的行为以及如何解决它?

代码:

function str2ab(str) {
  var encoder = new TextEncoder('utf-8');
  return encoder.encode(str);
}

function ab2str(buf) {
  var decoder = new TextDecoder('utf-8');
  return decoder.decode(buf);
}

var keypair;
var algorithmKeyGen = {
  name: 'RSA-OAEP',
  modulusLength: 2048,
  publicExponent: new Uint8Array([1,
    0,
    1
  ]), // Equivalent to 65537
  hash: {
    name: 'SHA-256'
  }
};
var crypter = window.crypto.subtle;

function encrypt(buffer) {
  return crypter.encrypt(algorithmKeyGen, keypair.publicKey, buffer).then(
    function(data) {
      alert(ab2str(data));
    },
    function(error) {
      alert(error);
    } …
Run Code Online (Sandbox Code Playgroud)

javascript encryption rsa webcrypto-api

3
推荐指数
1
解决办法
1882
查看次数

标签 统计

encryption ×1

javascript ×1

rsa ×1

webcrypto-api ×1