这个程序我试了一下,效果很好,但要记住是给文本或二进制文件加密的,如果给别的格式的文件加密,将无法解密到原来的文件。
翻译作者说明如下:
介绍
我在网上想找一个简单而且安全的文件加密的源代码,但是没有找到,所以自己写了一个。
File Encryption utility是一个简单的给文本或二进制文件加密的工具,使用blowfish压缩算法。
这个工具可以创建一个self extracted加密文件,如果你想深入了解怎样创建一个self extracted文件,请看我的另一篇文章Creating Self-Extracted Executable。
功能
1.快速的文件加密/解密功能
2.内部文件过滤功能
3.创建一个Self-Extracted加密文件
4.通过配置对话框综合控制
语言
File Encryption utility使用了C++/ATL窗口类,使用的ATL很少,因此对此库不熟悉的朋友也可以看懂代码。
概要
File Encryption Utility分为下面几个小的工程:
• FileEnc – The UI of the file encryption utility, also holding Processing class which is also used by SelfExtract and it’s responsible for reading/writing files.
• Enc_Blowfish – Blowfish encryption implementation (based upon Bruce Schneier & Jim Conger implementation).
• SelfExtract – Self Extracted executable “header”.
• GenLib – Small Library holding all commonly used in other project parts.
• Builder – Small Console utility for creating the final File Encryption Executable.
GenLib
为了使提供的各类有一个中心的切入点,我做了一个静态类GenLib
File Encryption Utility提供GenLib的Stripped版本。在这个版本里你可以看到下面这些有用的类:
•GenFiles – Openning OpenFile/SaveFile & OpenDirectory Dialog Boxes.
• SelfExtract – Creating Self-Extracted Executable.
• Thread – Implementation of a parent class for classes who want to execute code in separated thread (more information can be seen in the header – thread.h).
• FileWipe – Wiping a File from Hard Drive.
加密技术
在FileEnc工程中有一个接口叫做EncryptionInterface-使用这个接口可以简单的改变加密的应用。
Blowfish的实现是静态连接到应用中去的,这样是为了避免被改变的dll黑掉。
安全
为了使加密足够的安全,我做了在程序退出时擦除信息的功能。
当你看代码的时候,你会看到我使用了ZeroMemory API函数从内存中删除信息。
当加密一个文件时,你可以选择Wipe Source After Process复选框,功能是在加密时此文件不能被访问。
备注
解密时不验证密码,用一个错误的密码解密会得到一个错误的文件,这不是程序的一个bug,有许多解密程序都是这样的。
文件的加密决定于密码的长度,密码越长越安全。
尽管我自己认为文件擦除的方法是很安全的,但是我不能100%的确定这点。
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/