golang使用SQLite数据库对指定扩展名文件进行批量加密(一、原理篇)

序言:目前网上的文件加密软件,大多都是付费、注册类,于是打算自己用go语言手写一个,自用的文件加密小程序。

思路:图片、视频等文件都是二进制存储的数据,我们用文本编辑器打开删除部分信息后,就导致文件损坏无法打开。因此,我们可以用go语言二进制读取需要加密的文件,将文件前n个字节存储到SQLite中,将剩余的字节再存到文件中,并删除源文件,因文件部分数据缺失,就会导致无法打开。

为了进一步保证安全:

1、前n字节存储到SQLite数据库的时候进行下简单加密操作,比如全部按位取反后转为字符串保存。

2、剩余的字节也可以取反后转为字符串保存到文件中。

3、原文件名加密存储到数据库,取原文件名的哈希值作为加密后的文件名,同时文件名哈希值也保存到数据库中。别人只看到一串哈希字符的文件名,无法得到原文件名、原文件类型。

4、为了解密安全,我们可以在程序中设置一个固定的解密密码,也可以在数据库中以加密形式保存一个解密密码。别人在不知道解密密码的情况下,无法解密文件。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
gocryptfs 是一个使用 Go 开发的,加密的覆盖文件系统。gocryptfs 基于 go-fuse FUSE 库和其 LoopbackFileSystem API 构建。gocryptfs 灵感来源于 EncFS,修复了其安全问题,提供更好的性能。gocryptfs 当前只支持 Linux 系统,以后会继续支持 OS X。安装:$ go get github.com/rfjakob/gocryptfs使用:$ mkdir cipher plain $ $GOPATH/bin/gocryptfs --init cipher   [...] $ $GOPATH/bin/gocryptfs cipher plain   [...] $ echo test > plain/test.txt $ ls -l cipher   total 8   -rw-rw-r--. 1 user  user   33  7. Okt 23:23 0ao8Hyyf1A-A88sfNvkUxA==   -rw-rw-r--. 1 user  user  233  7. Okt 23:23 gocryptfs.conf $ fusermount -u plain性能:./benchmark.bash gocryptfs v0.3.1-30-gd69e0df-dirty; on-disk format 2 PASS BenchmarkStreamWrite-2       100      12246070 ns/op      85.63 MB/s BenchmarkStreamRead-2        200       9125990 ns/op     114.90 MB/s BenchmarkCreate0B-2        10000        101284 ns/op BenchmarkCreate1B-2        10000        178356 ns/op       0.01 MB/s BenchmarkCreate100B-2       5000        361014 ns/op       0.28 MB/s BenchmarkCreate4kB-2        5000        375035 ns/op      10.92 MB/s BenchmarkCreate10kB-2       3000        491071 ns/op      20.85 MB/s ok      github.com/rfjakob/gocryptfs/integration_tests  17.216s 标签:文件加密
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值