当前位置:   article > 正文

攻防世界-02_攻防世界 工业协议分析1

攻防世界 工业协议分析1

目录

Crypto

OldDriver 

ecb,_it’s_easy_as_123 

fanfie 

gcd 

exgcd 

 仿射密码 

代码实现 

 工业协议分析1

shanghai

简单流量分析

sleeping-guard 

Solve1

 Solve2

 Misc

embarrass 

 神奇的Modbus

 something_in_image

Aesop_secret

 倒立屋

Solve1

Solve2

a_good_idea

2017_Dating_in_Singapore 绝了,我鼠标勾线的图没了。。。

simple_transfer 

can_has_stdio?


 

 

Crypto

OldDriver 

学习wp

学习wp2

flag{wo0_th3_tr4in_i5_leav1ng_g3t_on_it} 

ecb,_it’s_easy_as_123 

意思是不会做 

参考

创建3840×2160的分辨率,16色深的bm的头,替换掉原来的头即可,即将前面的字节码

  1.     53 61 6c 74 65 64 5f 5f  ab 31 b5 e5 ca 3d b9 4d
  2.     f4 09 1a a5 df 88 b7 2c  0e bd 8a 73 98 15 ba 69
  3.     a2 24 3e 09 94 cb 79 1e  ea a1 ad 33 c8 17 66 63
  4.     78 98 23 0b f0 af 20 38  f1 aa 0b f4 69 1c ec cf
  5.     fc d8 8e 3d 45 2a 99 b0  53 6b 50 0d 8a 3d c4 b7
  6.     62 9c 6a 54 f0 59 20 13  22 4f b6 e2 b6 aa 0a 8b
  7.     5e 21 1a 9d cf 8c a2 f6  45 80 cb 9b b7 37 da 7f
  8.     73 50 88 cb df 63 ee 22  d4 24 b3 b9 f4 24 ad 40

替换成

  1.     424d 7648 3f00 0000 0000 7600 0000 2800
  2.     0000 000f 0000 7008 0000 0100 0400 0000
  3.     0000 0048 3f00 0000 0000 0000 0000 0000
  4.     0000 0000 0000 0000 0000 0000 8000 0080
  5.     0000 0080 8000 8000 0000 8000 8000 8080
  6.     0000 8080 8000 c0c0 c000 0000 ff00 00ff
  7.     0000 00ff ff00 ff00 0000 ff00 ff00 ffff
  8.     0000 ffff ff00 ffff ffff ffff ffff ffff

 flag{no_penguin_here}

fanfie 

仿射密码。 

参考:123(gcd&exgcd)4(exgcd)56(exgcd-2)

gcd 

 欧几里得算法,又名辗转相除法,用来计算两个数的最大公约数,原理:

gcd(a,b)=gcd(b,a mod b)

 证明:

设a,b的一个公约数为d

设a mod b=r,则a=kb+r(k为整数),r=a-kb

因为d|a, d|b,所以d|(a-kb)

理由如下:

d|(a−kb)

=(a−kb)/d

=a/d−kb/d

即d|r,而r=a mod b

所以d为b,a mod b的公约数

又因为d也为a,b的公约数,所以gcd(a,b)=gcd(b,a mod b),所以最大公约数必然一样,得证。

  1. int gcd(int a,int b){
  2. if (b==0)
  3. return a;
  4. return gcd(b,a%b);
  5. }

exgcd 

扩展欧几里得,不仅能求出a,b的最大公约数,还能求出满足ax+by=gcd(a,b)的一组可行解。

常用在求解模线性方程及方程组中。

  1. int exgcd(int a,int b,int &x,int &y){
  2. if (!b){
  3. x=1,y=0;
  4. return a;
  5. }
  6. int d=exgcd(b,a%b,y,x);
  7. y-=a/b*x;
  8. return d;
  9. }
  1. int exgcd(int a,int b,int &x,int &y){
  2. if (!b){
  3. x=1,y=0;
  4. return a;
  5. }
  6. int d=exgcd(b,a%b,x,y);
  7. int t=x;
  8. x=y;
  9. y=x-y*(a/b);
  10. return d;
  11. }

 仿射密码 

仿射密码是一种表单代换密码,字母表的每个字母相应的值使用一个简单的数学函数对应一个数值,再把对应数值转换成字母。

  • 加密函数:e(x) = ax + b (mod m) 其中a和m互质,m是编码系统中字母的个数(通常都是26)。

  • 解密函数:d(x) = inv a (x - b) (mod m) (inv a:乘法逆元,a^{-1}( a 在Z_{m}群的乘法逆元) )

ABCDEFGHIJKLMNOPQRSTUVWXYZ
012345678910111213141516171819202122232425

Gcd求解乘法逆元(Python):

  1. #欧几里德算法求最大公约数
  2. def gcd(a, b):
  3. k = a // b
  4. remainder = a % b
  5. while remainder != 0:
  6. a = b
  7. b = remainder
  8. k = a // b
  9. remainder = a % b
  10. return b
  11. #改进欧几里得算法求线性方程的x与y
  12. def exgcd(a, b):
  13. if b == 0:
  14. return 1, 0
  15. else:
  16. k = a // b
  17. remainder = a % b
  18. x1, y1 = get_(b, remainder)
  19. x, y = y1, x1 - k * y1
  20. return x, y
  21. a = input('a:')
  22. b = input('b:')
  23. a, b = int(a), int(b)
  24. #将初始b的绝对值进行保存
  25. if b < 0:
  26. m = abs(b)
  27. else:
  28. m = b
  29. flag = gcd(a, b)
  30. #判断最大公约数是否为1,若不是则没有逆元
  31. if flag == 1:
  32. x, y = exgcd(a, b)
  33. x0 = x % m #对于Python '%'就是求模运算,因此不需要'+m'
  34. print("所求的逆元:",x0) #x0就是所求的逆元
  35. else:
  36. print("Do not have!")

代码实现 

a=13,b=4.

  1. #仿射密码解密
  2. #改进欧几里得算法求线性方程的x与y
  3. def exgcd(a, b):
  4. if b == 0:
  5. return 1, 0
  6. else:
  7. k = a //b
  8. remainder = a % b
  9. x1, y1 = get(b, remainder)
  10. x, y =y1, x1 - k * y1
  11. return x, y
  12. s = input("请输入解密字符:").upper()
  13. a = int(input("请输入a:"))
  14. b = int(input("请输入b:"))
  15. #求a关于26的乘法逆元
  16. x, y = exgcd(a, 26)
  17. a1 = x % 26
  18. l= len(s)
  19. for i in range(l):
  20. cipher = a1 * (ord(s[i])- 65 - b) % 26
  21. res=chr(cipher + 65)
  22. print(res, end='')

密文

MZYVMIWLGBL7CIJOGJQVOA3IN5BLYC3NHI

仿射解密得:

IJEVIU2DKRDHWUZSKZ4VSMTUN5RDEWTNPU

base32解密得:

BITSCTF{S2VyY2tob2Zm}

 工业协议分析1

wireshark打开,找到:



转换得图片,即: 

flag{ICS-mms104} 

shanghai

维吉尼亚密码

参考

KEY:icqvigenere

flag{vigenereisveryeasyhuh} 

简单流量分析

新知识get

参考

流量分析题,分析的方法基本上有:binwalk、查找一些可疑字符串或16进制数据,排序流量包的长度(最长的流量包一般很可疑);

当我们对流量包的长度进行排序时,发现流量包最短90字节,最长也不过164字节,其中的data段数据长度从48到122,而ascii表中第48至122个字符为0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz,于是将每个流量包的长度转换为对应字符,然后连接成一段长字符串,看上去像base64编码,对字符串进行base64解码即可! 

  1. from pyshark.capture.file_capture import FileCapture
  2. from base64 import b64decode
  3. from sys import argv
  4. def solve(file_name):
  5. packets=FileCapture(input_file=file_name)
  6. res=''
  7. for packet in packets:
  8. for pkt in packet:
  9. if pkt.layer_name=='icmp' and int(pkt.type,16):
  10. res+=chr(int(pkt.data_len))
  11. return b64decode(res)
  12. if __name__=='__main__':
  13. print solve(argv[1])
  1. $ python solve.py fetus_pcap.pcap
  2. ::\nmongodb:!:17843:0:99999:7:::\nubuntu:$6$LhHRomTE$M7C4n84UcFLAG{xx2b8a_6mm64c_fsociety}::

flag{xx2b8a_6mm64c_fsociety} 

sleeping-guard 

参考1 参考2

连接上服务器之后,服务器返回的数据看上去像base64编码,对此,解码即可;

根据题目的提示,flag藏在图片中,解码后文件头数据不是png,jpg,bmp文件头格式(说明不是直接解码这么简单),也不是zip,rar,7z文件头格式(说明不是将图片加密压缩);

实际上,原比赛的此题还有一个Python脚本,大致意思是使用长度为12的密钥与图片数据进行(循环)异或加密

有了这个信息之后,尝试使用各种图片格式的文件头与加密数据进行异或得到密钥,使用png格式的文件头与加密数据进行异或时,得到的结果“很像”密钥;

接下来使用密钥解密即可。

Solve1

首先从服务器接收全部的数据,再进行base64解码(将解码后的数据存入文件data);

然后通过png文件头解出密钥(WoAh_A_Key!?),然后通过密钥解密,实现的Python脚本如下:

  1. from base64 import b64decode
  2. from binascii import unhexlify
  3. from Crypto.Util.strxor import strxor
  4. def enc(data,key):
  5. key=(key*(len(data)/len(key)+1))[:len(data)]
  6. return strxor(data,key)
  7. def solve(data):
  8. head=unhexlify('89504e470d0a1a0a0000000d49484452')
  9. key=strxor(head,data[:16])
  10. with open('sleeping-guard.png','wb') as f:
  11. f.write(enc(data,key[:12]))
  12. if __name__=='__main__':
  13. with open('data','rb') as f:
  14. solve(f.read())

 Solve2

首先使用nc命令连接到服务器,我们得到一个被base64编码过的数据流

base64decode后我们发现该文件不是一个有效的png文件

尝试简单的xor运算,我们从另一个已知的png文件中取出一个已知的明文,并尝试与该cipertext进行异或运算,尝试获取密钥

有了密钥,我们可以运行python脚本。

要在Linux环境下运行,得到的图片才能打开,windows环境下不行

  1. def xor(data, key):
  2. l = len(key)
  3. return bytearray((
  4. (data[i] ^ key[i % l]) for i in range(0,len(data))
  5. ))
  6. # Read the encrypted image as bytearray
  7. data = bytearray(open('out.png', 'rb').read())
  8. # This is our key as bytearray: "WoAh_A_Key!?"
  9. key = bytearray([0x57, 0x6f, 0x41, 0x68, 0x5f, 0x41, 0x5f, 0x4b, 0x65, 0x79, 0x21, 0x3f])
  10. with open('decrypted.png', 'w') as file_:
  11. file_.write(xor(data,key))

flag{l4zy_H4CK3rs_d0nt_g3T_MAg1C_FlaG5} 

 Misc

embarrass 

参考 

下载文件并进行解压,是一个流量包文件。
用wireshark打开,进行查找。(ps : 这个办法比较慢,而且最好在有题目提示的时候使用)
找了好几遍也没有找到。我们用foremost分解流量包。
得到很多htm文件、一个jpg文件和一个txt文件,但是还有没有找到结果。

strings './misc_02.pcapng' | grep flag

使用linux搜索直接得到flag{Good_b0y_W3ll_Done}。 

 

 神奇的Modbus

怎么说呢某种意义上这道题真的很神奇。。

.pcapng,wireshark打开,查找

以为就结束了,sctf{Easy_Mdbus}是吗,提交,居然不对。

看看题目叫什么,试试看。

sctf{Easy_Modbus}

 something_in_image

 StegSolve.jar打开,

flag{true_steganographers_doesnt_need_any_tools}

Aesop_secret

gif每帧拼起来得到:

010打开,末尾找到了加密字符串。 

ASE在线解密。
网址

密码=ISCC

flag{DugUpADiamondADeepDarkMine} 

 倒立屋

参考

Solve1

kali打开终端,

zsteg /home/kali/Desktop/倒立屋.png

 

 IsCc_2019,倒过来得到flag:

flag{9102_cCsI}

Solve2

StegSolve隐写

a_good_idea

 参考

下载所给附件,将文件后缀改为zip得到一个压缩文件,里边有一个文档和两张图片,

用stegslove将这两张图片合并,得到一个散布红点的图片,

我们保存下来用Photoshop打开,将它的曝光度调到最高,得到一个二维码

QRresearch扫描二维码即可

NCTF{m1sc_1s_very_funny!!!}

2017_Dating_in_Singapore

参考

题目描述:

01081522291516170310172431-050607132027262728-0102030209162330-02091623020310090910172423-02010814222930-0605041118252627-0203040310172431-0102030108152229151617-04050604111825181920-0108152229303124171003-261912052028211407-04051213192625

结合附件日历,按日期勾画得到

HITB{CTFFUN} 

simple_transfer 

在文件目录打开终端,

foremost 文件名 -o a

 (a是生成文件夹的名字。)

打开a/pdf/00000662.pdf

HITB{b3d0e380e9c39352c667307d010775ca} 

can_has_stdio?

trainfuck编码解密

flag{esolangs_for_fun_and_profit} 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/89096
推荐阅读
相关标签
  

闽ICP备14008679号