想用 php 开发一个在线记事本,记录一些非常私密的东西,首要要求是服务器被入侵后黑客也无法读取到我的文章内容.
所以想要找一个支持加密功能的单文件数据库,例如 sqlite3,但是免费版本的 sqlite3 不支持加密功能.
请问有没有类似 sqlite3 的其他的免费的支持加密功能的数据库呢?
性能不重要,自己一个人用的.
1
honeycomb Feb 4, 2017 via Android
keepass 数据库格式?
|
2
SingeeKing PRO 非对称加密就可以了吧
|
3
yexiaoxing Feb 4, 2017
换个思路,在 php 做加解密?
|
4
SuperMild Feb 4, 2017 php 加密后入数据库,缺点是不能搜索,但由于是一个人用数据量很小,可以每次把整个数据库读出来解密后放进一个临时数据库,这样就能搜索了,用完删除临时数据库。
|
5
springz Feb 4, 2017 DES 加密后密文存进数据库呗,你自己掌握 key
|
6
ryd994 Feb 4, 2017 via Android
换个思路, luks
自己要用再挂载 |
7
cnwtex Feb 4, 2017 via iPhone
只要 PHP 能读写,入侵的人就能读写,这种场景谈什么加密
|
8
wwqgtxx Feb 4, 2017
最简单的办法,在网页端用 JS 加密,密码自己掌握即可,就算破了你的服务器也拿不到有用的数据
|
9
zjgsamuel Feb 4, 2017
额~~ 最近也在构思自己的一个日记应用 有类似场景的需求 LZ 找到好的解决方案 记得分享一下哈~
|
10
missdeer Feb 4, 2017
基于 sqlite3 的 sqlcipher 有免费版本的
|
12
gdtv OP @yexiaoxing 在 php 做加解密,这样在数据库里就无法全文搜索了,就无法搜索文章了
|
19
grayon Feb 4, 2017
全文搜索你怎么做?分词做索引啊
|
20
springz Feb 4, 2017
BerkeleyDB
|
22
grayon Feb 4, 2017
用移位加密或者替换加密就好了
|
24
gdtv OP @SuperMild 我看了我的谷歌文档,几年来一共有 100M 的 word 文档,如果换成 txt ,估计至少要 20M 吧, 20M 的东西塞在 js 里可以吗? 另外放 js 里似乎更不安全吧,有时在别人的电脑上网, js 会留在别人的电脑缓存里。
|
26
SuperMild Feb 4, 2017
@gdtv 20M 小意思,现在宽带下载也很快,但是用手机流量访问时太费流量。缓存的问题应该可以通过设过期时限来解决吧(未确认),不过如果能在服务端用原生支持加密的数据库当然是最好的。
|
27
guxin0123 Feb 4, 2017
ms access ???
|
28
lslqtz Feb 4, 2017 via iPhone
Windows BitLocker
要用的时候 exec 解密,否则加密 根据传入的密码来,但是也不是绝对安全的,因为可以修改文件抓密钥 |
30
lslqtz Feb 4, 2017 via iPhone
建议用 HTML+AES+Chrome 扩展(读取 /写入本地文件)或 localStorage (注意备份)做成单机版的
|
31
phithon Feb 4, 2017 免费版本的 sqlite3 其实是预留了加密、解密接口的。
给你一个我大二时候写的密码管理器,代码乱七八糟的别吐槽,但其中有 sqlite3 的加密实现,这个软件的登录密码其实就是 aes 的密钥。 https://github.com/phith0n/PasswordKeeper 这个库就是一个 dll ,理论上用什么语言操作都不影响,但我没试过用 PHP 行不行。 |
32
Khlieb Feb 4, 2017 via Android
HSQLDB?
|
33
limhiaoing Feb 4, 2017
|
34
gdtv OP @limhiaoing 这个是收费的
|
35
jimzhong Feb 5, 2017
请问 LZ 的密钥如何存储呢?是由用户在每次加密 /解密时提供还是存在服务器上?
|
39
nilai Feb 5, 2017
SQLCipher +1
|
40
xieranmaya Feb 5, 2017
@lslqtz 这个思路很不错啊,我第一反应也是这么做。每次修改数据后把加密后的数据全量备份到 vps 上去,甚至扔 github 上都行
|