blog/_posts/2022-10-08-tinyaes.md

39 lines
4.1 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

---
layout: post
title: 用Python写一个超简单的加密程序
tags: [Python, 加密]
---
有些冷门的库也许更容易解决问题<!--more-->
# 起因
最近在写Python脚本的时候遇到一个问题就是怎么样轻松的加密一串字符。在网上随便一搜大都是介绍的使用比如pycryptodome或者cryptography库进行加密我以前写的一个[加密传输Demo](/2020/06/13/encrypt.html)作业的时候就用过。不过现在总感觉看着很难受倒不是说有多复杂主要是这些库的算法太多了什么AESRSA啥的都有而且还有一堆乱七八糟的参数我用的时候还要去思考到底用哪个算法比较好还要考虑有些有什么向量之类乱七八糟的。但是很多时候我只是单纯要个加密不想去考虑这些乱七八糟的东西那我应该怎么做比较好呢
# 探索
这时候我想起来我以前用的Pyinstaller库如果想要使用Key参数的时候会要求安装一个叫做[tinyaes](https://pypi.org/project/tinyaes/)的库我搜了一下这个库网上几乎没有对这个库的介绍没办法就只好去Github找找它[源代码的仓库](https://github.com/naufraghi/tinyaes-py)。去看了一眼说了跟没说一样就几句话连个示例也没有的……不过大概意思就是C也有个叫[tiny-AES-c](https://github.com/kokke/tiny-AES-c)的库它是在Python上对这个库做的一个简单的包装但那个仓库里面也没有示例😂……还好tinyaes仓库里面有个测试脚本我看了一眼又回去看了看C的库那个文档结合“Same function for encrypting as for decrypting in CTR mode”这句话我才明白这个tinyaes原来就用一个方法就能进行加解密了怪不得叫“xcrypt”就像xor加密那样用同样的方法就可以做到加密和解密这个仓库加密的算法是AES-128-CTR这样我也不用费心考虑到底选什么加密算法了使用也非常简单非常的符合我的需求啊可惜就是这个库不怎么出名100个⭐都不到。
# 使用方法
tinyaes的使用方法非常简单一句话就可以搞定而且加密和解密的代码完全一致
```python
__import__("tinyaes").AES(b"十六位的密码", b"十六位的向量,可以不要").CTR_xcrypt_buffer(b"需要加密/解密的内容")
```
使用起来非常的简单啊就是密码要求必须是16位的……那我要是想要一个随意位数的密码怎么办呢我想起来MD5的hash长度好像就是16位的所以如果想要其他位数的密码就用MD5哈希之后再用吧。
# 示例
既然使用方法如此简单我估摸了一下如果写一个加密文件的小程序估计用不了10行用其他的加密库我估计应该做不到吧所以说就随手写了一个试试看果然不到10行就写了出来看起来非常不错。
```python
import hashlib, tinyaes, sys
if not len(sys.argv) == 3:
exit(f"Usage: {sys.argv[0]} [filepath] [key]")
key = tinyaes.AES(hashlib.md5(sys.argv[2].encode()).digest())
with open(sys.argv[1], 'rb') as orig:
with open(sys.argv[1] + ".xc", 'wb') as enc:
for byte_block in iter(lambda: orig.read(4096), b''):
enc.write(key.CTR_xcrypt_buffer(byte_block))
```
用法很简单比如我给这个脚本起名叫“encrypt_file.py”我想加密就可以直接输入`python3 encrypt_file.py 要加密的文件.txt 密码`就可以了,执行完之后会生成一个“.xc”为后缀的文件解密也一样输入`python3 encrypt_file.py 要加密的文件.txt.xc 密码`就OK了不过因为我这个程序并不能判断一个文件有没有加密所以解密的时候就会给后缀再加一个“.xc”这时候就只能手动把它去掉了。如果密码不正确那就相当于二次加密了解密就要按顺序依次反过来执行很有意思。
# 感想
这样的库我感觉更符合Pythonic用什么pycryptodome或者cryptography库写的就感觉像是Java程序那样臃肿这种程序感觉就很直观不用考虑那么多奇怪的东西。