CTF之密码学(栅栏加密)
栅栏密码是古典密码的一种,其原理是将一组要加密的明文划分为n个一组(n通常根据加密需求确定,且一般不会太大,以保证密码的复杂性和安全性),然后取每个组的第一个字符(有时也涉及取其他位置的字符,但规则需事先约定),根据情况将这些字符重新排列组合成一段无规律的话,形成密文。
栅栏密码的“栏”数,即分组后形成的“列”数或“行”数(具体取决于加密时的排列方式),是栅栏密码的一个重要参数。根据栏数的不同,栅栏密码可以分为多种类型,其中比较常见的是2栏栅栏密码。但理论上,栏数n可以是任何正整数(实际应用中受限于明文的长度和加密的安全性要求)。
加密过程示例
以明文“welcome to ctf”为例,假设采用3栏栅栏密码进行加密:
- 去掉空格,得到“welcometoctf”。
- 将明文划分为三组(尽量平均):“w e l c”、“o m e t”和“o c t f”。
- 按竖列取出字母,得到“woo”、“emc”、“let”和“ctf”。
- 将这些字母连在一起,形成密文“woo emc let ctf”。
解密过程示例
对于上述密文“woo emc let ctf”,假设已知是采用3栏栅栏密码进行加密的,解密过程如下:
- 将密文划分为三组(根据加密时的栏数和密文长度确定):“w o o”、“e m c”和“l e t c t f”。
- 按竖列顺序取字母,重新组合成明文:“welcome to ctf”(注意恢复空格)。
注意事项
- 栅栏密码的安全性主要依赖于栏数的选择和明文的长度。栏数越多,密文的规律性越弱,但同时明文的长度也会限制栏数的选择。
- 在实际应用中,为了增加密码的复杂性,可以采用变栏数(即不同部分使用不同的栏数进行加密)或与其他加密方法(如替换密码、移位密码等)相结合的方式进行加密。
综上所述,栅栏密码的栏数是一个灵活的参数,可以根据加密需求和安全要求进行选择。
下面是python加密程序
# 栅栏加密
def zhalan(txt,key):
s = ''
# 从0开始遍历到key - 1
for m in range(key):
#遍历m后面每个与前面的距离为key的字符
for n in range(m,len(txt),key):
s += txt[n]
return s
if __name__ == '__main__':
txt = input("请输入明文").strip()
key = []
# 计算是文本长度的约数的数字
for i in range(2,len(txt)):
if len(txt) % i == 0:
key.append(i)
# 遍历每个数字,计算出他们对应的栏数的文本
for j in key:
flag = zhalan(txt,j)
print(f'{j}栏,{flag}')