Yet*_*tti 5 javascript encryption encoding typed-arrays sjcl
我在使用 SJCL 和 javascript 加密文件时遇到问题。
我设法使用 FileReader API 和 readAsBinaryString 加密文本文件。当涉及到加密 pdf/png/.. 时,可能由于编码而出现问题。
我发现我可以使用完美适合这项任务的 readAsArrayBuffer,所以我基本上读取文件并创建新的类型化数组,new Uint8Array()但我不知道我应该如何加密这样的数据。
这是我的代码:
/** Convert from an array of bytes to a bitArray. */
function toBitArrayCodec(bytes) {
var out = [], i, tmp=0;
for (i=0; i<bytes.length; i++) {
tmp = tmp << 8 | bytes[i];
if ((i&3) === 3) {
out.push(tmp);
tmp = 0;
}
}
if (i&3) {
out.push(sjcl.bitArray.partial(8*(i&3), tmp));
}
return out;
}
/** Convert from a bitArray to an array of bytes. */
function fromBitArrayCodec(arr) {
var out = [], bl = sjcl.bitArray.bitLength(arr), i, tmp;
for (i=0; i<bl/8; i++) {
if ((i&3) === 0) {
tmp = arr[i/4];
}
out.push(tmp >>> 24);
tmp <<= 8;
}
return out;
}
var reader = new FileReader();
reader.readAsArrayBuffer(fileData); //filedata comes from function
reader.onload = function() {
var bytes = new Uint8Array(reader.result);
var bits = toBitArrayCodec(bytes);
var crypt = sjcl.encrypt("aaaaa", bits);
var decrypt = sjcl.decrypt("aaaaa", crypt);
var byteNumbers = fromBitArrayCodec(decrypt);
var byteArray = new Uint8Array(byteNumbers);
saveData(byteArray, 'png.png');
Run Code Online (Sandbox Code Playgroud)
我遇到错误
Uncaught URIError: URI malformed sjcl.js:12sjcl.codec.utf8String.fromBits sjcl.js:12sjcl.json.decrypt sjcl.js:44reader.onload
Run Code Online (Sandbox Code Playgroud)
我需要知道如何加密uint8array或其他替代方法来加密(pdf/png/..)文件。
sjcl 中的明文预计为 utf8 编码。加密手动构建的 bitArray 有效,因为加密是在 bitArray 上完成的,并且不必解码。但在解密的最后是一个编码步骤,它将恢复的明文 bitArray 转换为 utf8string。这不起作用,因为它包含不可打印的字符,因为源可能是二进制的。
解决方案是在加密之前将其编码为 Base64,并在解密后将其转换回来。
var bytes = new Uint8Array(reader.result);
var bits = toBitArrayCodec(bytes);
var base64bits = sjcl.codec.base64.fromBits(bits); // added
var crypt = sjcl.encrypt("aaaaa", base64bits);
var base64decrypt = sjcl.decrypt("aaaaa", crypt);
var decrypt = sjcl.codec.base64.toBits(base64decrypt); // added
var byteNumbers = fromBitArrayCodec(decrypt);
var byteArray = new Uint8Array(byteNumbers);
Run Code Online (Sandbox Code Playgroud)