Skip to content

Instantly share code, notes, and snippets.

@marcus7777
Last active July 25, 2017 11:08
Show Gist options
  • Save marcus7777/c2753942505e99f82d916d93b4316b6f to your computer and use it in GitHub Desktop.
Save marcus7777/c2753942505e99f82d916d93b4316b6f to your computer and use it in GitHub Desktop.
Web Crypto API example
var string = new Uint8Array([0x01, 0x02])
var data = new Uint8Array([0x03, 0x04, 0x05])
var handle_error = function (error) {
cnosole.log("Error:",error)
}
window.crypto.subtle.digest({name: "SHA-256"}, string).then(function (hash) {
console.log("SHA-256:",new Uint8Array(hash))
window.crypto.subtle.importKey("raw", hash, {name: "AES-GCM"}, true, ["encrypt", "decrypt"]).then(function (key) {
var algorithm = key.algorithm
algorithm.iv = window.crypto.getRandomValues(new Uint8Array(16))
window.crypto.subtle.encrypt(algorithm, key, data).then(function (ct) {
console.log("AES-GCM encrypt:",new Uint8Array(ct))
window.crypto.subtle.decrypt(algorithm, key, ct).then(function (pt) {
console.log("AES-GCM decrypt:",new Uint8Array(pt))
}, handle_error)
}, handle_error)
}, handle_error)
}, handle_error)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment