有没有这样一种加密方法?

2015-12-01 13:25:10 +08:00
 stupidcat
解密时,无论输入什么密码,解密软件本身并不提示“密码正确”或“密码错误”,而是都会产生一个文件。当且仅当输入了正确的密码时,才会产生正确的原文件
当然,也需要满足一些加密算法的基本要求,例如
1. 加密算法本身完全公开
2. 错误密码与错误文件的对应关系对于寻找正确密码没有帮助


如果真的有这样一种加密方法,那破解难度就大大提高了。暴力破解的速度是很快,可是人眼一天能看几个文件?

目前存在这样的加密算法吗?
2761 次点击
所在节点    奇思妙想
17 条回复
ShadowStar
2015-12-01 13:32:27 +08:00
几乎常用的绝大部分加密算法都是这样的,你所说的只是加解密软件的问题。
stupidcat
2015-12-01 13:37:48 +08:00
@ShadowStar 解密软件之所以会提示“错误”,是因为算法本身提供了相关信息(校验之类),那么,有没有不提供这种信息的算法?
PublicID
2015-12-01 13:38:57 +08:00
判断解密是否正确不是加密算法的事
PublicID
2015-12-01 13:40:53 +08:00
@stupidcat 算法不提供信息。这么做通常是在加密时附加校验信息,然后解密时验证加密算法的输出。
stupidcat
2015-12-01 13:43:35 +08:00
@PublicID 以 rar 加密为例,为什么 winrar 会提示密码错误?因为校验和对不上。这个校验和不就是该加密算法规定了要保存在密文中的内容吗。
是否存在某一种加密算法,不在密文中储存“校验和”、或是任何其他可以让解密软件判断出密码正确或错误的信息?
RemRain
2015-12-01 13:50:21 +08:00
rar 是压缩算法, winrar 是软件,校验是软件做的,不是加密算法。 winrar 用的加密算法是 blowfish , blowfish 不含密码验证。
est
2015-12-01 13:51:24 +08:00
我早就说了, ssh 登陆提示信息无论成功与否一律改成 Permission denied, please try again. 。保证有奇效。
ShadowStar
2015-12-01 13:51:51 +08:00
RAR 不是加密
zjqzxc
2015-12-01 13:52:06 +08:00
事实上,就算是有这么一款加密软件(楼上意见解释了这个不是算法的事儿),暴力破解的难度并不会增加。。

如果密码正确,那么产生的信息一定是有意义的。如果压缩的是文件,那解密后的内容也一定要是文件才行。图片什么的都有头文件,查一下就知道是不是,是什么类型的文件了。纯文本内容直接尝试使用 utf8,gbk 等方式解码,能解出来就是正确的,解不出来就可以认为不对。

所以,就算是有这种软件,对暴力破解来说就是多了一个步骤而已(并增加了大量的 IO 次数?)
wy315700
2015-12-01 13:52:41 +08:00
@stupidcat 算法本身不提供解密失败的信息,算法本身只是按照你输入的密文和密钥进行解密,
msg7086
2015-12-01 17:01:33 +08:00
@stupidcat 5 楼
回答你第一段的问题:不是。
comicfans44
2015-12-04 16:40:29 +08:00
首先加密算法只是变换,不会关心你的密钥是否正确。 rar 用错误密码解密并且选中保留损坏的文件,得到的就是你想要的无确认密码的加解密(得到一堆无用的二进制)。

根据 rar 的描述

http://www.rarlab.com/technote.htm#enchead

If flag 0x0002 is present, RAR transforms the checksum preserving file or service data integrity, so it becomes dependent on encryption key. It makes guessing file contents based on checksum impossible. It affects both data CRC32 in file header and checksums in file hash record in extra area.

checksum 是密码相关联的,因此对于寻找正确的密码没有帮助。
另外 @zjqzxc 的说法是正确的,人眼看不过来,但是有专门的库(比如 libmagic)用于识别文件类型,因此即使没有这个额外的确认信息,也不会减少被破解的可能。



你所描述的,其实是"裸"加密,去掉加密之外的一切信息,只剩下变换后的二进制。你自己随便编一个可逆变换就可以了。别人打死也猜不出来一个你乱编的算法是怎么变换的,当然也就没法解密了。
akagi
2015-12-05 23:26:04 +08:00
@comicfans44 然而也许可以用频率统计来减小解空间?
comicfans44
2015-12-07 09:36:15 +08:00
@akagi 不太了解你说的频率统计的方面的内容。具体的操作是?
akagi
2015-12-08 17:33:22 +08:00
@comicfans44 呃,只是个粗浅的想法。解密后的文件如果是规范的原始文件,即使是纯二进制流,也应该会有特定的频率统计特性。或许可以靠分析文件排除分布明显不合适的情况。

比如,首先统计字串的出现次数,然后统计某字串后接另一字串的出现次数…… 然后统计百分比什么的。

好像过于简陋了 ..
comicfans44
2015-12-08 21:29:17 +08:00
@akagi 感觉这个还是比较困难的
Silicon
2015-12-09 04:43:45 +08:00
@comicfans44 并不困难
但熵值分析本身也需要配合一些特定场景。如果目标文件本身很有规律( PE 、文本、波形或者位图),那熵值分析基本十拿九稳。
但要是碰上其他文件就难说了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/240255

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX