6

Web Cryptography API を使用して公開鍵暗号化を実装するための次の JavaScript コードがあります。Firefox と Chrome では機能しますが、Microsoft Edge では失敗します。Edge から表示されるエラーは、「エラー 80700011 のため操作を完了できませんでした」です。私は何を逃したのですか?

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

    cryptoSubtle.generateKey(
        {
            name: "RSA-OAEP",
            modulusLength: 2048, 
            publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
            hash: { name: "SHA-256" }, 
        },
        true, 
        ["encrypt", "decrypt"]
    ).then(function (key) { 
        console.log(key);
        console.log(key.publicKey);
        return cryptoSubtle.encrypt(
            {
                name: "RSA-OAEP"
            },
            key.publicKey,
            data
            );
    }).then(function (encrypted) { 
        console.log(new Uint8Array(encrypted));
    }).catch(function (err) {
        console.error(err);
    });
</script>
4

2 に答える 2

10

この問題の原因がわかりました。暗号化関数を呼び出すときに、ハッシュ フィールドを追加する必要があります。

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

これはWeb 暗号化 API 仕様と一致しませんが、機能します。

于 2015-10-16T17:20:21.833 に答える
2

と同じ問題crypto.subtle.sign。ハッシュアルゴリズムを追加する必要がありました (Safari で同じ問題)

交換

crypto.subtle.sign(
            {
                 name: "RSASSA-PKCS1-v1_5"
            },
            cryptoKey,
            digestToSignBuf);

crypto.subtle.sign(
            {
                 name: "RSASSA-PKCS1-v1_5", 
                 hash: "SHA-256"
            },
            cryptoKey,
            digestToSignBuf);
于 2016-10-14T10:09:47.423 に答える