python 简单加密算法小计

这里主要记录 ROT13 算法 和 hash 算法

一、ROT13算法

套用ROT13到一段文字上仅仅只需要检查字元字母顺序并取代它在13位之后的对应字母,有需要超过时则重新绕回26英文字母开头即可[2]。A换成N、B换成O、依此类推到M换成Z,然后序列反转:N换成A、O换成B、最后Z换成M。只有这些出现在英文字母里头的字元受影响;数字符号、空白字元以及所有其他字元都不变。因为只有在英文字母表里头只有26个,并且26=2×13,ROT13函数是它自己的逆反:
        对任何字元x:ROT13(ROT13(x))=ROT26(x)=x
换句话说,两个连续的ROT13应用函式会回复原始文字(在数学上,这有时称之为对合(involution);在密码学上,这叫做对等加密(reciprocalcipher))。(取自互动百科http://www.baike.com/wiki/ROT13&prd=so_1_doc

1 def rot13(strs, offset=13):
2     rot = {chr(i+c): chr((i+offset) % 26 + c for i in range(26) for c in (65, 97))}
3     return ''.join([rot.get(c, c) for c in s])

二、hash算法

Hash,一般翻译做散列、杂凑,或音译为哈希,是把任意长度的输入(又叫做预映射pre-image)通过散列算法变换成固定长度的输出,该输出就是散列值。这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能会散列成相同的输出,所以不可能从散列值来确定唯一的输入值。简单的说就是一种将任意长度的消息压缩到某一固定长度的消息摘要的函数。(取自百度百科https://baike.baidu.com/item/Hash/390310)

hash 是不可逆的。

1 def md5(strs):
2     m = hashlib.md5()
3     m.update(strs.encode('utf8'))
4     return m.hexdigest()

参考:

https://www.cnblogs.com/c-hy/archive/2012/08/04/2623453.html

猜你喜欢

转载自www.cnblogs.com/ToFgetU/p/10626326.html