最近写electron单机版遇到对文件加密的业务,踩了一些坑,记录一下。
- node
fs.readFileSync
读取大文件会存在数据读不全的问题,最好使用fs.readFile
异步读取方法,或者使用流的读取方式fs.createReadStream
。
fs.readFileSync读取丢失数据可以看这 - 关于文件内容加解密,可以理解为对二进制数据进行加解密。
比如一个字符串 ‘ABCDEFGH’,转成二进制数据也就是 65 66 67 68 69 70 71 72。65也就是大写A对应的ascii值(小写a是65+32=97),如果字符串中含有中文,根据选择的编码格式,长度会有所不同,例如utf-8
,一个汉字就是三个字节,字符串’ABC张三’ 会有3+2*3=9个字节。加密就是通过某种算法,把这个二进制数据改成另一个二进制数据。
Demo:我用了AES-128-cbc
算法。加密后得到下图 第三行 53 84开头的数据,解密则是将该数据再转为原来的65 - 66 ... - 72
。至于8字节为什么转16字节,则是和算法有关。
- 关于加密,可以参考这位大佬的文章,讲的很详细。数据加密 ---- 总篇