Python 포렌식-메모리 및 포렌식

이 장에서는 다음의 도움으로 휘발성 메모리를 조사하는 데 중점을 둘 것입니다. Volatility, 다음 플랫폼에 적용 할 수있는 Python 기반 포렌식 프레임 워크 : AndroidLinux.

휘발성 메모리

휘발성 메모리는 시스템의 전원이 꺼 지거나 중단 될 때 내용이 지워지는 스토리지 유형입니다. RAM은 휘발성 메모리의 가장 좋은 예입니다. 즉, 하드 드라이브와 같은 비 휘발성 메모리에 저장되지 않은 문서를 작업 중일 때 컴퓨터의 전원이 꺼지면 모든 데이터가 손실됩니다.

일반적으로 휘발성 메모리 포렌식은 다른 포렌식 조사와 동일한 패턴을 따릅니다.

  • 조사 대상 선정
  • 법의학 데이터 수집
  • 법의학 분석

기본 volatility plugins Android 수집에 사용되는 RAM dump분석을 위해. 분석을 위해 RAM 덤프가 수집되면 RAM에서 맬웨어를 찾기 시작하는 것이 중요합니다.

YARA 규칙

YARA는 강력한 언어를 제공하고 Perl 기반 정규식과 호환되며 의심되는 파일 / 디렉토리 및 일치 문자열을 검사하는 데 사용되는 인기있는 도구입니다.

이 섹션에서는 패턴 매칭 구현을 기반으로 YARA를 사용하고이를 유틸리티 전력과 결합합니다. 전체 프로세스는 법의학 분석에 유용합니다.

다음 코드를 고려하십시오. 이 코드는 코드 추출에 도움이됩니다.

import operator
import os
import sys

sys.path.insert(0, os.getcwd())
import plyara.interp as interp

# Plyara is a script that lexes and parses a file consisting of one more Yara
# rules into a python dictionary representation.
if __name__ == '__main__': 
   file_to_analyze = sys.argv[1] 
   rulesDict = interp.parseString(open(file_to_analyze).read()) 
   authors = {} 
   imps = {} 
   meta_keys = {} 
   max_strings = [] 
   max_string_len = 0 
   tags = {} 
   rule_count = 0  

   for rule in rulesDict: 
      rule_count += 1  
   
   # Imports 
   if 'imports' in rule: 
      for imp in rule['imports']: 
         imp = imp.replace('"','') 
         
         if imp in imps: 
            imps[imp] += 1 
         else: 
            imps[imp] = 1  
   # Tags 
   if 'tags' in rule: 
      for tag in rule['tags']: 
         if tag in tags: 
            tags[tag] += 1 
         else: 
            tags[tag] = 1
            
   # Metadata 
   if 'metadata' in rule: 
      for key in rule['metadata']: 
         if key in meta_keys: 
            meta_keys[key] += 1
         else: 
            meta_keys[key] = 1 
         
         if key in ['Author', 'author']: 
            if rule['metadata'][key] in authors: 
               authors[rule['metadata'][key]] += 1 
            else: 
               authors[rule['metadata'][key]] = 1  

   #Strings 
   if 'strings' in rule: 
      for strr in rule['strings']: 
         if len(strr['value']) > max_string_len: 
            max_string_len = len(strr['value']) 
            max_strings = [(rule['rule_name'], strr['name'], strr['value'])] 
         elif len(strr['value']) == max_string_len: 
            max_strings.append((rule['rule_name'], strr['key'], strr['value']))  
   
   print("\nThe number of rules implemented" + str(rule_count))
   ordered_meta_keys = sorted(meta_keys.items(), key = operator.itemgetter(1),
      reverse = True)
   ordered_authors = sorted(authors.items(), key = operator.itemgetter(1), 
      reverse = True)
   ordered_imps = sorted(imps.items(), key = operator.itemgetter(1), reverse = True)
   ordered_tags = sorted(tags.items(), key = operator.itemgetter(1), reverse = True)

위의 코드는 다음 출력을 생성합니다.

구현 된 YARA 규칙의 수는 의심되는 파일을 더 잘 파악하는 데 도움이됩니다. 간접적으로 의심되는 파일 목록은 포렌식에 대한 적절한 정보를 수집하는 데 도움이됩니다.

다음은 github의 소스 코드입니다. https://github.com/radhikascs/Python_yara