攻防世界之掀桌子(详细分析)

目录

审题测试

思路分析

开始实践


审题测试

根据题目描述,发现只有一串字符串有用,应该是一串密文

c8e9aca0c6f2e5f3e8c4efe7a1a0d4e8e5a0e6ece1e7a0e9f3baa0e8eafae3f9e4eafae2eae4e3eaebfaebe3f5e7e9f3e4e3e8eaf9eaf3e2e4e6f2

试过了很多解密方式,base64什么的都不行

猜测应该是十六进制转化成十进制后再转Ascall字符

用Python写了一段代码

运行后

那再先看看转成10进制后的样子,再看看最大最小的数,稍微改动一下代码

 运行后

思路分析

可以看见上面表中,第一个数是200,最大的数是250,最小的是160,对照ascall码表,如果这串代码是通过ascall码解码得到flag的话,根据flag的格式,开头第一个要么是f,要么是c,要么无规则(那就减128、64、32尝试),而f对应的ascall码为102 , c对应的ascall码为99 , 但是ascall码只有126前才能正常显示不会乱码,符号flag格式的ascall码只在32到126之间

ASCALL码对照表 - Xiaohu_BigData - 博客园 (cnblogs.com)

这里最大的数为250,最小的为160,为了ascall转码后能正常显示至少要减掉124 ,最多只能减去128,所以用Python试一下一个个减掉再输出看看,盲猜是128

开始实践

写一下代码

 开始运行

果然,减去128才能得到flag

成功拿到flag

flag{hjzcydjzbjdcjkzkcugisdchjyjsbdfr} 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

金 帛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值