Internet Explorer 11中的公钥加密

3

我正在尝试使用以下代码在IE11中使用JavaScript实现公钥加密:

<script>
    var data = new Uint8Array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]);

    var crypto = window.crypto || window.msCrypto;
    var cryptoSubtle = crypto.subtle;

    var genOp = cryptoSubtle.generateKey(
        {
            name: "RSA-OAEP",
            modulusLength: 2048,
            publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
            hash: { name: "SHA-256" },
        },
        true,
        ["encrypt", "decrypt"]
    );

    genOp.onerror = function (e) {
        console.error(e);
    };

    genOp.oncomplete = function (e) {
        var key = e.target.result;
        console.log(key);
        console.log(key.publicKey);

        var encOp = cryptoSubtle.encrypt(
            {
                name: "RSA-OAEP"
            },
            key.publicKey,
            data
        );

        encOp.onerror = function (e) {
            console.error(e);
        };

        encOp.oncomplete = function (e) {
            var encrypted = e.target.result;
            console.log(new Uint8Array(encrypted));
        };
    };
</script>

它生成了密钥对,但在加密时出现错误事件。使用对称AES密钥的类似代码是可行的。IE11支持公钥加密吗?我的代码有什么问题吗?


1
这个问题与这个问题有何不同? - President James K. Polk
@JamesKPolk 这个问题是关于IE11的,另一个问题是关于Edge的。可以说它们本来可以合并成一个问题,但是有5个标签限制和其他考虑因素。所以我能理解OP为每个浏览器发布单独的问题而进行实验。 - sideshowbarker
1
@JamesKPolk IE11的API与Edge不同,因此代码也不同。 - FengHuang
1个回答

5
我已经找到了原因。在调用加密函数时,需要添加哈希字段:
        var encOp = cryptoSubtle.encrypt(
            {
                name: "RSA-OAEP",
                hash: { name: "SHA-256" }
            },
            key.publicKey,
            data
        );

这不符合Web Cryptography API规范,但它可以正常工作。

如果这里的IE行为不符合规范,请考虑针对IE提交错误报告,并在可能的情况下在此处发布该错误报告的链接。 - sideshowbarker

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接