buuctf-鸡藕椒盐味 write up

该博客讲述了如何利用海明校验码纠正一个倒置的12位验证码中的错误,以解决公司食堂鸡藕椒盐汉堡的验证码问题。通过计算校验位并发现错误位,得出正确的验证码,然后使用MD5加密得到flag。内容涉及到数据传输错误检测、奇偶校验和海明校验码的原理与应用。
摘要由CSDN通过智能技术生成

题目描述:公司食堂最新出了一种小吃,叫鸡藕椒盐味汉堡,售价八块钱,为了促销,上面有一个验证码,输入后可以再换取一个汉堡。但是问题是每个验证码几乎都有错误,而且打印的时候倒了一下。小明买到了一个汉堡,准备还原验证码,因为一个吃不饱啊验证码如下:1100 1010 0000 ,而且打印的时候倒了一下。把答案哈希一下就可以提交了。(答案为正确值(不包括数字之间的空格)的32位md5值的小写形式) 注意:得到的 flag 请包上 flag{} 提交

从题目我们可知鸡藕椒盐==奇偶校验(想不到吧

奇偶校验码的定义:

1.编码方式

无论数据位多少位,校验位只有一位数据位和校验位一共所含的1个数为奇数,称为奇校验数据位和校验位一共所含的1个数为偶数,称为偶校验

注:数据传输过程一般是出现一位错误,而奇偶校验码能发现奇数个错误

海明校验码可以用来修正数字上的错误,验证码有错误,那么11001010000直接md5加密肯定不对,我们用海明校验码来获得正确的验证码:

验证码一共有12位,题目给了一个提示:每个汉堡8块,也就是说,数据位为8(k),校验位为4(r),而校验位在2^n的位置,所以共有4位校验码在1,2,4,8位置,而且题目提示验证码倒了,所以我们倒着输入验证码:


 

123456789101112
01010011
r1r2r3r4

海明校验码计算公式:

2^r≥k+r+1(k为数据位,r为校验位)

 接下来我们求校验码r1r2r3r4的值:

所等于的校验位相加对应校验位
11r1
22r2
31+2r1,r2
44r3
54+1r3,r1
64+2r3,r2
74+2+1r3,r2,r1
88r4
98+1r4,r1
108+2r4,r2
118+3r4,r1,r2
128+4r4,r3

校验位出现在数据位汇总:

r1:3,5,7,9,11

r2:3,6,7,10,11

r3:5,6,7,12

r4:9,10,11,12

r1等校验位的计算要用到异或(⊕)异或计算就是一样的数字得0,不同的数字得1:

那么应有:r1=0⊕1⊕1⊕1=1

r2=0⊕0⊕1⊕0⊕1=0

r3=1⊕0⊕1⊕0=0

r4=0⊕0⊕1⊕1=0

明显r1出现错误,与题目所给的r1=0不符,所依通过计算比对我们可知,9的位置出现错误,应该为1(奇偶校验码嘛,奇数个错误,一般数据传输有一位错误,所以可以确定9出现错误)

最终我们可得正确的验证码:11011010000,最后放到md5里加密一下就是flag啦:

MD5在线加密 (hwcha.com)

flag{d14084c7ceca6359eaac6df3c234dd3b}

俺也是小白,如果有哪里有错误欢迎大佬给俺指出来(*`▽´*)

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值