CTF之密码学(栅栏加密)

栅栏密码是古典密码的一种,其原理是将一组要加密的明文划分为n个一组(n通常根据加密需求确定,且一般不会太大,以保证密码的复杂性和安全性),然后取每个组的第一个字符(有时也涉及取其他位置的字符,但规则需事先约定),根据情况将这些字符重新排列组合成一段无规律的话,形成密文。

栅栏密码的"栏"数,即分组后形成的"列"数或"行"数(具体取决于加密时的排列方式),是栅栏密码的一个重要参数。根据栏数的不同,栅栏密码可以分为多种类型,其中比较常见的是2栏栅栏密码。但理论上,栏数n可以是任何正整数(实际应用中受限于明文的长度和加密的安全性要求)。

加密过程示例

以明文"welcome to ctf"为例,假设采用3栏栅栏密码进行加密:

  1. 去掉空格,得到"welcometoctf"。
  2. 将明文划分为三组(尽量平均):"w e l c"、"o m e t"和"o c t f"。
  3. 按竖列取出字母,得到"woo"、"emc"、"let"和"ctf"。
  4. 将这些字母连在一起,形成密文"woo emc let ctf"。

解密过程示例

对于上述密文"woo emc let ctf",假设已知是采用3栏栅栏密码进行加密的,解密过程如下:

  1. 将密文划分为三组(根据加密时的栏数和密文长度确定):"w o o"、"e m c"和"l e t c t f"。
  2. 按竖列顺序取字母,重新组合成明文:"welcome to ctf"(注意恢复空格)。

注意事项

  1. 栅栏密码的安全性主要依赖于栏数的选择和明文的长度。栏数越多,密文的规律性越弱,但同时明文的长度也会限制栏数的选择。
  2. 在实际应用中,为了增加密码的复杂性,可以采用变栏数(即不同部分使用不同的栏数进行加密)或与其他加密方法(如替换密码、移位密码等)相结合的方式进行加密。

综上所述,栅栏密码的栏数是一个灵活的参数,可以根据加密需求和安全要求进行选择。

下面是python加密程序

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}')
相关推荐
安全方案1 小时前
2024信息安全网络安全等安全意识(附培训PPT下载)
网络·安全·web安全
黑客老陈3 小时前
BaseCTF scxml 详解
开发语言·网络·python·sql·安全·web安全
LLLuckyGirl~3 小时前
计算机网络之---ICMP协议与Ping命令
服务器·网络·计算机网络
LLLuckyGirl~3 小时前
计算机网络之---网络拓扑
网络·计算机网络
蚁景网络安全3 小时前
WebSocket 测试入门篇
网络·websocket·网络协议
bachelores3 小时前
计算机网络_数据链路层
网络·网络协议·计算机网络
路星辞*4 小时前
基于访问表的安全防范策略
运维·网络·安全·智能路由器·acl
kaixin_啊啊5 小时前
静态路由配置与调试——计算机网络实训day1
网络·计算机网络
玖石书6 小时前
[IoT]物联网(IoT)网络的安全性
网络·物联网·智能路由器
DataDynamos数动实验室6 小时前
【计算机网络】IPSec的安全协议和封装模式
网络·计算机网络·网络安全