Шифрование с открытым ключом в Internet Explorer 11

Я пытаюсь реализовать шифрование с открытым ключом с помощью JavaScript для IE11 со следующим кодом:

<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? Что-то не так с моим кодом?


comment
Чем этот вопрос отличается от этого?   -  person President James K. Polk    schedule 10.10.2015
comment
@JamesKPolk Это про IE11, а другое про Edge. Возможно, их можно было бы объединить в один вопрос, но есть ограничение в 5 тегов и другие проблемы. Итак, я понимаю, что ОП экспериментирует с публикацией отдельных вопросов для каждого браузера.   -  person sideshowbarker    schedule 10.10.2015
comment
@JamesKPolk API для IE11 отличается от Edge. Так что код другой.   -  person FengHuang    schedule 10.10.2015


Ответы (1)


Я выяснил причину этого. Мне нужно добавить хеш-поле при вызове шифрования:

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

Это не соответствует спецификации API веб-криптографии, но работает.

person FengHuang    schedule 16.10.2015
comment
Если поведение IE здесь не соответствует спецификации, рассмотрите возможность регистрации ошибки в IE и публикации ссылки на эту ошибку здесь, если это возможно. - person sideshowbarker; 17.10.2015