當前位置: 首頁>>代碼示例>>Python>>正文


Python PE.peFromMemoryObject方法代碼示例

本文整理匯總了Python中PE.peFromMemoryObject方法的典型用法代碼示例。如果您正苦於以下問題:Python PE.peFromMemoryObject方法的具體用法?Python PE.peFromMemoryObject怎麽用?Python PE.peFromMemoryObject使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在PE的用法示例。


在下文中一共展示了PE.peFromMemoryObject方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: safeseh

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def safeseh(vdb, line):
    """
    Show the SafeSEH status of all the loaded DLLs or list the
    handlers for a particular dll by normalized name.

    Usage: safeseh [libname]
    """
    t = vdb.getTrace()
    libs = t.getMeta("LibraryBases")
    if len(line):
        base = libs.get(line)
        if base == None:
            vdb.vprint("Unknown library: %s" % line)
            return

        vdb.vprint("%s:" % line)

        try:
            p = PE.peFromMemoryObject(t, base)
        except Exception as e:
            vdb.vprint('Error: %s (0x%.8x) %s' % (line, base, e))
            return

        if p.IMAGE_LOAD_CONFIG != None:
            va = int(p.IMAGE_LOAD_CONFIG.SEHandlerTable)
            if va != 0:
                count = int(p.IMAGE_LOAD_CONFIG.SEHandlerCount)
                for h in t.readMemoryFormat(va, "<%dL" % count):
                    vdb.vprint("\t0x%.8x %s" % (base+h, vdb.reprPointer(base+h)))
                return
        vdb.vprint("None...")

    else:
        lnames = list(libs.keys())
        lnames.sort()
        for name in lnames:
            base = libs.get(name)
            try:
                p = PE.peFromMemoryObject(t, base)
            except Exception as e:
                vdb.vprint('Error: %s (0x%.8x) %s' % (name, base, e))
                continue

            enabled = False
            if p.IMAGE_LOAD_CONFIG != None:
                va = int(p.IMAGE_LOAD_CONFIG.SEHandlerTable)
                if va != 0:
                    enabled = True

            vdb.vprint("%16s\t%s" % (name, enabled))
開發者ID:bat-serjo,項目名稱:vivisect,代碼行數:52,代碼來源:windows.py

示例2: platformParseBinary

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
 def platformParseBinary(self, filename, baseaddr, normname):
     try:
         pe = PE.peFromMemoryObject(self, baseaddr)
         for rva, ord, name in pe.getExports():
             self.addSymbol(e_resolv.Symbol(name, baseaddr + rva, 0, normname))
     except Exception, e:
         print ("Error Parsing Binary (%s): %s" % (normname, e))
開發者ID:ssatanss,項目名稱:nightmare,代碼行數:9,代碼來源:vmware.py

示例3: showaslr

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def showaslr(vdb, base, libname):
    t = vdb.getTrace()
    try:
        p = PE.peFromMemoryObject(t, base)
    except Exception, e:
        vdb.vprint('Error: %s (0x%.8x) %s' % (libname, base, e))
        return
開發者ID:Fitblip,項目名稱:SocketSniff,代碼行數:9,代碼來源:windows.py

示例4: platformParseBinaryPe

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
    def platformParseBinaryPe(self, filename, baseaddr, normname):

        # If we're on windows, fake out the PE header and use dbghelp
        if False:
            # FIXME this code is stolen and should be a function!
            import vtrace.platforms.win32 as vt_win32
            fakepe = self.readMemory(baseaddr, 1024)
            tfile = tempfile.NamedTemporaryFile(delete=False)
            tfilename = tfile.name
            import ctypes
            pebuf = ctypes.create_string_buffer(fakepe)
            try:
                try:
                    tfile.write(fakepe)
                    tfile.close()
                    #parser = vt_win32.Win32SymbolParser(-1, tfilename, baseaddr)
                    parser = vt_win32.Win32SymbolParser(-1, None, ctypes.addressof(pebuf))
                    parser.parse()
                    parser.loadSymsIntoTrace(self, normname)
                finally:
                    os.unlink(tfilename)
            except Exception as e:
                print(e)

        else:
            pe = PE.peFromMemoryObject(self, baseaddr)
            for rva, ord, name in pe.getExports():
                self.addSymbol(e_resolv.Symbol(name, baseaddr+rva, 0, normname))
開發者ID:bat-serjo,項目名稱:vivisect,代碼行數:30,代碼來源:gdbstub.py

示例5: printIAT

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def printIAT(trace, fileName, verbose=False):
    #print "FileName: %s" % fileName
    
    libs = trace.getMeta("LibraryPaths")
    libBase = trace.getMeta("LibraryBases")
    #print "Lib Base: %s" % libBase
    #print "File Name: %s" % fileName

    base = libBase[fileName.lower()]

    p = PE.peFromMemoryObject(trace, base)

    IMAGE_DIRECTORY_ENTRY_IMPORT          =1   # Import Directory
    IMAGE_DIRECTORY_ENTRY_IAT            =12   # Import Address Table

    idir = p.IMAGE_NT_HEADERS.OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_IMPORT]
    poff = p.rvaToOffset(idir.VirtualAddress)
    psize = idir.Size
    # Once you have VirtualAddress BP on that and you can stop 
    # the program before any external call.
   
    p.parseImports()
    if verbose == True:
        for i in p.imports:
            print("Address: %s \tLibrary: %s \tFirstThunk: %s" % (hex(base+i[0]), i[1], i[2]))
    return base, p.imports
開發者ID:hoangcuongflp,項目名稱:vtrace_scripts,代碼行數:28,代碼來源:simpleAPI.py

示例6: showaslr

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def showaslr(vdb, base, libname):
    t = vdb.getTrace()
    p = PE.peFromMemoryObject(t, base)
    enabled = False
    c = p.IMAGE_NT_HEADERS.OptionalHeader.DllCharacteristics
    if c & IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE:
        enabled = True
    vdb.vprint("%16s\t%s" % (libname, enabled))
開發者ID:gdisneyleugers,項目名稱:vdebug,代碼行數:10,代碼來源:windows.py

示例7: loadSymbols

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def loadSymbols(trace, library, pdb=None):
  
  import PE as PE
  SYMBOLS_PATH = os.getenv('_NT_SYMBOL_PATH')
  if SYMBOLS_PATH == None:
    SYMBOLS_PATH = "C:\\Symbols"
  
  baseaddr = trace.getMeta('LibraryBases').get(library)

  if baseaddr == None:
    #raise Exception("%s library not loaded" % library)
    return 2
  else:
    pe = PE.peFromMemoryObject(trace, baseaddr)
    oh = pe.IMAGE_NT_HEADERS.OptionalHeader
    deb = pe.IMAGE_NT_HEADERS.OptionalHeader.DataDirectory[PE.IMAGE_DIRECTORY_ENTRY_DEBUG]
    virtaddr = deb.vsGetField('VirtualAddress')
    virtsize = deb.vsGetField('Size')
    poff = pe.rvaToOffset(virtaddr)

    if poff == 0:
      return 1

    imageDebugDirectory = pe.readStructAtOffset(poff, 'pe.IMAGE_DEBUG_DIRECTORY')
    addrRawData = imageDebugDirectory.vsGetField('AddressOfRawData')
    cvInfoPdb = pe.readStructAtOffset(addrRawData, 'pe.CV_INFO_PDB70')
    cvGuid = cvInfoPdb.vsGetField('GuidSignature')
    cvSig = cvInfoPdb.vsGetField('CvSignature')
    tmpGuid = cvGuid.vsGetFields()
    tmpGuid.sort()
    guid = bytearray(16)
    for elem in range(len(tmpGuid)):
      guid[elem] = tmpGuid[elem][1].vsGetValue()

    guid_str = str(guid).encode('hex')

    if pdb == None:
      sympath = os.getenv('_NT_SYMBOL_PATH')
      if sympath == None:
        # Guess that the symbols are in the typical spot for windows.
        sympath = SYMBOLS_PATH
        filename = sympath + "\\" + library + ".pdb\\" + guid_str + "1\\" + library + ".pdb"
    else:
      filename = pdb

    if os.path.isfile(filename):
      try:
        trace.parseWithDbgHelp(filename, baseaddr, library)
        return 0
      except:
        return 1
    else:
      return 1
開發者ID:hoangcuongflp,項目名稱:vtrace_scripts,代碼行數:55,代碼來源:loadSymbols.py

示例8: showaslr

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def showaslr(vdb, base, libname):
    t = vdb.getTrace()
    try:
        p = PE.peFromMemoryObject(t, base)
    except Exception as e:
        vdb.vprint('Error: %s (0x%.8x) %s' % (libname, base, e))
        return
    enabled = False
    c = p.IMAGE_NT_HEADERS.OptionalHeader.DllCharacteristics
    if c & IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE:
        enabled = True
    vdb.vprint("%16s\t%s" % (libname, enabled))
開發者ID:bat-serjo,項目名稱:vivisect,代碼行數:14,代碼來源:windows.py

示例9: platformParseBinary

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
    def platformParseBinary(self, filename, baseaddr, normname):
        try:
            pe = PE.peFromMemoryObject(self, baseaddr)
            vhash = e_symcache.symCacheHashFromPe(pe)

            symcache = self.symcache.getCacheSyms(vhash)
            if symcache == None:
                # Symbol type 0 for now...
                symcache = [ ( rva, 0, name, e_resolv.SYMSTOR_SYM_SYMBOL ) for rva,ord,name in pe.getExports() ]
                self.symcache.setCacheSyms( vhash, symcache )

            self.impSymCache( symcache, symfname=normname, baseaddr=baseaddr )

        except Exception as e:
            import traceback;traceback.print_exc()
            print(('Error Parsing Binary (%s): %s' % (normname, e)))
開發者ID:bat-serjo,項目名稱:vivisect,代碼行數:18,代碼來源:vmware.py

示例10: get_pe_obj

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def get_pe_obj(va):
    """
    Gets a vivisect PE object from a virtual address.

    Parameters:
      va : virtual address

    Returns: vivisect PE object
    """
    pu = flaredbg.ProcessUtils()
    va = pu.get_allocation_base(va)
    pbytes = pu.get_process_region_bytes(va)
    memobj = envi.memory.MemoryObject()
    memobj.addMemoryMap(va, envi.memory.MM_RWX, "", pbytes)
    pe = PE.peFromMemoryObject(memobj, va)

    return pe
開發者ID:SEC-squad,項目名稱:flare-dbg,代碼行數:19,代碼來源:utils.py

示例11: getOEP

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def getOEP(trace, filepath):
    base = None

    libs = trace.getMeta("LibraryPaths")
    for k, v in libs.iteritems():
        if filepath in v:
            base = k
    
    if base is None:
        p = PE.peFromFileName(filepath)
        base = p.IMAGE_NT_HEADERS.OptionalHeader.ImageBase
    else:
        p = PE.peFromMemoryObject(trace, base)

    ep = p.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint
    oep = base + ep
    return oep
開發者ID:hoangcuongflp,項目名稱:vtrace_scripts,代碼行數:19,代碼來源:simpleAPI.py

示例12: getIATLocation

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def getIATLocation(trace, fileName, verbose=False):
    #print "FileName: %s" % fileName
    
    libs = trace.getMeta("LibraryPaths")
    libBase = trace.getMeta("LibraryBases")
    #print "Lib Base: %s" % libBase
    #print "File Name: %s" % fileName

    base = libBase[fileName.lower()]

    p = PE.peFromMemoryObject(trace, base)

    IMAGE_DIRECTORY_ENTRY_IMPORT          =1   # Import Directory
    IMAGE_DIRECTORY_ENTRY_IAT            =12   # Import Address Table

    idir = p.IMAGE_NT_HEADERS.OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_IMPORT]
    poff = p.rvaToOffset(idir.VirtualAddress)
    psize = idir.Size
    # Once you have VirtualAddress BP on that and you can stop 
    # the program before any external call.
    return base, poff, psize
開發者ID:hoangcuongflp,項目名稱:vtrace_scripts,代碼行數:23,代碼來源:simpleAPI.py

示例13: hookIat

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def hookIat(trace, libname, implib='*', impfunc='*', fast=False):
    '''
    Hook the IAT with special "breakpoint" like objects which
    handle the memory access errors and document the calls...
    Set fast=True for them to be "Fastbreak" breakpoints.

    This returns a list of (name, bpid) tuples...

    Example:
        for impname, bpid in hookIat(t, 'ws2_32')
            t.setBreakpointCode(bpid, codestr)
            ...
    '''
    ret = []
    baseaddr = trace.parseExpression(libname)
    pe = PE.peFromMemoryObject(trace, baseaddr)
    origs = {}

    implib = implib.lower()
    impfunc = impfunc.lower()

    for rva, ilib, ifunc in pe.getImports():
        ilib = ilib.lower().replace('.dll', '')

        if ilib != implib and implib != '*':
            continue

        if ifunc.lower() != impfunc and impfunc!='*':
            continue

        iatname = '%s.%s.%s' % (libname, ilib, ifunc)
        wp = IatHook(baseaddr + rva, iatname)
        wp.fastbreak = fast
        bpid = trace.addBreakpoint(wp)
        ret.append( (iatname, bpid) )

    return ret
開發者ID:Fitblip,項目名稱:SocketSniff,代碼行數:39,代碼來源:iathook.py

示例14: pe

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
def pe(vdb, line):
    """
    Show extended info about loaded PE binaries.

    Usage: pe [opts] [<libname>...]
    -I      Show PE import files.
    -m      Toggle inmem/ondisk behavior (directly mapped DLLs)
    -N      Show full NT header
    -t      Show PE timestamp information
    -E      Show PE exports
    -S      Show PE sections
    -v      Show FileVersion from VS_VERSIONINFO
    -V      Show all keys from VS_VERSIONINFO

    NOTE: "libname" may be a vtrace expression:

    Examples:

        # Show the imports from a PE loaded at 0x777c0000
        pe -I 0x777c0000

        # Show the exports from advapi32.dll
        pe -E advapi32

        # Show the build timestamp of the PE pointed to by a register
        pe -t esi

    """
    #-v      Show PE version information
    argv = e_cli.splitargs(line)
    try:
        opts,args = getopt.getopt(argv, "EImNStvV")
    except Exception as e:
        return vdb.do_help('pe')

    inmem = True

    showsecs = False
    showvers = False
    showtime = False
    showimps = False
    shownthd = False
    showexps = False
    showvsin = False
    for opt,optarg in opts:
        if opt == '-I':
            showimps = True
        elif opt == '-t':
            showtime = True
        elif opt == '-v':
            showvers = True
        elif opt == '-V':
            showvsin = True
        elif opt == '-N':
            shownthd = True
        elif opt == '-m':
            inmem = False
        elif opt == '-S':
            showsecs = True
        elif opt == '-E':
            showexps = True

    t = vdb.trace
    bases = t.getMeta("LibraryBases")
    paths = t.getMeta("LibraryPaths")

    names = args
    if len(names) == 0:
        names = t.getNormalizedLibNames()

    names.sort()
    names = e_cli.columnstr(names)
    for libname in names:
        base = bases.get(libname.strip(), None)
        if base == None:
            base = vdb.trace.parseExpression(libname)
        path = paths.get(base, "unknown")

        try:
            pobj = PE.peFromMemoryObject(t, base)
        except Exception as e:
            vdb.vprint('Error: %s (0x%.8x) %s' % (libname, base, e))
            continue

        if showimps:
            ldeps = {}
            try:
                for rva,lname,fname in pobj.getImports():
                    ldeps[lname.lower()] = True
                lnames = list(ldeps.keys())
                lnames.sort()
                vdb.vprint('0x%.8x - %.30s' % (base, libname))
                for lname in lnames:
                    vdb.vprint('    %s' % lname)
            except Exception as e:
                vdb.vprint('Import Parser Error On %s: %s' % (libname, e))

        elif showvers:
            version = 'Unknown!'
            vs = pobj.getVS_VERSIONINFO()
#.........這裏部分代碼省略.........
開發者ID:bat-serjo,項目名稱:vivisect,代碼行數:103,代碼來源:windows.py

示例15: int

# 需要導入模塊: import PE [as 別名]
# 或者: from PE import peFromMemoryObject [as 別名]
        if p.IMAGE_LOAD_CONFIG != None:
            va = int(p.IMAGE_LOAD_CONFIG.SEHandlerTable)
            if va != 0:
                count = int(p.IMAGE_LOAD_CONFIG.SEHandlerCount)
                for h in t.readMemoryFormat(va, "<%dL" % count):
                    vdb.vprint("\t0x%.8x %s" % (base+h, vdb.reprPointer(base+h)))
                return
        vdb.vprint("None...")

    else:
        lnames = libs.keys()
        lnames.sort()
        for name in lnames:
            base = libs.get(name)
            try:
                p = PE.peFromMemoryObject(t, base)
            except Exception, e:
                vdb.vprint('Error: %s (0x%.8x) %s' % (name, base, e))
                continue

            enabled = False
            if p.IMAGE_LOAD_CONFIG != None:
                va = int(p.IMAGE_LOAD_CONFIG.SEHandlerTable)
                if va != 0:
                    enabled = True

            vdb.vprint("%16s\t%s" % (name, enabled))

def validate_heaps(db):
    """
    A simple routine that works like the built in windows
開發者ID:Fitblip,項目名稱:SocketSniff,代碼行數:33,代碼來源:windows.py


注:本文中的PE.peFromMemoryObject方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。