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


Python idc.get_wide_byte方法代碼示例

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


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

示例1: nextGlobalString

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def nextGlobalString(self, ea):
        """Find the next possible address for a global string, given the beginning of the current global string.

        Args:
            ea (int): effective start address of the current global string.

        Return Value:
            Possible start address for the next global string
        """
        str_content = self.getAsciiString(ea)
        if str_content is None:
            return ea + self._global_alignment
        elif idc.get_wide_byte(ea + len(str_content)) != ord('\0'):
            return ea + max(self._global_alignment, pad(len(str_content), self._global_alignment))
        else:
            for offset in range(len(str_content) - 1, -1, -1):
                if chr(str_content[offset]) not in string.printable:
                    return ea + max(self._global_alignment, pad(offset, self._global_alignment))
        return ea + self._global_alignment 
開發者ID:CheckPointSW,項目名稱:Karta,代碼行數:21,代碼來源:strings.py

示例2: read_leb128

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def read_leb128(ea, signed):
  """ Read LEB128 encoded data
  """
  val = 0
  shift = 0
  while True:
    byte = idc.get_wide_byte(ea)
    val |= (byte & 0x7F) << shift
    shift += 7
    ea += 1
    if (byte & 0x80) == 0:
      break

    if shift > 64:
      DEBUG("Bad leb128 encoding at {0:x}".format(ea - shift/7))
      return idc.BADADDR

  if signed and (byte & 0x40):
    val -= (1<<shift)
  return val, ea 
開發者ID:lifting-bits,項目名稱:mcsema,代碼行數:22,代碼來源:util.py

示例3: get_native_function

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def get_native_function(self):

		ecx = idc.get_reg_value("ECX")
		esp = idc.get_reg_value("ESP")

		method_name = self.get_method_name(esp)
		
		if (idc.get_wide_byte(idc.get_wide_dword(ecx + 8) + 0x38) != 0):
			function = idc.get_wide_dword(idc.get_wide_dword(esp + 4) + 0x28)
		else:
			function = idc.get_wide_dword(idc.get_wide_dword(esp + 4) + 0x24)
		
		print("Resolved native function: 0x%x - %s" % (function, method_name))

		if ((method_name not in self.ignore and not self.ignore_all) or
			(method_name in self.debug_if_equals) or 
			(any(x for x in self.debug_if_contains if method_name is not None and x in method_name))):
			self.traced.append({"name": method_name, "ea": function, "type": "native", "hit": 0})
			idc.add_bpt(function) 
開發者ID:KasperskyLab,項目名稱:ActionScript3,代碼行數:21,代碼來源:klfdb.py

示例4: revert_patch

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def revert_patch(va, nr):
    """Unpatch the opcodes at @va, reverting them to their original value.

    Args:
        va (numbers.Integral): Address of the location of the patch to revert
        nr (numbers.Integral): Number of bytes to scan and revert

    Returns:
        bool: True if patched bytes were restored
    """
    ret = False

    orig = [ida_bytes.get_original_byte(va + i) for i in range(nr)]
    current = [idc.get_wide_byte(va + i) for i in range(nr)]

    for i in range(len(orig)):
        if orig[i] != current[i]:
            ret = True
            idaapi.patch_byte(va + i, orig[i])

    return ret 
開發者ID:fireeye,項目名稱:flare-ida,代碼行數:23,代碼來源:code_grafter.py

示例5: extractFunctionStartSample

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def extractFunctionStartSample(self, ea, code_type):
        """Extract features for a "function start" sample.

        Args:
            ea (int): effective address to be sampled
            code_type (int): code type of the wanted sample

        Return Value:
            feature set (list of byte values)
        """
        return list(map(lambda o: idc.get_wide_byte(ea + o), self._classifiers_start_offsets[code_type])) 
開發者ID:CheckPointSW,項目名稱:Karta,代碼行數:13,代碼來源:function.py

示例6: extractFunctionEndSample

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def extractFunctionEndSample(self, ea, code_type):
        """Extract features for a "function end" sample.

        Args:
            ea (int): effective address to be sampled
            code_type (int): code type of the wanted sample

        Return Value:
            feature set (list of byte values)
        """
        return list(map(lambda o: idc.get_wide_byte(ea + o), self._classifiers_end_offsets[code_type])) 
開發者ID:CheckPointSW,項目名稱:Karta,代碼行數:13,代碼來源:function.py

示例7: extractFunctionMixedSample

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def extractFunctionMixedSample(self, ea, code_type):
        """Extract features for a "function start/end" sample.

        Args:
            ea (int): effective address to be sampled
            code_type (int): code type of the wanted sample

        Return Value:
            feature set (list of byte values)
        """
        return list(map(lambda o: idc.get_wide_byte(ea + o), self._classifiers_mixed_offsets[code_type])) 
開發者ID:CheckPointSW,項目名稱:Karta,代碼行數:13,代碼來源:function.py

示例8: extractFunctionTypeSample

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def extractFunctionTypeSample(self, ea):
        """Extract features for a "code type" sample.

        Args:
            ea (int): effective address to be sampled

        Return Value:
            feature set (list of byte values)
        """
        return list(map(lambda o: idc.get_wide_byte(ea + o), self._classifier_type_offsets)) 
開發者ID:CheckPointSW,項目名稱:Karta,代碼行數:12,代碼來源:function.py

示例9: read_bytes_slowly

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def read_bytes_slowly(start, end):
  bytestr = []
  for i in xrange(start, end):
    if idc.has_value(idc.get_full_flags(i)):
      bt = idc.get_wide_byte(i)
      bytestr.append(chr(bt))
    else:
      bytestr.append("\x00")
  return "".join(bytestr) 
開發者ID:lifting-bits,項目名稱:mcsema,代碼行數:11,代碼來源:util.py

示例10: _getbytes

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def _getbytes(self, start, l=1):
        out = []
        for ad in range(l):
            offset = ad + start + self.base_address
            if not is_mapped(offset):
                raise IOError("not enough bytes")
            out.append(int_to_byte(get_wide_byte(offset)))
        return b''.join(out) 
開發者ID:cea-sec,項目名稱:miasm,代碼行數:10,代碼來源:bin_stream_ida.py

示例11: get_guid

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def get_guid(address):
    """get GUID located by address"""
    guid = []
    guid.append(idc.get_wide_dword(address))
    guid.append(idc.get_wide_word(address + 4))
    guid.append(idc.get_wide_word(address + 6))
    for addr in range(address + 8, address + 16, 1):
        guid.append(idc.get_wide_byte(addr))
    return guid 
開發者ID:yeggor,項目名稱:UEFI_RETool,代碼行數:11,代碼來源:utils.py

示例12: get_header_idb

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def get_header_idb():
    """get file header from idb"""
    if idc.get_segm_name(0) == 'HEADER':
        header = bytearray(
            [idc.get_wide_byte(ea) for ea in range(0, idc.get_segm_end(0))])
        return header
    return bytearray(b'') 
開發者ID:yeggor,項目名稱:UEFI_RETool,代碼行數:9,代碼來源:utils.py

示例13: getByte

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def getByte(self, ea):
        if idaapi.IDA_SDK_VERSION < 700:
            return idc.Byte(ea)
        else:
            return idc.get_wide_byte(ea) 
開發者ID:danielplohmann,項目名稱:apiscout,代碼行數:7,代碼來源:IdaProxy.py

示例14: read_byte

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def read_byte(insn=None):

        if (insn):
            b = insn.get_next_byte()
        else:
            b = idc.get_wide_byte(Reader.pos)
            Reader.pos += 1
        return b 
開發者ID:KasperskyLab,項目名稱:ActionScript3,代碼行數:10,代碼來源:as3.py

示例15: read_rect_size

# 需要導入模塊: import idc [as 別名]
# 或者: from idc import get_wide_byte [as 別名]
def read_rect_size(li):

    nbits = idc.get_wide_byte(8) >> 3
    return ((5 + 4*nbits) + 7) / 8 
開發者ID:KasperskyLab,項目名稱:ActionScript3,代碼行數:6,代碼來源:swf.py


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