Safety - Misc Mingchu love (Xiangyun cup 2021)

1, Title


2, WriteUp

[1]. Get compressed package

Directly modify the suffix of the document to zip or use binwalk -e [file name] in kalinux to obtain a compressed package

The contents are as follows

[2]. Tips

In_ There is a key in rels Txt, said to move forward bravely, indicating that the flag is likely to be in this directory


  • When you first use 360 compression, open love Zip, the file is too large to respond
  • The content opened with Bandizip is as follows. It can be found that it contains 129488 pictures,
    It can be found from the file size and CRC that there are only two types of pictures

  • Binary is represented by the size of the picture, the smaller picture 262 represents binary 0, and the larger picture 435 represents binary 1
  • Because a decimal system can be represented by an eight bit binary number, the binary of the first eight pictures is 01100100
    If you convert it to decimal, it is 100. If 100 is ascii, it is d
  • Similarly, the binary of the second group of 8 bits is 0110 0001, representing the character a
    In this way, the idea may be correct


[3]. Extract compressed package

Use python to create a script to extract the file name and file size in the compressed package. The reference article is python creates and reads compressed packages (zip type)

The general idea of the algorithm is as follows:

  • First extract all file names and file sizes in the compressed package
  • Because zipobj The file names in the namelist () file list are not sorted incrementally, so you need to extract the file name and file size into another list first
  • The first data is empty and needs to be deleted
  • There are many small lists in this large list. Each sub list represents a file. The first element of the sub list is the file name and the second element is the file size
  • Because the file name is in the format of out / name, you need to delete the suffix and out / string, keep the number, and then convert it to the number type
  • Use the sorted() function to increment the large list. If the elements of the list are all lists, it will be sorted incrementally by the first element of each sub list by default
  • The subsequent operation is to replace the file size with 0 and 1, convert every 8 bits of binary to decimal, and then convert from decimal to ASCII characters
  • Finally, write the character results to the file
# Little Author: Little Fox FM
import zipfile
lis = []
result = ""
data = ""
size = 1
with zipfile.ZipFile('love.zip', 'r') as zipobj: #Read compressed package
    for file_name in zipobj.namelist(): #Traversal name
        info = zipobj.getinfo(file_name)
        file_name = file_name.encode('cp437').decode('gbk')
        lis.append([file_name,info.file_size])
# print(lis)
del lis[0]
for i in range(len(lis)): #Processing file names and data
    lis[i][0] = lis[i][0].replace("out/","")
    lis[i][0] = lis[i][0].replace(".png", "")
    lis[i][0] = int(lis[i][0])
    if lis[i][1]==262:
        lis[i][1]='0'
    else:
        lis[i][1]='1'
# print(lis)
lis = sorted(lis)
# print(lis)
for i in range(len(lis)):
    data += lis[i][1] #data size
    if len(data)%8==0: #When all octets are binary
        result+=chr(int(data,2))
        data=""
with open("2.txt","w") as fp:
    fp.write(result)

After execution, a section of characters will be output to the file
This format is the base64 form of the picture



[4]. Picture conversion

Find an online website and convert base64 into the corresponding picture. Below the picture is the flag
base64 image online conversion tool - Webmaster tool

Keywords: Python security CTF MISC

Added by Thivya on Mon, 20 Dec 2021 03:34:43 +0200