婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python反編譯教程之2048小游戲實例

python反編譯教程之2048小游戲實例

熱門標簽:正安縣地圖標注app 阿里電話機器人對話 400電話申請資格 螳螂科技外呼系統怎么用 qt百度地圖標注 地圖地圖標注有嘆號 舉辦過冬奧會的城市地圖標注 電銷機器人系統廠家鄭州 遼寧智能外呼系統需要多少錢

一.背景

一道ctf題,通過破解2048游戲獲得flag

游戲的規則很簡單,需要控制所有方塊向同一個方向運動,兩個相同數字方塊撞在一起之后合并成為他們的和,每次操作之后會隨機生成一個2或者4,最終得到一個“2048”的方塊就算勝利了。

二.工具準備

1.pyinstxtractor.py腳本用于反編譯python

腳本內容如下

from __future__ import print_function
import os
import struct
import marshal
import zlib
import sys
import imp
import types
from uuid import uuid4 as uniquename


class CTOCEntry:
 def __init__(self, position, cmprsdDataSize, uncmprsdDataSize, cmprsFlag, typeCmprsData, name):
 self.position = position
 self.cmprsdDataSize = cmprsdDataSize
 self.uncmprsdDataSize = uncmprsdDataSize
 self.cmprsFlag = cmprsFlag
 self.typeCmprsData = typeCmprsData
 self.name = name


class PyInstArchive:
 PYINST20_COOKIE_SIZE = 24  # For pyinstaller 2.0
 PYINST21_COOKIE_SIZE = 24 + 64 # For pyinstaller 2.1+
 MAGIC = b'MEI\014\013\012\013\016' # Magic number which identifies pyinstaller

 def __init__(self, path):
 self.filePath = path


 def open(self):
 try:
  self.fPtr = open(self.filePath, 'rb')
  self.fileSize = os.stat(self.filePath).st_size
 except:
  print('[*] Error: Could not open {0}'.format(self.filePath))
  return False
 return True


 def close(self):
 try:
  self.fPtr.close()
 except:
  pass


 def checkFile(self):
 print('[*] Processing {0}'.format(self.filePath))
 # Check if it is a 2.0 archive
 self.fPtr.seek(self.fileSize - self.PYINST20_COOKIE_SIZE, os.SEEK_SET)
 magicFromFile = self.fPtr.read(len(self.MAGIC))

 if magicFromFile == self.MAGIC:
  self.pyinstVer = 20 # pyinstaller 2.0
  print('[*] Pyinstaller version: 2.0')
  return True

 # Check for pyinstaller 2.1+ before bailing out
 self.fPtr.seek(self.fileSize - self.PYINST21_COOKIE_SIZE, os.SEEK_SET)
 magicFromFile = self.fPtr.read(len(self.MAGIC))

 if magicFromFile == self.MAGIC:
  print('[*] Pyinstaller version: 2.1+')
  self.pyinstVer = 21 # pyinstaller 2.1+
  return True

 print('[*] Error : Unsupported pyinstaller version or not a pyinstaller archive')
 return False


 def getCArchiveInfo(self):
 try:
  if self.pyinstVer == 20:
  self.fPtr.seek(self.fileSize - self.PYINST20_COOKIE_SIZE, os.SEEK_SET)

  # Read CArchive cookie
  (magic, lengthofPackage, toc, tocLen, self.pyver) = \

  struct.unpack('!8siiii', self.fPtr.read(self.PYINST20_COOKIE_SIZE))

  elif self.pyinstVer == 21:
  self.fPtr.seek(self.fileSize - self.PYINST21_COOKIE_SIZE, os.SEEK_SET)

  # Read CArchive cookie
  (magic, lengthofPackage, toc, tocLen, self.pyver, pylibname) = \

  struct.unpack('!8siiii64s', self.fPtr.read(self.PYINST21_COOKIE_SIZE))

 except:
  print('[*] Error : The file is not a pyinstaller archive')
  return False

 print('[*] Python version: {0}'.format(self.pyver))

 # Overlay is the data appended at the end of the PE
 self.overlaySize = lengthofPackage
 self.overlayPos = self.fileSize - self.overlaySize
 self.tableOfContentsPos = self.overlayPos + toc
 self.tableOfContentsSize = tocLen

 print('[*] Length of package: {0} bytes'.format(self.overlaySize))
 return True


 def parseTOC(self):
 # Go to the table of contents
 self.fPtr.seek(self.tableOfContentsPos, os.SEEK_SET)

 self.tocList = []
 parsedLen = 0

 # Parse table of contents
 while parsedLen  self.tableOfContentsSize:
  (entrySize, ) = struct.unpack('!i', self.fPtr.read(4))
  nameLen = struct.calcsize('!iiiiBc')

  (entryPos, cmprsdDataSize, uncmprsdDataSize, cmprsFlag, typeCmprsData, name) = \

  struct.unpack( \

  '!iiiBc{0}s'.format(entrySize - nameLen), \

  self.fPtr.read(entrySize - 4))

  name = name.decode('utf-8').rstrip('\0')
  if len(name) == 0:
  name = str(uniquename())
  print('[!] Warning: Found an unamed file in CArchive. Using random name {0}'.format(name))

  self.tocList.append( \

    CTOCEntry(   \

     self.overlayPos + entryPos, \

     cmprsdDataSize,  \

     uncmprsdDataSize,  \

     cmprsFlag,   \

     typeCmprsData,  \

     name   \

    ))

  parsedLen += entrySize
 print('[*] Found {0} files in CArchive'.format(len(self.tocList)))



 def extractFiles(self):
 print('[*] Beginning extraction...please standby')
 extractionDir = os.path.join(os.getcwd(), os.path.basename(self.filePath) + '_extracted')

 if not os.path.exists(extractionDir):
  os.mkdir(extractionDir)

 os.chdir(extractionDir)

 for entry in self.tocList:
  basePath = os.path.dirname(entry.name)
  if basePath != '':
  # Check if path exists, create if not
  if not os.path.exists(basePath):
   os.makedirs(basePath)

  self.fPtr.seek(entry.position, os.SEEK_SET)
  data = self.fPtr.read(entry.cmprsdDataSize)

  if entry.cmprsFlag == 1:
  data = zlib.decompress(data)
  # Malware may tamper with the uncompressed size
  # Comment out the assertion in such a case
  assert len(data) == entry.uncmprsdDataSize # Sanity Check

  with open(entry.name, 'wb') as f:
  f.write(data)

  if entry.typeCmprsData == b's':
  print('[+] Possible entry point: {0}'.format(entry.name))

  elif entry.typeCmprsData == b'z' or entry.typeCmprsData == b'Z':
  self._extractPyz(entry.name)


 def _extractPyz(self, name):
 dirName = name + '_extracted'
 # Create a directory for the contents of the pyz
 if not os.path.exists(dirName):
  os.mkdir(dirName)

 with open(name, 'rb') as f:
  pyzMagic = f.read(4)
  assert pyzMagic == b'PYZ\0' # Sanity Check

  pycHeader = f.read(4) # Python magic value

  if imp.get_magic() != pycHeader:
  print('[!] Warning: The script is running in a different python version than the one used to build the executable')
  print(' Run this script in Python{0} to prevent extraction errors(if any) during unmarshalling'.format(self.pyver))

  (tocPosition, ) = struct.unpack('!i', f.read(4))
  f.seek(tocPosition, os.SEEK_SET)

  try:
  toc = marshal.load(f)
  except:
  print('[!] Unmarshalling FAILED. Cannot extract {0}. Extracting remaining files.'.format(name))
  return

  print('[*] Found {0} files in PYZ archive'.format(len(toc)))

  # From pyinstaller 3.1+ toc is a list of tuples
  if type(toc) == list:
  toc = dict(toc)

  for key in toc.keys():
  (ispkg, pos, length) = toc[key]
  f.seek(pos, os.SEEK_SET)

  fileName = key
  try:
   # for Python > 3.3 some keys are bytes object some are str object
   fileName = key.decode('utf-8')
  except:
   pass

  # Make sure destination directory exists, ensuring we keep inside dirName
  destName = os.path.join(dirName, fileName.replace("..", "__"))
  destDirName = os.path.dirname(destName)
  if not os.path.exists(destDirName):
   os.makedirs(destDirName)

  try:
   data = f.read(length)
   data = zlib.decompress(data)
  except:
   print('[!] Error: Failed to decompress {0}, probably encrypted. Extracting as is.'.format(fileName))
   open(destName + '.pyc.encrypted', 'wb').write(data)
   continue

  with open(destName + '.pyc', 'wb') as pycFile:
   pycFile.write(pycHeader) # Write pyc magic
   pycFile.write(b'\0' * 4) # Write timestamp
   if self.pyver >= 33:
   pycFile.write(b'\0' * 4) # Size parameter added in Python 3.3
   pycFile.write(data)


def main():
 if len(sys.argv)  2:
 print('[*] Usage: pyinstxtractor.py filename>')

 else:
 arch = PyInstArchive(sys.argv[1])
 if arch.open():
  if arch.checkFile():
  if arch.getCArchiveInfo():
   arch.parseTOC()
   arch.extractFiles()
   arch.close()
   print('[*] Successfully extracted pyinstaller archive: {0}'.format(sys.argv[1]))
   print('')
   print('You can now use a python decompiler on the pyc files within the extracted directory')
   return

  arch.close()


if __name__ == '__main__':
 main()

2.winhex用于編輯16進制的軟件

壓縮包已上傳至博主資源,下載地址:https://blog.csdn.net/qq_50216270?type=download

三.反編譯

1.放置腳本

將腳本和待編譯的exe文件放在同一路徑下后,在路徑框中輸入cmd打開終端

2.運行腳本

在終端中輸入python后輸入腳本名和待反編譯exe文件名

編譯成功后會在原路徑生成如下文件夾

3.找到軟件名文件和struct文件

4.托入winhex進行對比

5.將struct多出的那一行復制到puzzle前面

6.更改其后綴為.pyc

7.安裝第三方庫uncompyle

8.python版本為3.8以下可以調用uncompyle

對應路徑終端輸入uncompyle6 puzzle.pyc > puzzle.py

9.python版本為3.8以上可以選擇在線工具(.pyc>.py)

https://tool.lu/pyc/

10.最后可以得到puzzle.py文件

代碼如下

#!/usr/bin/env python
# visit http://tool.lu/pyc/ for more information
import random
from tkinter import Frame, Label, CENTER
import logic
import constants as c

class GameGrid(Frame):
 
 def __init__(self):
 Frame.__init__(self)
 self.grid()
 self.master.title('C1CTF2019')
 self.master.bind('Key>', self.key_down)
 self.commands = {
  c.KEY_J: logic.down,
  c.KEY_K: logic.up,
  c.KEY_L: logic.right,
  c.KEY_H: logic.left,
  c.KEY_RIGHT_ALT: logic.right,
  c.KEY_LEFT_ALT: logic.left,
  c.KEY_DOWN_ALT: logic.down,
  c.KEY_UP_ALT: logic.up,
  c.KEY_RIGHT: logic.right,
  c.KEY_LEFT: logic.left,
  c.KEY_DOWN: logic.down,
  c.KEY_UP: logic.up }
 self.grid_cells = []
 self.init_grid()
 self.init_matrix()
 self.update_grid_cells()
 self.mainloop()

 
 def init_grid(self):
 background = Frame(self, c.BACKGROUND_COLOR_GAME, c.SIZE, c.SIZE, **('bg', 'width', 'height'))
 background.grid()
 for i in range(c.GRID_LEN):
  grid_row = []
  for j in range(c.GRID_LEN):
  cell = Frame(background, c.BACKGROUND_COLOR_CELL_EMPTY, c.SIZE / c.GRID_LEN, c.SIZE / c.GRID_LEN, **('bg', 'width', 'height'))
  cell.grid(i, j, c.GRID_PADDING, c.GRID_PADDING, **('row', 'column', 'padx', 'pady'))
  t = Label(cell, '', c.BACKGROUND_COLOR_CELL_EMPTY, CENTER, c.FONT, 5, 2, **('master', 'text', 'bg', 'justify', 'font', 'width', 'height'))
  t.grid()
  grid_row.append(t)
  
  self.grid_cells.append(grid_row)
 

 
 def gen(self):
 return random.randint(0, c.GRID_LEN - 1)

 
 def init_matrix(self):
 self.matrix = logic.new_game(4)
 self.history_matrixs = list()
 self.matrix = logic.add_two(self.matrix)
 self.matrix = logic.add_two(self.matrix)

 
 def update_grid_cells(self):
 for i in range(c.GRID_LEN):
  for j in range(c.GRID_LEN):
  new_number = self.matrix[i][j]
  if new_number == 0:
   self.grid_cells[i][j].configure('', c.BACKGROUND_COLOR_CELL_EMPTY, **('text', 'bg'))
   continue
  self.grid_cells[i][j].configure(str(new_number), c.BACKGROUND_COLOR_DICT[new_number], c.CELL_COLOR_DICT[new_number], **('text', 'bg', 'fg'))
  
 
 self.update_idletasks()

 
 def key_down(self, event):
 key = repr(event.char)
 if key == c.KEY_BACK and len(self.history_matrixs) > 1:
  self.matrix = self.history_matrixs.pop()
  self.update_grid_cells()
  print('back on step total step:', len(self.history_matrixs))
 elif key in self.commands:
  (self.matrix, done) = self.commands[repr(event.char)](self.matrix)
  if done:
  self.matrix = logic.add_two(self.matrix)
  self.history_matrixs.append(self.matrix)
  self.update_grid_cells()
  done = False
  if logic.game_state(self.matrix) == 'win':
   self.grid_cells[1][0].configure('C1CTF', c.BACKGROUND_COLOR_CELL_EMPTY, **('text', 'bg'))
   self.grid_cells[1][1].configure('{2048', c.BACKGROUND_COLOR_CELL_EMPTY, **('text', 'bg'))
   self.grid_cells[1][2].configure('_1s_', c.BACKGROUND_COLOR_CELL_EMPTY, **('text', 'bg'))
   self.grid_cells[1][3].configure('fun}', c.BACKGROUND_COLOR_CELL_EMPTY, **('text', 'bg'))
  if logic.game_state(self.matrix) == 'lose':
   self.grid_cells[1][1].configure('You', c.BACKGROUND_COLOR_CELL_EMPTY, **('text', 'bg'))
   self.grid_cells[1][2].configure('Lost!', c.BACKGROUND_COLOR_CELL_EMPTY, **('text', 'bg'))

 
 def generate_next(self):
 index = (self.gen(), self.gen())
 while self.matrix[index[0]][index[1]] != 0:
  index = (self.gen(), self.gen())
 self.matrix[index[0]][index[1]] = 2


gamegrid = GameGrid()

11.找到flag大公告成

總結

到此這篇關于python反編譯教程之2048小游戲實例的文章就介紹到這了,更多相關python反編譯2048小游戲內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python實現簡單2048小游戲
  • Python實現簡單的2048小游戲
  • 一步步教你用Python實現2048小游戲
  • 用Python寫一個無界面的2048小游戲
  • Python新手實現2048小游戲
  • python實現2048小游戲
  • 用Python手把手教你實現2048小游戲

標簽:信陽 隨州 昭通 淘寶好評回訪 合肥 阜新 濟源 興安盟

巨人網絡通訊聲明:本文標題《python反編譯教程之2048小游戲實例》,本文關鍵詞  python,反,編譯,教程,之,2048,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python反編譯教程之2048小游戲實例》相關的同類信息!
  • 本頁收集關于python反編譯教程之2048小游戲實例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美国产成人在线| 精品一区二区久久| 国产一区不卡精品| 精品1区2区在线观看| 久久精品噜噜噜成人av农村| 欧美一区二区三区四区在线观看| 亚洲1区2区3区4区| 日韩亚洲欧美中文三级| 美女一区二区久久| 久久免费偷拍视频| 国产91在线观看丝袜| 亚洲欧洲在线观看av| 欧美日韩免费观看一区二区三区| 日韩综合一区二区| 欧美国产一区二区| 在线国产电影不卡| 久久99久久久久久久久久久| 久久精品夜色噜噜亚洲a∨| 99久久婷婷国产综合精品电影| 一区二区三区在线不卡| 欧美一区二区三区视频免费播放| 国产精品一区二区果冻传媒| 亚洲精品欧美在线| 26uuuu精品一区二区| 91精品办公室少妇高潮对白| 久久99国产精品久久99| 成人免费在线视频| 精品福利av导航| 欧美在线|欧美| 国产一区二区三区免费播放| 亚洲免费视频中文字幕| 久久久久久免费| 欧美老肥妇做.爰bbww视频| 国产成人午夜片在线观看高清观看| 玉米视频成人免费看| 精品免费国产一区二区三区四区| 91美女福利视频| 国产毛片精品视频| 日韩电影网1区2区| 亚洲精品乱码久久久久久| 日韩欧美一级二级三级久久久| 99r精品视频| 精品亚洲aⅴ乱码一区二区三区| 亚洲乱码中文字幕| 国产精品久久久久久久久久久免费看| 欧美一区二区精美| 在线视频中文字幕一区二区| 国产成人无遮挡在线视频| 日本欧美一区二区| 日韩国产欧美在线观看| 夜夜嗨av一区二区三区网页| 中文字幕在线不卡一区二区三区 | 在线观看日韩精品| 成人中文字幕电影| 国产一区二区三区免费观看| 日本va欧美va瓶| 午夜免费久久看| 亚洲精品国产高清久久伦理二区| 国产精品美女一区二区在线观看| 欧美精品一区二区三区蜜桃 | 亚洲精品中文在线| 国产精品久久国产精麻豆99网站| 国产日韩欧美高清在线| 国产日本一区二区| 国产精品久久久久一区二区三区共 | 青椒成人免费视频| 婷婷夜色潮精品综合在线| 亚洲最快最全在线视频| 亚洲动漫第一页| 亚洲国产精品久久人人爱| 亚洲一区二区三区小说| 亚洲精品成人悠悠色影视| 一区二区三区小说| 性做久久久久久久免费看| 首页亚洲欧美制服丝腿| 麻豆精品久久久| 国产99久久精品| 97久久超碰精品国产| 欧美丝袜丝交足nylons| 日韩一区二区三区高清免费看看 | 免播放器亚洲一区| 久久精品理论片| 成人少妇影院yyyy| 91最新地址在线播放| 欧美性欧美巨大黑白大战| 欧美一区二区三区免费在线看 | 亚洲人成7777| 午夜久久久久久久久久一区二区| 青青草视频一区| 国产凹凸在线观看一区二区| 91浏览器入口在线观看| 欧美一区二区三区免费视频| 国产精品人人做人人爽人人添| 一区二区三区精品在线观看| 日产国产高清一区二区三区| 国产揄拍国内精品对白| av在线免费不卡| 91精品国产一区二区人妖| 国产亚洲精品久| 亚洲成人激情社区| 国产精品一色哟哟哟| 日本精品视频一区二区| 久久综合一区二区| 亚洲已满18点击进入久久| 久久国产生活片100| 一本色道亚洲精品aⅴ| 欧美电视剧免费全集观看| 依依成人综合视频| 国产在线精品一区在线观看麻豆| 91老司机福利 在线| 欧美精品一区二区久久久| 亚洲成人福利片| 99久久亚洲一区二区三区青草| 91精品国产一区二区人妖| 亚洲男人天堂av网| 国产剧情在线观看一区二区| 欧美日韩亚洲国产综合| 国产精品久久久久久亚洲伦| 麻豆91免费看| 欧美日韩不卡一区| 一区二区三区久久久| 成人久久18免费网站麻豆| 精品国产a毛片| 奇米影视在线99精品| 欧美性猛交xxxx乱大交退制版| 国产精品萝li| 国产精品一区二区在线看| 日韩美一区二区三区| 日韩电影一区二区三区| 欧美日韩一区二区不卡| 亚洲制服欧美中文字幕中文字幕| 不卡一区二区中文字幕| 国产清纯美女被跳蛋高潮一区二区久久w | 日韩一级二级三级精品视频| 亚洲1区2区3区视频| 欧美日韩一区 二区 三区 久久精品 | 一区二区三区四区五区视频在线观看| 成人午夜在线免费| 国产午夜精品在线观看| 精品一区二区免费在线观看| 精品久久99ma| 国产精品亚洲一区二区三区妖精 | jizzjizzjizz欧美| 久久久久久久久久看片| 国产成人精品1024| 国产精品久久久久久久久图文区 | 国产精品区一区二区三区| 99久久精品费精品国产一区二区| 中文乱码免费一区二区| av中文一区二区三区| 亚洲精品水蜜桃| 欧美性xxxxx极品少妇| 日韩福利视频导航| 久久九九影视网| 99久久久精品| 亚洲大尺度视频在线观看| 91精品国产品国语在线不卡| 亚洲成人av一区二区三区| 欧美一级二级三级乱码| 国产成人在线观看| 亚洲欧美日韩一区二区三区在线观看 | 国产片一区二区三区| 91啪亚洲精品| 国产伦精一区二区三区| 综合网在线视频| 欧美精品久久99久久在免费线| 久久99国产精品免费| 国产精品日韩成人| 在线观看亚洲精品视频| 麻豆精品在线播放| 国产精品色婷婷| 777色狠狠一区二区三区| 国产精品一级片| 一级精品视频在线观看宜春院| 日韩欧美一区二区久久婷婷| 成人av综合一区| 美女国产一区二区| 一区二区三区欧美日韩| 久久夜色精品一区| 色av成人天堂桃色av| 久久精品国产99国产| 一级女性全黄久久生活片免费| 欧美精品一区视频| 欧美日韩成人高清| 91日韩精品一区| 成人影视亚洲图片在线| 蜜桃一区二区三区在线观看| 亚洲精品高清在线观看| 久久久久久久精| 日韩欧美另类在线| 欧美人妇做爰xxxⅹ性高电影| 成人午夜伦理影院| 国产综合一区二区| 99久免费精品视频在线观看| 石原莉奈在线亚洲二区| 亚洲欧美精品午睡沙发| 国产精品国产自产拍在线| 久久影院视频免费| 精品久久久久久久久久久久久久久| 欧美日韩高清影院|