首页 > Python资料 博客日记
CTFshow菜狗杯-misc-wp(详解 脚本 过程 全)
2024-03-25 02:00:04Python资料围观278次
首先感谢ctf平台和各位出题的大佬
其次感谢各位读者,对我的支持( •̀ ω •́ )y 有什么问题和建议可以私聊我
废话不多话开启你们的旅程吧 这个也是我这几天才看 一些见解和思路分享给你们
希望你们在旅途中玩的开心,学的开心✌( •̀ ω •́ )y
杂项签到
data:image/s3,"s3://crabby-images/35671/35671558686e05c05145a384c6817d6417c424fc" alt=""
data:image/s3,"s3://crabby-images/fb553/fb5531c93f56e03bd303ff2aa8520954c9b1dfed" alt=""
既然是签到就别往复杂想
直接010 搜索ctf
data:image/s3,"s3://crabby-images/98b76/98b7666a92733cbf46fa957511330e94090894b9" alt=""
得到flag
ctfshow{a62b0b55682d81f7f652b26147c49040}
损坏的压缩包
data:image/s3,"s3://crabby-images/2a6af/2a6af78ae327002107c59334e594e08803156f2f" alt=""
data:image/s3,"s3://crabby-images/4c3ee/4c3eeda95cdd5f10b673373209f5282f7433de3d" alt=""
data:image/s3,"s3://crabby-images/ff37e/ff37e5c67de5645816cfc1a69bd10bf9b8ed862f" alt=""
010查看十六进制发现附件为png图片,修改后缀为png解得flag
ctfshow{e19efe2eb86f10ccd7ca362110903c05}
谜之栅栏
data:image/s3,"s3://crabby-images/ef68c/ef68c633413e15b3e91ea883b0a2c88d0db3c901" alt=""
data:image/s3,"s3://crabby-images/ddc0a/ddc0a79e1a3417c23986ad1be14014ad3d81863f" alt=""
这个提示已经很明显了
使用010editor的文件比较功能找到两张图片的十六进制不同点,按顺序互相取一位数或者栅栏2位解得flag
data:image/s3,"s3://crabby-images/194a3/194a3a695fcca694fefdb1972c37dc6108a12023" alt=""
010的功能远不如此 多多学习
data:image/s3,"s3://crabby-images/5aaf1/5aaf12e20c9bac6979a4b926eeca0eda06fe631f" alt=""
ctfshow{f0a6a0b721cfb949a7fb55ab5d8d210a}
你会数数吗
data:image/s3,"s3://crabby-images/5c601/5c6013010a8462855496a70974b6ce3d15c8abc3" alt=""
data:image/s3,"s3://crabby-images/7def0/7def080e12350f9b18252fb721b7202a04faeb3c" alt=""
无后缀拖010里查看源代码
data:image/s3,"s3://crabby-images/38e8e/38e8efef673bdc7ff41955c0b0fc21cc05060ca5" alt=""
一堆乱码
结合题目你会数数吗
想到可能是词频统计
这里还要用到010
工具直方图
data:image/s3,"s3://crabby-images/80fab/80fab6938c3a1b5d690d0e29f69f3241952439af" alt=""
data:image/s3,"s3://crabby-images/68b43/68b439fe8f457174c85920750c20ecc0ea9cf1e9" alt=""
得到直方图按照计数降序统计字符
data:image/s3,"s3://crabby-images/336f2/336f286b404b7f7fddde2279b2e1ece3352f85ee" alt=""
得到flag
ctfshow{a1b2d3e4g56i7j8k9l0}
这里也可以不使用010使用python
# -*- coding:utf-8 -*-
import re
from collections import Counter
#定义一个函数,用于统计字母的个数
def analyze_letter_count(text):
# 从文本中提取出所有字母
letters = re.findall(r'\S', text)
# 统计所有字母的个数
counter = Counter(letters)
return counter
# 将文本存入变量
# 调用函数分析字母个数
def re_letter(s):
regex = r'\'(.*?)\''
new_string = re.findall(regex,s)
return new_string
text=input("输入文本:")
letter_count = analyze_letter_count(text)
strings=str(letter_count)
#print(letter_count)
print(''.join(re_letter(strings)))
同样最后也可以得到flag
ctfshow{a1b2d3e4g56i7j8k9l0}
你会异或吗
data:image/s3,"s3://crabby-images/dde64/dde64b5c6f4aec1f3ca675e00d3be0ceeb5e35c9" alt=""
data:image/s3,"s3://crabby-images/57935/57935c56e64c84d3b1b723a78fa83b35ff24fdb8" alt=""
老规矩010走一遭
data:image/s3,"s3://crabby-images/abf8a/abf8aa7c2305f2357732b3749f2d3cb9b3db2db2" alt=""
乱码一堆
根据题目提示(你会异或吗 神秘数字:0x50)
那我们就图片十六进制值异或十六进制50解得图片
这里还要使用010
全选代码工具十六进制运算二进制异或
data:image/s3,"s3://crabby-images/94bca/94bcaba90ac5b39d8a022857e61054f2e5bc501f" alt=""
data:image/s3,"s3://crabby-images/a30db/a30dbb6e49a671b676b51ec3db98957e0ddbce31" alt=""
得到完整的png图片
data:image/s3,"s3://crabby-images/abfe6/abfe6504e7c39f9f7b326d3ceb1dcc4a3509174c" alt=""
保存如下图
data:image/s3,"s3://crabby-images/7e9d9/7e9d99bf8aa3181bc7c924c4874dd87540c5a0da" alt=""
得到flag
ctfshow{030d0f5073ab4681d30866d1fdf10ab1}
这里同样可以使用python
path = 'misc5.png'
# 新文件路径
new_path = 'new.png'
# 异或运算 def xor(file_path):
# 以二进制读取图片
with open(file_path, 'rb') as f:
data = f.read()
# 十六进制异或
data = bytes([c ^ 0x50 for c in data])
# 写入新的图片
with open(new_path, 'wb') as f:
f.write(data)
# 调用
xor(path)
ctfshow{030d0f5073ab4681d30866d1fdf10ab1}
flag一分为二
data:image/s3,"s3://crabby-images/e90e2/e90e2229ba5d347fc094632b74d8b98384b0485b" alt=""
仅仅从标题看,这个题就不可能只有一种隐写方式了
但不要慌,唯一好的一点她是个能正常打开的图了
挺好看的一个图片
data:image/s3,"s3://crabby-images/9c0cf/9c0cf82b9d9ed25f64b529d6f0205364387c6615" alt=""
使用StegSlove工具打开
查看file format
data:image/s3,"s3://crabby-images/19051/19051b4c38f391cfec1fe9824a071c03c6b6339f" alt=""
data:image/s3,"s3://crabby-images/102ab/102ab0f1a17ea87e596f0538a8116403a926c35f" alt=""
这时候你就会发现CRC(CRC) Calculated CRC(计算的CRC)不一样
这能证明什么有很大可能图片的高度被修改过
接下就是恢复高度(当然有些题你可以直接将高度调大,但我们是要精通一个题 所以我们可以使用工具。或者脚本找到图片的原始高度)
脚本
#png图片爆破宽高
import zlib
import struct
file = 'miku.png'
fr = open(file,'rb').read()
data = bytearray(fr[12:29])
#crc32key = eval(str(fr[29:33]).replace('\\x','').replace("b'",'0x').replace("'",''))
crc32key = 0x7507b944
#data = bytearray(b'\x49\x48\x44\x52\x00\x00\x01\xF4\x00\x00\x01\xF1\x08\x06\x00\x00\x00')
n = 4095
for w in range(n):
width = bytearray(struct.pack('>i', w))
for h in range(n):
height = bytearray(struct.pack('>i', h))
for x in range(4):
data[x+4] = width[x]
data[x+8] = height[x]
#print(data)
crc32result = zlib.crc32(data)
if crc32result == crc32key:
print(width,height)
print(data)
newpic = bytearray(fr)
for x in range(4):
newpic[x+16] = width[x]
newpic[x+20] = height[x]
# fw = open(file+'.png','wb')
fw = open(file, 'wb')
fw.write(newpic)
fw.close
print("It's done!")
data:image/s3,"s3://crabby-images/a9c3c/a9c3c27fa8d309bf836f071d3ea2440f38b35e12" alt=""
在010直接改高度就行
data:image/s3,"s3://crabby-images/25a0c/25a0cff6bd41436b2636b40c9ef38d2bd97af051" alt=""
工具
链接:https://pan.baidu.com/s/1DHzIfRwb9zkn-qSHAl-1qQ
提取码:lulu
--来自百度网盘超级会员V3的分享
图片直接拖进去就行
data:image/s3,"s3://crabby-images/af606/af606762b7df8b4fe29715fb3b89ba1151c2ffa8" alt=""
不管那种都可以得到图片的原始高度
data:image/s3,"s3://crabby-images/97405/97405509673fd5e9f33970ea75920cc0577ee47b" alt=""
SecondP@rTMikumiku~}
后一半找到了
接下来只要找到前一半就行了
首先我们要试试分离lsb隐写之类的
后来发现是盲水印
使用waterMark.exe盲水印工具提取就可以
data:image/s3,"s3://crabby-images/1f641/1f6410a33c8a295ffc769d87fd26066fd548122a" alt=""
得到前一部分
ctfshow{FirstP@RT
最终得到flag
ctfshow{FirstP@RTSecondP@rTMikumiku~}
我是谁??
data:image/s3,"s3://crabby-images/eb9b2/eb9b297b10fc02ee58f817239a09cc92c590d3b2" alt=""
有意思的题目 感兴趣可以尝试
部署实例
data:image/s3,"s3://crabby-images/891fd/891fd85d575d1ede166509132e71d54fe7d15d62" alt=""
data:image/s3,"s3://crabby-images/fbf95/fbf95c9507b782672252dea36625d3db14890a15" alt=""
刚开始还蛮期待的
其实就是找图片
在题目给出的链接里面玩游戏即可,眼睛好的可以快速通关,像我一样菜的需要点时间才能拿到flag。
当然也可以用脚本来做,找到视频的关键帧,然后截取出剪影部分,然后根据剪影在大图里找。
这里提供一个脚本供参考:(官方脚本)
import requests
from lxml import html
import cv2
import numpy as np
import json
url="http://xxxxxxxxxxxxxxxxxxxx.challenge.ctf.show"
sess=requests.session()
all_girl=sess.get(url+'/static/all_girl.png').content
with open('all_girl.png','wb')as f:
f.write(all_girl)
big_pic=cv2.imdecode(np.fromfile('all_girl.png', dtype=np.uint8), cv2.IMREAD_UNCHANGED)
big_pic=big_pic[50:,50:,:]
image_alpha = big_pic[:, :, 3]
mask_img=np.zeros((big_pic.shape[0],big_pic.shape[1]), np.uint8)
mask_img[np.where(image_alpha == 0)] = 255
cv2.imwrite('big.png',mask_img)
def answer_one(sess):
#获取视频文件
response=sess.get(url+'/check')
if 'ctfshow{' in response.text:
print(response.text)
exit(0)
tree=html.fromstring(response.text)
element=tree.xpath('//source[@id="vsource"]')
video_path=element[0].get('src')
video_bin=sess.get(url+video_path).content
with open('Question.mp4','wb')as f:
f.write(video_bin)
#获取有效帧
video = cv2.VideoCapture('Question.mp4')
frame=0
while frame<=55:
res, image = video.read()
frame+=1
#cv2.imwrite('temp.png',image)
video.release()
#获取剪影
image=image[100:400,250:500]
gray_image=cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)
#cv2.imwrite('gray_image.png',gray_image)
temp = np.zeros((300, 250), np.uint8)
temp[np.where(gray_image>=128)]=255
#去白边
temp = temp[[not np.all(temp[i] == 255) for i in range(temp.shape[0])], :]
temp = temp[:, [not np.all(temp[:, i] == 255) for i in range(temp.shape[1])]]
#缩放至合适大小,肉眼大致判断是1.2倍,不一定准
temp = cv2.resize(temp,None,fx=1.2,fy=1.2)
#查找位置
res =cv2.matchTemplate( mask_img,temp,cv2.TM_CCOEFF_NORMED)
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)
x,y=int(max_loc[0]/192),int(max_loc[1]/288)#为什么是192和288,因为大图去掉标题栏就是1920*2880
guess='ABCDEFGHIJ'[y]+'0123456789'[x]
print(f'guess:{guess}')
#传答案
response=sess.get(url+'/submit?guess='+guess)
r=json.loads(response.text)
if r['result']:
print('guess right!')
return True
else:
print('guess wrong!')
return False
i=1
while i<=31:
print(f'Round:{i}')
if answer_one(sess):
i+=1
else:
i=1
You and me
data:image/s3,"s3://crabby-images/c273c/c273c563c1f42e3880d08f6533edc4f55ae4abaf" alt=""
下载解压俩小女孩
data:image/s3,"s3://crabby-images/02042/020420daae06c2d80ac0e909edef00e4c6c3af7f" alt=""
这一看就知道在干嘛吧
使用BlindWaterMark-master盲水印
python3 bwmforpy3.py decode you.png you_and_me.png wm2.png
data:image/s3,"s3://crabby-images/47407/47407a80ca6628aa355d0bbe7fb7c8880a4d9a2c" alt=""
data:image/s3,"s3://crabby-images/9b66a/9b66abc17da1f741812e243f65b78c87aa140fed" alt=""
得到ctfshow{CDEASEFFR8846}
7.1.05
data:image/s3,"s3://crabby-images/5ffeb/5ffeb5f37fee96a7d65da01457bc40d4344bfa7f" alt=""
解压之后是个SAV的文件
data:image/s3,"s3://crabby-images/a7c38/a7c387e86246b260d50fcda837de01eab1e2ef2c" alt=""
这种文件不是内存取证就是游戏存档
这里信息非常少只能我们一个一个去找
使用strings检索关键字
strings flagInHere.SAV >4.txt
data:image/s3,"s3://crabby-images/40b85/40b854759b2f8a4a2a867809bd962957fe6644d0" alt=""
得到两个重要信息
data:image/s3,"s3://crabby-images/17c59/17c59933def708a3f8766851bb5bf95789e40619" alt=""
data:image/s3,"s3://crabby-images/3f64a/3f64a1b68fb5077ed769644d589e326b746a60b0" alt=""
翻译一下
data:image/s3,"s3://crabby-images/ba4f7/ba4f72ac836e875b298271382b788cb6a4d575ab" alt=""
发现数个网址,点击其中一个进行访问:
data:image/s3,"s3://crabby-images/e4f3f/e4f3f717beee5ec0da313c6db34a784a81629cbd" alt=""
发现无论打开那个都有这张图片直接来个信息搜集
data:image/s3,"s3://crabby-images/c9f0a/c9f0a3537eb3c57107dafa24846be1e996a0d2cf" alt=""
果然游戏没错那个文件八成就是游戏存档
在网上搜索游戏,发现游戏版本已经更新到了8.1.18版本。
结合题目中的7.1.05,不难联想到题目希望使用7.1.05版本的游戏来打开存档,所以使用capitalism lab v.7.1.05进行搜索
data:image/s3,"s3://crabby-images/9922e/9922e7bc83abe643b59dd70f6a8ce7ce28c908be" alt=""
还有另一种方法:这个游戏有中文社群,可以加QQ群754365305然后找管理要。
下载后打开游戏,却不知道如何载入存档?
之前不是使用strings扫描关键字符吗 还有一段信息没有使用
“C:\Users\Administrator\Documents\MyGames\CapitalismLab\SAVE\LONG_001.SAV”,存档文件应该放置在我的文档下的MyGames文件夹中的\CapitalismLab\SAVE\中。然后打开游戏,载入存档
data:image/s3,"s3://crabby-images/f14f6/f14f60d88d92711b16a944c4b58e7e4a3effe5ef" alt=""
加载存档
data:image/s3,"s3://crabby-images/1443b/1443bf6ccd0f7f68bf51fedcb737172adbabcd26" alt=""
data:image/s3,"s3://crabby-images/0560e/0560e58afced05eb6ba1173ca49f80356eb21844" alt=""
若载入存档时出错,请关闭所有MOD,并打开所有DLC。
载入存档后如上图所示。这时我们会注意到底下的flag和操作。
long_flag_in_R&D。
R&D的意思是Research&Develop
在游戏中能代表这个含义的,是研发中心。因此我们需要找到研发中心的秘密
data:image/s3,"s3://crabby-images/3cf57/3cf577170a744e954997b78a7ebebd088c9bda75" alt=""
可以发现每个研发中心的研发部门的数量都不一样,将其按照从左下向右上,再行扫描的方式,可以得到这么一串数字:
9794598612147726669494087179782678475623253058262173164497949649813569030779924086502049160804再结合提示
data:image/s3,"s3://crabby-images/1621e/1621e93ea334ec5967d11a54599ab55ffe5a933d" alt=""
long_to_bytes是一个常用于RSA的函数,用于将数字转成字节,来试一下:
>>> from Crypto.Util.number import long_to_bytes
>>> long _ to_bytes
(9794598612147726669494087179782678475623253058262173164497949649813569030779924086502049160804 )b " \ X01 , x84 ( xfa , xe7 ] FI & x84 ? \ \ \ \ \ \ \ \ \ \ xc1x08\ x03 / \ x9auo \ xc2;ek \ x9ed'
失败了,那有没有可能是被逆序了?
>>>long _ to _ bytes
(4080619402056804299770309653189469497944613712628503523265748762879717804949666277412168954979)
b'}3maG_d00G_0S_s1_baL_ms1lat1paC{wohsftc'
可以明显看到一个wohsftc,这是被逆序过的ctfshow。再逆序一遍即可得到flag
ctfshow{Cap1tal1sm_Lab_1s_S0_G00d_Gam3}
黑丝白丝还有什么丝?
data:image/s3,"s3://crabby-images/68015/6801586acd071a605024f8dfe0f872972daa6db7" alt=""
这个题多说无意我们相信探姬师傅是为了出题才穿女装的
data:image/s3,"s3://crabby-images/78f76/78f7688d74623f29f25b09f2f8e3fa62d6b363fb" alt=""
视频链接
https://www.douyin.com/video/7164477952082693414
提示已经非常明显了
白丝为 . 黑丝为 - 转场为
看视频手敲:.-- ....- -. - - ----- -... ...-- -- --- .-. . -.-. ..- - .
data:image/s3,"s3://crabby-images/f6ecc/f6ecc4e73c105318b7371dc5c922d5b8d90ebf39" alt=""
得到flag
ctfshow{w4ntt0b3morecute}
我吐了你随意
data:image/s3,"s3://crabby-images/b0bed/b0bed368f2da61924e95b33816a644f0ab548123" alt=""
这是妥妥的拜师贴呀
data:image/s3,"s3://crabby-images/3d0a3/3d0a34812af694634010922031178a5e5dc2bdfc" alt=""
当然这个提示也非常明确了零宽度字符的Unicode隐写术
零宽度字符的Unicode隐写术链接
http://330k.github.io/misc_tools/unicode_steganography.html
data:image/s3,"s3://crabby-images/c942d/c942deeef6510b9c2de92bd48281094402a85466" alt=""
得到flag
ctfshow{OP_is_for_Over_Power}
这是个什么文件?
data:image/s3,"s3://crabby-images/b052e/b052e41b79771ff1542a134f4c367b8097969d00" alt=""
看见需要密码的压缩包 第一时间想到的应该是不是伪密码
data:image/s3,"s3://crabby-images/05440/05440c0496ae9991573aa890bd0842a601e073f6" alt=""
010查看 果然 把09改成00就好了
data:image/s3,"s3://crabby-images/b7d67/b7d671b3567e63845846178bea14d4e110b8d062" alt=""
得到无后缀文件
data:image/s3,"s3://crabby-images/908ab/908ab299f949978068256ca815dd7739247ebd6a" alt=""
010查看
data:image/s3,"s3://crabby-images/d9719/d9719a2c5e6209569125d228bb6e62be34fe1c07" alt=""
怀疑可能是pyc文件 假后缀
data:image/s3,"s3://crabby-images/6f292/6f2925c6378d8534e30569e769f773478a37be0e" alt=""
那就需要反编译成py文件
在线网站
data:image/s3,"s3://crabby-images/86e2e/86e2ee72f18241c3f379d456a543a21da15509a5" alt=""
flag=bytes([99,116,102,115,104,111,119,123,99,100,106,110,106,100,95,53,54,53,102,95,71,67,68,72,95,107,99,114,105,109,125]).decode()
print(flag)
运行一下就可以了
data:image/s3,"s3://crabby-images/96385/963851212c5e2b09ee0de9d5f84856b438b67441" alt=""
得到flag
ctfshow{cdjnjd_565f_GCDH_kcrim}
抽象画
data:image/s3,"s3://crabby-images/ed1a9/ed1a9db1e7c36d390df7e24c959eabfec6d7e27c" alt=""
data:image/s3,"s3://crabby-images/1329d/1329d9260063307100ca486c7aa3bd8d70f56a3a" alt=""
题目说是图片打开确实乱码
说明这肯定是源代码编译过的
先试base
Base58到base32到base64
data:image/s3,"s3://crabby-images/5a252/5a252316e186025a8b1dd9201fb70a315299239a" alt=""
得到16进制代码
在010新建16进制文本 粘贴自十六进制文本
data:image/s3,"s3://crabby-images/11127/11127a2eca66d58d01d8b600e4773dfe47958936" alt=""
转化成图片保存png格式
data:image/s3,"s3://crabby-images/84bde/84bde4cc8f8547a1bcfcc0134f48c53da85531fe" alt=""
果然够抽象
这里需要我们用到npiet这个工具
下载链接
https://download.csdn.net/download/m0_68012373/87428971?spm=1001.2014.3001.5501
data:image/s3,"s3://crabby-images/03e51/03e514898fab7e869c47f4bd78f7c0506cd050dc" alt=""
npiet.exe -tpic 1.png
data:image/s3,"s3://crabby-images/a2cc9/a2cc93b1bf453ef1631a9256cef154f7a121231e" alt=""
得到flag
ctfshow{dec8de_frejnv_frejer89}
迅疾响应
data:image/s3,"s3://crabby-images/927e4/927e499239097e5faec0b9340e8d67681d1fbecc" alt=""
打开一看二维码 但一看就是扫不出来的那种果然什么都没有
data:image/s3,"s3://crabby-images/2f5ef/2f5ef6e68c77a2cdcfa5039f8dd5f137e02be96d" alt=""
正常思路就是图片隐写分离什么的
就使用strings搜索了一下关键字符
data:image/s3,"s3://crabby-images/4dcd4/4dcd497be53e7e089d28af24c8efb8b7ea0d53f4" alt=""
就发现这段字符(后来知道这是出题人设计的一个小坑)
既然什么都没有
那我们还就行走二维码这条路
data:image/s3,"s3://crabby-images/425d0/425d0fb407002a9363caa12c2087246f9847480a" alt=""
二维码识别最好用的还要看工具QRazyBox
工具在线链接https://merricx.github.io/qrazybox/
导入文件
data:image/s3,"s3://crabby-images/07de6/07de6c4f9b852c2e2f484e7da88a05daa08bab42" alt=""
data:image/s3,"s3://crabby-images/543d8/543d8b9019c01b36c1d1d5d83ca49fee67c641ab" alt=""
工具提取QR信息
data:image/s3,"s3://crabby-images/1f765/1f765c9fd3599fb955e1a5bd00e622b48206bf8c" alt=""
data:image/s3,"s3://crabby-images/e9053/e90532fdb9bbbf246c62317d0a1d5fc390447c3b" alt=""
ctfshow{11451419-1981-
这也就表示还有一部分
data:image/s3,"s3://crabby-images/381ee/381eef3d3b51c10a3ebf9afc1f9776f77936a243" alt=""
使用画笔将纠错区给涂白如上图
然后工具刚刚的步骤在扫描一遍
data:image/s3,"s3://crabby-images/4c5cd/4c5cdd1746c427ad5092b182a2d5bcdc70ddad45" alt=""
就有了后面一部分
landexiangle}
拼起来得到flag
ctfshow{11451419-1981-landexiangle}
我可没有骗你
data:image/s3,"s3://crabby-images/d18e5/d18e5e71ea9d83c6ab4980ed51251f9c70c4e897" alt=""
压缩包要密码(正常思路,肯定是密码被藏起来,需要我们去找,我们还满怀期待的去找,结果什么都没,不得不说,作者呀)
data:image/s3,"s3://crabby-images/22523/22523601525f69cf07b43e7c5caa1d55317e19c3" alt=""
这个密码只能去爆破
使用ARCHPR,尝试爆破,选数字
data:image/s3,"s3://crabby-images/d0054/d0054300e3021c358143185c51274b7bb9ffd1c3" alt=""
data:image/s3,"s3://crabby-images/d4f2a/d4f2a1f7481d5b6c189c9408566add949589fb66" alt=""
得到密码55813329
解压得到svega.mp3
data:image/s3,"s3://crabby-images/96d8c/96d8c98516a5a04e7cafa2dfae87de1ae63e1dfc" alt=""
直接听百分之九十九没有用但还是要听一听
然后查看源代码
没有什么特别奇怪的地方
就是文件后缀是MP3 但源代码的格式是wav
data:image/s3,"s3://crabby-images/6b14f/6b14fa07814e38c6bd0a243a10d2ccac92d1e812" alt=""
所以改后缀wav
正常顺序对文件分析分离隐写什么的一下但没有什么东西
那就绝大可能是工具隐写
关于音频隐写的工具wbStego silenteye等等就不多说了
这里使用的是静默之眼(silenteye)别为什么因为题目没有提示 那我们只能一个一个去试
先导入文件然后打开decode
data:image/s3,"s3://crabby-images/38d15/38d15e5ebd485a2822cfaa8e8ae1de902167624b" alt=""
Sound qualit选择high
data:image/s3,"s3://crabby-images/a5db2/a5db231447f446bbbf2c20cd2074acbf3d1cc1a1" alt=""
点击decode
data:image/s3,"s3://crabby-images/6d45c/6d45cc6cae8b12c18b76c7ef213657cbaedc93f3" alt=""
解密
得到flag
ctfshow{aha_cdsc_jejcfe5rj_cjfr24J}
你被骗了
data:image/s3,"s3://crabby-images/2cc7d/2cc7de61b9df4b2adfeb81199e9d744fffc1f286" alt=""
下载解压又是一个MP3文件
data:image/s3,"s3://crabby-images/c74a0/c74a0baa247d06404db76694bd8f4354940480f2" alt=""
在属性详细信息里有个flag(但是误导性信息假的,照应了题目)
data:image/s3,"s3://crabby-images/82752/82752713f14192ad31b73f4f93f1ca1c37986bf8" alt=""
使用MP3Stego这个工具
(当还需要密码,先拿空密码试试,发现不是就拿标题试一下)
MP3StegoDecode.exe -X -P nibeipianle nibeipianle.mp3
data:image/s3,"s3://crabby-images/0dd37/0dd37f5b2ad5270bfafb4d3d1b4c1873811edc4b" alt=""
有个txt文件 里面就是flag
data:image/s3,"s3://crabby-images/0c3d0/0c3d0f96e2d668f6fa34253d7abeed879c0b428e" alt=""
得到flag
ctfshow{chdv_1dcs_cjksnjn_NJDSjdcdjn}
一闪一闪亮晶晶
data:image/s3,"s3://crabby-images/edcbc/edcbca8a46a30248a6e21479154c8ed7dc2000dd" alt=""
下载附件
两文件what is this 是不需要密码的 那个一闪一闪亮晶晶是需要的
data:image/s3,"s3://crabby-images/ede81/ede81ca6ab7bd2dadbbf6ce58964e94ae14be9a3" alt=""
打开二维码那就扫 普及一下这种图片形式叫汉信码。中国自己的二维码
在线网站(兔子二维码)
data:image/s3,"s3://crabby-images/a459b/a459b9312d48951fa8f30ba51f70532ebf6edd70" alt=""
data:image/s3,"s3://crabby-images/c05da/c05da5c3ee73ffec12f2a71f2859b5757216ef5c" alt=""
密码是CDBHSBHSxskv6
解压之后是一个小小音频
data:image/s3,"s3://crabby-images/b864c/b864cf9b514435a4ed6075734739686da9b01361" alt=""
老规矩先仔细听听
不容易发现终于不再是单调的歌曲
它声音一响我还以为是摩斯密码
但等他放完发现根本不是
到一点无线电频的感觉
这就需要使用RX-SSTV这个工具了
这选项的解密方式是Robot36 点击Receiving然后播放音频就可以了
data:image/s3,"s3://crabby-images/dd7d4/dd7d44b8406f9c4dffa9e404db1a928da53804c2" alt=""
得到flag
ctfshow{NNICCETOMMETYOU}
一层一层一层地剥开我的♥
data:image/s3,"s3://crabby-images/b6944/b6944915de4a938ecb00f0a3e5cc5bbdd82aa34f" alt=""
好名字如果你愿意一层一层地剥开我的心你会发现你会明白
哎名字挺好题肯定不简单一层一层的套呀
data:image/s3,"s3://crabby-images/21174/2117461d1d5cf0c61a658adf7ab4389b503ee0fa" alt=""
data:image/s3,"s3://crabby-images/9874d/9874dd742bcd0cf21f665a2d1ee179611e60e367" alt=""
正常解压是会提示文件压缩文件已损坏
这时候肯定是要查看源代码
data:image/s3,"s3://crabby-images/115ea/115ea5efcb745948fcbc9a1fab82fc51e0d0a25c" alt=""
如上图我有理由怀疑这是一个word文档 改后缀伪docx
data:image/s3,"s3://crabby-images/6941e/6941e15f131c670e59a907834ece0f743afcd555" alt=""
一段奇怪的字符
data:image/s3,"s3://crabby-images/388ee/388ee0c444501d55b461e9a89acbba53c0214b05" alt=""
data:image/s3,"s3://crabby-images/eb203/eb20327bfa8559a768342a1f912ad12a0f7f95bc" alt=""
改一下字体改成宋体就行
data:image/s3,"s3://crabby-images/f1bb5/f1bb55691bde27142309b99df363ffa346aa4f9f" alt=""
Twinkle twinkle little star,how I wonder what you are
翻译一下
data:image/s3,"s3://crabby-images/c2fce/c2fce74b028ae8d007fe738191ffc1a4af69fb9d" alt=""
字面意思貌似没什么用 不知道后面有用吗
那就再看看之前压缩包的源代码吧
仔细查找一番貌似还有一个rar的压缩包
data:image/s3,"s3://crabby-images/1acc7/1acc719d86145952df5f2a61f8448f44b1c3e49e" alt=""
那就分离一下
使用binwalk
data:image/s3,"s3://crabby-images/80168/801684968609670b010933c74ee1cb8629677cdd" alt=""
data:image/s3,"s3://crabby-images/6b3cb/6b3cbd649adb31d011b7dcdc1af9365167184dbd" alt=""
里面有一个jpg图片 和一个爱心的文件
但需要密码
猜测密码与word文档内容有关,
最后试出来是这两句歌曲的简谱数字:11556654433221
解压
data:image/s3,"s3://crabby-images/e771d/e771d57bc0b6c63a34aeaadbac66792791a9e5db" alt=""
我们可以那个爱心里面是有一个txt的文件 我们有理由怀疑他是一个压缩包
data:image/s3,"s3://crabby-images/b0152/b0152aaec02e33b083f77ce2ca39a75ba830c489" alt=""
补全文件头52 62 72 21 保存
data:image/s3,"s3://crabby-images/bc383/bc383c3a856033027c4ed768c5d46bea66711df0" alt=""
里面果然有一个txt文件 但需要密码
data:image/s3,"s3://crabby-images/1ce13/1ce131dc8353095a868a8b04cde7c98d37f185ed" alt=""
那先看图片吧
data:image/s3,"s3://crabby-images/9e87a/9e87add8e340641804a31b13d1268e00e81885a1" alt=""
二话不说010走一波
data:image/s3,"s3://crabby-images/4670f/4670f009f0f50e8bed5e1f42aae2e0f6f238d4a9" alt=""
底下这么明显的分层如下图
data:image/s3,"s3://crabby-images/b9c1a/b9c1a96d66c373b535f7868f3e3b95b9b948d6c2" alt=""
肯定是有东西的而且底下怎么看就是一个完整的文件
用010单独提出来 保存
data:image/s3,"s3://crabby-images/812d1/812d141ad1caf0463dbc83fc9d5015073276fb37" alt=""
压缩包密码就是winkwink~
得到字符
data:image/s3,"s3://crabby-images/7975d/7975d0df10fbf24b12603513076c2a6fb420f90c" alt=""
Emoji表情符号编码
在线网站
http://www.atoolbox.net/Tool.php?Id=937
data:image/s3,"s3://crabby-images/9e404/9e404de41b02b476e311473ce49cd458e7c417cc" alt=""
得到flag
ctfshow{Wa0_wa_Congr@tulations~}
打不开的图片
data:image/s3,"s3://crabby-images/fbf65/fbf655126896a8d2e05b789199b4b7320cfcd0ba" alt=""
压缩包里面有一张打不开的图片,使用010查看十六进制码,发现文件头与PNG文件头十六进制码相加为100,
故用0x100相减既得png图片。
写一个python脚本制作图片:
f1 = open("./misc5.5.png","rb")
f2 = open("./output.png","wb")
all_data = f1.read()
lt = []for i in all_data:
if i == 0:
lt.append(i)
else:
lt.append(0x100 - i)
f2.write(bytes(lt))
f1.close()
f2.close()
得到如下图片
data:image/s3,"s3://crabby-images/93ca8/93ca8972cd9b5984c0b3e965ed0635b945152c3b" alt=""
得到flag
ctfshow{84a3ca656e6d01e25bcb7e5f415491fa}
加油各位( •̀ ω •́ )y 期待与君再相逢
标签:
相关文章
最新发布
- 光流法结合深度学习神经网络的原理及应用(完整代码都有Python opencv)
- Python 图像处理进阶:特征提取与图像分类
- 大数据可视化分析-基于python的电影数据分析及可视化系统_9532dr50
- 【Python】入门(运算、输出、数据类型)
- 【Python】第一弹---解锁编程新世界:深入理解计算机基础与Python入门指南
- 华为OD机试E卷 --第k个排列 --24年OD统一考试(Java & JS & Python & C & C++)
- Python已安装包在import时报错未找到的解决方法
- 【Python】自动化神器PyAutoGUI —告别手动操作,一键模拟鼠标键盘,玩转微信及各种软件自动化
- Pycharm连接SQL Sever(详细教程)
- Python编程练习题及解析(49题)
点击排行
- 版本匹配指南:Numpy版本和Python版本的对应关系
- 版本匹配指南:PyTorch版本、torchvision 版本和Python版本的对应关系
- Python 可视化 web 神器:streamlit、Gradio、dash、nicegui;低代码 Python Web 框架:PyWebIO
- 相关性分析——Pearson相关系数+热力图(附data和Python完整代码)
- Anaconda版本和Python版本对应关系(持续更新...)
- Python与PyTorch的版本对应
- Windows上安装 Python 环境并配置环境变量 (超详细教程)
- Python pyinstaller打包exe最完整教程