Crypto之LFSR

介绍

LFSR又称线性反馈移位寄存器
是在GF(2)有限域上的一个n级反馈移位寄存器
其由n个二元存储器与一个反馈函数组成
在这里插入图片描述
或者用下图更清楚的描述
在这里插入图片描述

每当最高位(如a1)输出时,会根据反馈函数计算得到一个 a n + 1 a_{n+1} an+1 ,每个存储器向右移动一位,然后将 a n + 1 a_{n+1} an+1放到最低位
这样就实现了一次完整的移位运算,如下图所示
![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/953d0caf02b8454db6c2547a8df161a8.png
图画的有点难看,不要介意
而在ctf中,c1,c2,…cn的状态常用mask表示
其中mask的位数也就代表了存储器的个数,即我们想要求出的flag长度

比如mask是32位,通常会给出每次循环移位的最低位 a n + 1 a_{n+1} an+1,移动32次
就是我们只会得到移位后的数据( a n + 1 a_{n+1} an+1, a n + 2 a_{n+2} an+2, a n + 3 a_{n+3} an+3 a n + 32 a_{n+32} a

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值