目录
审题测试
根据题目描述,发现只有一串字符串有用,应该是一串密文
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之间
这里最大的数为250,最小的为160,为了ascall转码后能正常显示至少要减掉124 ,最多只能减去128,所以用Python试一下一个个减掉再输出看看,盲猜是128
开始实践
写一下代码
开始运行
果然,减去128才能得到flag
成功拿到flag
flag{hjzcydjzbjdcjkzkcugisdchjyjsbdfr}