SubtleCrypto.deriveKey()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
O método SubtleCrypto.deriveKey()
retorna como Promise
de um recentemente gerado CryptoKey
derivada de uma master key e um algoritmo específico dados como parâmetro.
Sintaxe
var result = crypto.subtle.deriveKey(algorithm, masterKey, derivedKeyAlgorithm, extractable, keyUsages);
Parâmetros
algorithm
é um objeto definindo o algoritmo de derivação a se usar. Os valores suportados são:{"name": "ECDH", "public": publicKey}
{"name": "DH", "public": publicKey}
{"name": "PBKDF2", salt, iterations, hash}
wheresalt
is anArrayBuffer
ou umArrayBufferView
,iterations
é o número de interações ehash
é umDOMString
identificando o algoritmo hashing para uso.{"name": "HKDF-CTR", hash, label, context}
masterKey
é umaCryptoKey
representando a master key para ser utilizada por um algoritmo de derivação de key.derivedKeyAlgorithm
é um objeto que define o algoritmo, a key derivada será utilizada paraDOMString
como um atalho para{"name": derivedKeyAlgo}
. Para AES uma propriedadelength
também é requerida, e os valores possíveis são 128, 192 ou 256 bits.extractable
é umBoolean
indicando se a key pode ser extraída de um objetoCryptoKey
em um estágio mais tardio.keyUsages
é umArray
indicando o que pode ser feito com a chave derivada. Os valores possíveis do array são:"encrypt"
, permitindo que a key seja utilizada para encrypting mensagens."decrypt"
, permitindo que a key seja utilizada para decrypting mensagens."sign"
, permitindo que a key seja utilizada para signing mensagens."verify"
, permitindo que a key seja utilizada para verifying the signature de mensagens."deriveKey"
, permitindo que a key seja utilizada como key base na derivação de uma nova key."deriveBits"
, permitindo que a key seja utilizada como key base na derivação de bits de informação para uso em criptografias primitivas."wrapKey"
, permitindo que a key envolva uma key simétrica (transferência, armazenamento) em ambientes não seguros."unwrapKey"
, permitindo que a key se desvincule de uma key simétrica para uso (transfererência, armazenamento) em ambientes não seguros.
Valor de retorno
result
é umaPromise
que retorna a key derivada como umaCryptoKey
ou umaCryptoKeyPair
.
Exceções
A promise é rejeitada quando uma das seguintes exceções é encontrada:
InvalidAccessError
quando a master key não é uma key para o algoritmo de derivação requisitado ou se o valor desta chave,CryptoKey.usages
, não contém"deriveKey"
.NotSupported
quando tentando usar um algoritmo que não é nem desconhecido e nem se encaixa para a derivação, ou se, o algoritmo requisitado da key derivada não define o comprimento da key.SyntaxError
quandokeyUsages
está vazio mas a key desvinculada é do tipo"secret"
ou"private"
.
Exemplo
Aqui está um exemplo de como usar deriveKey() para criar uma Secure Remote Password (também nomeado de Proof of Secret) da password de um usuário.
// salt deve ser Uint8Array ou ArrayBuffer
var saltBuffer = Unibabel.hexToBuffer("e85c53e7f119d41fd7895cdc9d7bb9dd");
// não use métodos naïve para conversão de texto, senão caracteres
// internacionais não terão a sequência correta de byte. Use o TextEncoder quando
// possível ou então use polyfills relevantes
var passphraseKey = Unibabel.utf8ToBuffer("I hëart årt and £$¢!");
// Você deve primeiramente importar sua passphrase Uint8array em uma CryptoKey
window.crypto.subtle
.importKey("raw", passphraseKey, { name: "PBKDF2" }, false, [
"deriveBits",
"deriveKey",
])
.then(function (key) {
return window.crypto.subtle.deriveKey(
{
name: "PBKDF2",
salt: saltBuffer,
// não seja muito ambicioso, ou pelo menos tenha em mente
// que celulares com baixo poder de processamento vão acessar o seu app
iterations: 100,
hash: "SHA-256",
},
key,
// Nota: para essa demo nós não vamos precisar de uma cipher suite,
// mas a API exige que a mesma seja especificada.
// Para AES o comprimento requerido é de 128 ou 256 bits (não bytes)
{ name: "AES-CBC", length: 256 },
// Independente da resposta a key é extraível (menos seguro) ou não extraível (mais seguro),
// quando falso, a key pode ser entregue apenas como um objeto crypto web, não inspecionado
true,
// esse objeto crypto web será permitido para apenas essas funções:
["encrypt", "decrypt"],
);
})
.then(function (webKey) {
return crypto.subtle.exportKey("raw", webKey);
})
.then(function (buffer) {
var proofOfSecret = Unibabel.bufferToHex(buffer);
// esta proof-of-secret / password remota-segura
// pode agora ser enviada no lugar da password do usuário
});
Nota: Por conta de não haver ferramentas nativas que convertam entre Uint8Array, Unicode, hex, e base64, você provavelmente vai querer utilizar algo como o Unibabel ou Buffer para converter entre eles.
Especificações
Specification |
---|
Web Cryptography API # SubtleCrypto-method-deriveKey |
Compatibilidade com navegadores
BCD tables only load in the browser
Veja também
Crypto
eCrypto.subtle
.SubtleCrypto
, a interface a qual ele pertence.
Dicionário
"Key" = "Chave"
"Master key" = "Chave mestre"
"Proof-of-secret" = "Prova de segredo ou Atestado de sigilo"
"Password" = "Palavra passe ou Senha"