栅栏密码

所谓栅栏密码,就是把明文分成N个组,然后取出每组的第一个,每组的第二个。。接着按顺序排列得出密文。若每个组里有2两个元素的话就叫2栏栅栏密码。

例一

就比如明文为The girl is beautiful,按照2栏栅栏密码的步骤就需要将这个字符串分成9个组(明文中的空格不计数),9个组分别如下:
Th eg ir li sb ea ut if ul
将每个组的第一个元素提出来,Teilseuiu
将每个组的第二个元素提出来,hgribatfl
最后按照顺序排列的密文:Teilseuiuhgribatfl

若要将密文还原为明文,只需将密文分成两半(已知是2栏栅栏密码)
第一个组为Teilseuiu
第二个组为hgribatfl
只需从第一个组读一个元素,第二个元素读一个元素,循环往复即可得到明文
读取如下:Th eg ir li sb ea ut if ul
所以明文为Thegirlisbeautiful

由于由明文变为密文的时候对空格采用了不计数的操作,所以得到的明文中也是没有空格的(一般来说空格是不计的,虽然博主觉得还是计了方便,要不然明文没有空格看起来很不方便)

下面来介绍个记空格的例子。

例二

例二是CTF的练习题
题目链接
http://ctf.idf.cn/index.php?g=game&m=article&a=index&id=52

题目
一只小羊跳过了栅栏,两只小样跳过了栅栏,一坨小羊跳过了栅栏…
tn c0afsiwal kes,hwit1r g,npt ttessfu}ua u hmqik e {m, n huiouosarwCniibecesnren.

思路:由于题中提到了栅栏,于是猜这段字符串使用了栅栏密码,去掉空格后一数发现字符串长度为71,因为71是一个素数,所以无法对其进行各很好的分组,所以猜测空格可能是计数的,再看字符串中有些字母中间空格不止一个,就更加肯定空格是计数的了,于是加上空格,字符串长度为85,而85的因子有5和17,于是乎我们就可以按5个一组或17个一组去试,分别如下:

5个一组:
tn c0
afsiw
al ke
s,hwi
t1r
g,npt
tte
ssfu}
ua u
hmqi
k e {
m, n
huio
uosar
wCnii
beces
nren.

对于这种分法很明显可以看出是不对的,因为这样组成的明文根本读不通

于是需要试一下17个一组的
tn c0afsiwal kes,
hwit1r g,npt tt
essfu}ua u hmqik
e {m, n huiouos
arwCniibecesnren.

由这个分组可得明文为the anwser is wctf{C01umnar},if u is a big new,u can help us think more question,tks.

附录

在解码的时候,博主用C写了个小程序,用来数字符串的长度和找素数,代码附上:

#include<stdio.h>
#include<string.h>
int main(){
	char str[]="tn c0afsiwal kes,hwit1r  g,npt  ttessfu}ua u  hmqik e {m,  n huiouosarwCniibecesnren.";
	printf("%d\n",strlen(str));
	int N=strlen(str);
	for(int i=2;i<N;i++){
		if(N%i==0)
		printf("%d\n",i);
	}
	return 0;
}

博主个人认为很多时候解密就是在凑,只是凑得方法不一样而已

  • 10
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python可以使用以下方式实现凯撒密码和栅栏密码: 凯撒密码是一种简单的密码转换方法,通过对原文中的每个字母进行移位来加密和解密。在Python中,可以使用ord()和chr()函数来实现字母的ASCII码和字符之间的转换。 例如,我们要将明文字符串"HELLO"使用凯撒密码进行加密,假设移位值为3: ```python def caesar_cipher_encrypt(plaintext, shift): ciphertext = "" for char in plaintext: if char.isalpha(): # 只对字母进行加密 ascii_value = ord(char.upper()) # 转换为大写字母的ASCII码 shifted_ascii_value = (ascii_value - 65 + shift) % 26 + 65 # 字母移位 ciphertext += chr(shifted_ascii_value) # 转换为加密后的字符 else: ciphertext += char # 非字母字符直接添加到密文中 return ciphertext plaintext = "HELLO" shift = 3 ciphertext = caesar_cipher_encrypt(plaintext, shift) print(ciphertext) # 输出:KHOOR ``` 栅栏密码是一种换位密码,通过将明文的字母按照一定的规则重新排列来加密和解密。在Python中,可以使用循环和切片操作来实现栅栏密码。 例如,我们要将明文字符串"HELLO"使用栅栏密码进行加密,假设栏数为2: ```python def rail_fence_cipher_encrypt(plaintext, num_rails): rails = [[] for _ in range(num_rails)] # 创建栅栏列表 current_rail = 0 direction = 1 # 标识方向 for char in plaintext: rails[current_rail].append(char) # 根据当前栏添加字符 if current_rail == num_rails - 1: # 到达最后一栏时改变方向 direction = -1 elif current_rail == 0: # 回到第一栏时改变方向 direction = 1 current_rail += direction # 改变当前栏 ciphertext = "" for rail in rails: ciphertext += "".join(rail) # 将栏内字符拼接成密文 return ciphertext plaintext = "HELLO" num_rails = 2 ciphertext = rail_fence_cipher_encrypt(plaintext, num_rails) print(ciphertext) # 输出:HLOEL ``` 以上就是使用Python实现凯撒密码和栅栏密码的简单示例,这些代码可以作为基础来进一步扩展和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值