参考了tarequeh的DES,采用相同的命令行使用方式。
命令行选项参数解析在windows x64环境下使用alex85k的wingetopt。
关于getopt()的使用参考getopt-优雅地处理命令行参数。
感谢~😀
Refer to the 的DES of tarequeh, the program is also used through the command line like tarequeh.
The command line option parameter resolution uses the wingetopt of alex85k in the Windows x64 environment.
The reference for using getopt(): getopt-gracefully handles command line arguments.
Thanks~ 😀
代码为密码学教材("Cryptography Theory and Practice Third Edition")中Data Encryption Standard(DES)的C语言实现。程序通过命令行使用。
需要注意的是教材中的DES与实际投入使用的DES不太一样,在某些文献中,作为算法的DES被称为DEA(Data Encryption Algorithm,数据加密算法),以与作为标准的DES区分开来。所以严格来说,本项目是对DEA的实现。详情参照DES_维基百科。
针对工作模式的描述参考分组密码工作模式_维基百科。
在项目的test文件夹中有一个名为Whole_Process_Of_Single_DES(点击下载)的excel表格文件,我使用excel函数实现了针对一个分组的DES流程,方便学习时理解以及测试程序输出数据的正确性。
在EXCEL文件的最上方按照每字节以2位16进制的格式输入8B(64bit)的明文和密钥,文件便会计算出对应的密文输出在下方。文件下方可以查看对一个8B分组明文的DES加密过程的每一步的输出。
EXCEL_使用
EXCEL_实例
经过测试在合法的参数输入下程序能正常运行。对一些可能的非法输入有进行了校验,但可能有些没有考虑周到的错误输入不能正确处理,如果发现了错误以及不规范之处希望能帮忙指出,非常感谢~
The code is the C implementation of Data Encryption Standard(DES) in the Cryptography Theory and Practice Third Edition. The program is used through the command line.
It should be noted that the DES in the textbook is different from the DES actually put into use. In some literatures, the DES as an algorithm is called DEA(Data Encryption Algorithm) to distinguish it from the DES as a standard. So strictly speaking, this project is the realization of DEA. Refer to DES(Wikipedia) for details.
For the description of the operation mode, refer to the block Block cipher mode of operation(Wikipedia).
In the test folder of the project, there is a file named Whole_Process_Of_Single_DES(Click Download), which is a Excel table file. I used excel functions to implement the DES process for one DES data block, which is convenient for understanding during learning and testing the correctness of the program's output data.
Input 8B (64bit) plaintext and key at the top of the EXCEL file in 2-bit hexadecimal format per byte, and the file will calculate the corresponding ciphertext output followed. In the subsequent part of the file, you can view the output of each step of the DES encryption process for an 8B group plaintext.
EXCEL_use
EXCEL_usage
After testing, the program can run normally with legal parameter input. Some possible illegal inputs have been verified, but maybe some inadvertent incorrect inputs cannot be handled correctly. If errors and irregularities are found, I hope you can point them out. Thank you very much~
- -h
查看命令指南
./DES.exe -h
- -g key_file_name
生成随机的密钥文件。
./DES.exe -g keyfile.key
- -e key_file_name plaintext_file_name encrypted_ciphertext_file_name (byte_padding_way) (mode_name) (initialization_vector_file_name)
进行加密。参数需要按照给定顺序指定才能正确解析。括号内为可省略项。
./DES.exe -e keyfile.key input.txt output.txt p cbc iv.txt
- -d key_file_name ciphertext_file_name decrypted_plaintext_file_name (byte_padding_way) (mode_name) (initialization_vector_file_name)
进行解密。
./DES.exe -d keyfile.key input.txt output.txt I CFB iv.txt
- -c file_name
在命令行打印指定文件的十六进制和二进制格式。
./DES.exe -c output.txt
- 未输入参数。
No parameters entered.
- 查看命令指南。
View the command guide.
- 参数缺失。
Required parameter missing.
- 生成密钥文件并输出其十六进制及二进制格式。
Generate the key file and output it in hexadecimal and binary formats.
- 在CTR模式,ISO10126填充方式下进行加密。输入为:密钥文件keyfile.key,明文文件input.txt,初始向量文件iv.txt;输出密文至文件output_ctr_iso.txt。
Encryption is performed in CTR mode and ISO10126 padding mode. Input: key file keyfile.key, plaintext file input.txt, initialization vector file iv.txt; Output ciphertext to file output_ctr_iso.txt.
- 对上一步生成的密文进行解密。输出明文至文件decrypted_input_ctr_iso.txt。
Decrypt the ciphertext generated in the previous step. Output plaintext to file decrypted_input_ctr_iso.txt.
- 对一些可能的非法输入的处理。
Handling of some possible illegal inputs.
代码还有许多需要优化的地方,并且目前仅在windows x64环境下可用,linux环境的兼容还在实现中。
后续会继续使用C语言实现其他的加解密方式。
The code still needs to be optimized, and it is only available in the Windows x64 environment at present. The compatibility of the Linux environment is still in the process of implementation. Later, I will continue to use C language to implement other encryption and decryption methods.