Python Forensics-빠른 가이드
Python은 전문 개발자와 초보 프로그래머 모두가 쉽게 이해할 수있는 쉽고 읽기 쉬운 코드가있는 범용 프로그래밍 언어입니다. Python은 모든 스택 프레임 워크에서 사용할 수있는 많은 유용한 라이브러리로 구성됩니다. 많은 실험실에서 예측을위한 기본 모델을 구축하고 실험을 실행하기 위해 Python을 사용합니다. 또한 중요한 운영 시스템을 제어하는 데 도움이됩니다.
Python에는 디지털 조사를 지원하고 조사 중에 증거의 무결성을 보호하는 기능이 내장되어 있습니다. 이 튜토리얼에서는 디지털 또는 계산 포렌식에서 Python을 적용하는 기본 개념을 설명합니다.
전산 법의학이란 무엇입니까?
Computational Forensics는 새로운 연구 영역입니다. 디지털 방법을 사용하여 법의학 문제를 해결합니다. 디지털 증거를 연구하기 위해 계산 과학을 사용합니다.
Computation Forensics에는 주로 도구 표시, 지문, 구두 지문, 문서 등과 같은 패턴 증거를 기반으로 조사 된 대상, 물질 및 프로세스가 포함 된 광범위한 주제가 포함되며 생리적 및 행동 패턴, DNA 및 디지털 증거도 포함됩니다. 범죄 현장.
다음 다이어그램은 Computational Forensics에서 다루는 광범위한 주제를 보여줍니다.
전산 법의학은 일부 알고리즘의 도움으로 구현됩니다. 이러한 알고리즘은 신호 및 이미지 처리, 컴퓨터 비전 및 그래픽에 사용됩니다. 또한 데이터 마이닝, 기계 학습 및 로봇 공학도 포함됩니다.
전산 법의학에는 다양한 디지털 방법이 포함됩니다. 법의학에서 모든 디지털 방법을 용이하게하는 가장 좋은 솔루션은 Python과 같은 범용 프로그래밍 언어를 사용하는 것입니다.
전산 법의학의 모든 활동에 Python이 필요하므로 단계별로 이동하여 설치 방법을 이해하겠습니다.
Step 1 − 이동 https://www.python.org/downloads/ 시스템에있는 운영 체제에 따라 Python 설치 파일을 다운로드합니다.
Step 2 − 패키지 / 설치 프로그램을 다운로드 한 후 exe 파일을 클릭하여 설치 프로세스를 시작합니다.
설치가 완료되면 다음 화면이 표시됩니다.
Step 3 − 다음 단계는 시스템에서 Python의 환경 변수를 설정하는 것입니다.
Step 4 − 환경 변수가 설정되면 명령 프롬프트에 "python"명령을 입력하여 설치 성공 여부를 확인합니다.
설치에 성공하면 콘솔에 다음 출력이 표시됩니다.
Python으로 작성된 코드는 C 또는 Pascal과 같은 다른 기존 프로그래밍 언어로 작성된 코드와 매우 유사합니다. 또한 Python의 구문은 C에서 많이 빌려 왔다고합니다. 여기에는 C 언어와 유사한 많은 Python 키워드가 포함됩니다.
Python에는 포렌식을 위해 데이터를 정확하게 추출하는 데 사용할 수있는 조건문 및 반복문이 포함되어 있습니다. 흐름 제어를 위해if/else, while및 상위 수준 for "반복 가능한"개체를 반복하는 문.
if a < b:
max = b
else:
max = a
Python이 다른 프로그래밍 언어와 다른 주요 영역은 dynamic typing. 개체를 참조하는 변수 이름을 사용합니다. 이러한 변수는 선언 할 필요가 없습니다.
데이터 유형
파이썬에는 문자열, 부울, 숫자 등과 같은 내장 데이터 유형 세트가 포함되어 있습니다. 또한 불변 유형도 있습니다. 이는 실행 중에 변경할 수없는 값을 의미합니다.
Python에는 또한 다음을 포함하는 복합 내장 데이터 유형이 있습니다. tuples 불변의 배열입니다. lists, 및 dictionaries해시 테이블입니다. 이들 모두는 증거를 수집하는 동안 가치를 저장하기 위해 디지털 포렌식에서 사용됩니다.
타사 모듈 및 패키지
Python은 모듈 및 / 또는 패키지 그룹을 지원합니다. third-party modules (단일 소스 파일에 함께 그룹화 된 관련 코드) 프로그램 구성에 사용됩니다.
Python에는 광범위한 표준 라이브러리가 포함되어 있으며, 이는 전산 법의학에서 인기가 높은 주된 이유 중 하나입니다.
Python 코드의 수명주기
처음에는 Python 코드를 실행할 때 인터프리터가 코드에서 구문 오류를 확인합니다. 인터프리터가 구문 오류를 발견하면 즉시 오류 메시지로 표시됩니다.
구문 오류가 없으면 코드가 컴파일되어 bytecode PVM (Python Virtual Machine)으로 전송됩니다.
PVM은 런타임 또는 논리적 오류에 대해 바이트 코드를 확인합니다. PVM이 런타임 오류를 발견하면 즉시 오류 메시지로보고됩니다.
바이트 코드에 오류가 없으면 코드가 처리되고 출력이 표시됩니다.
다음 그림은 Python 코드를 먼저 해석하여 바이트 코드를 생성하는 방법과 바이트 코드가 PVM에서 처리되어 출력을 생성하는 방법을 그래픽 방식으로 보여줍니다.
Forensic 지침에 따라 애플리케이션을 만들려면 명명 규칙과 패턴을 이해하고 따르는 것이 중요합니다.
명명 규칙
Python 포렌식 애플리케이션을 개발하는 동안 따라야 할 규칙과 규칙이 다음 표에 설명되어 있습니다.
상수 | 밑줄 구분이있는 대문자 | 높은 온도 |
지역 변수 이름 | 울퉁불퉁 한 대문자가있는 소문자 (밑줄은 선택 사항) | currentTemperature |
전역 변수 이름 | 울퉁불퉁 한 대문자가있는 접두사 gl 소문자 (밑줄은 선택 사항) | gl_maximumRecordedTemperature |
기능 명 | 울퉁불퉁 한 대문자가있는 대문자 (선택 사항 인 밑줄) | ConvertFarenheitToCentigrade (...) |
개체 이름 | 울퉁불퉁 한 대문자로 접두사 ob_ 소문자 | ob_myTempRecorder |
기준 치수 | 밑줄 다음에 울퉁불퉁 한 대문자가있는 소문자 | _tempRecorder |
클래스 이름 | 접두사 class_ 다음 울퉁불퉁 한 대문자 및 간결하게 | class_TempSystem |
Computational Forensics에서 명명 규칙의 중요성을 이해하는 시나리오를 살펴 보겠습니다. 데이터 암호화에 일반적으로 사용되는 해싱 알고리즘이 있다고 가정합니다. 단방향 해싱 알고리즘은 입력을 이진 데이터 스트림으로 사용합니다. 이것은 암호, 파일, 바이너리 데이터 또는 디지털 데이터 일 수 있습니다. 해싱 알고리즘은 다음을 생성합니다.message digest (md) 입력에서 수신 된 데이터와 관련하여.
주어진 메시지 다이제스트를 생성 할 새로운 바이너리 입력을 만드는 것은 사실상 불가능합니다. 바이너리 입력 데이터의 단일 비트라도 변경되면 이전 메시지와 다른 고유 한 메시지를 생성합니다.
예
위에서 언급 한 규칙을 따르는 다음 샘플 프로그램을 살펴보십시오.
import sys, string, md5 # necessary libraries
print "Please enter your full name"
line = sys.stdin.readline()
line = line.rstrip()
md5_object = md5.new()
md5_object.update(line)
print md5_object.hexdigest() # Prints the output as per the hashing algorithm i.e. md5
exit
위의 프로그램은 다음과 같은 출력을 생성합니다.
이 프로그램에서 Python 스크립트는 입력 (전체 이름)을 받아들이고 md5 해싱 알고리즘에 따라이를 변환합니다. 필요한 경우 데이터를 암호화하고 정보를 보호합니다. 법의학 지침에 따라 증거의 이름 또는 기타 증거를이 패턴으로 보호 할 수 있습니다.
ㅏ hash function많은 양의 데이터를 지정된 길이의 고정 값으로 매핑하는 함수로 정의됩니다. 이 함수는 동일한 입력이 실제로 해시 합계로 정의되는 동일한 출력을 생성하도록합니다. 해시 합계에는 특정 정보가있는 특성이 포함됩니다.
이 기능은 되돌리기가 사실상 불가능합니다. 따라서 무차별 대입 공격과 같은 타사 공격은 사실상 불가능합니다. 또한 이런 종류의 알고리즘을one-way cryptographic algorithm.
이상적인 암호화 해시 함수에는 네 가지 주요 속성이 있습니다.
- 주어진 입력에 대한 해시 값을 쉽게 계산할 수 있어야합니다.
- 해시에서 원래 입력을 생성하는 것은 실행 불가능해야합니다.
- 해시를 변경하지 않고 입력을 수정하는 것은 실행 불가능해야합니다.
- 동일한 해시를 가진 두 개의 다른 입력을 찾는 것은 실행 불가능해야합니다.
예
16 진수 형식의 문자를 사용하여 암호를 일치시키는 데 도움이되는 다음 예제를 고려하십시오.
import uuid
import hashlib
def hash_password(password):
# userid is used to generate a random number
salt = uuid.uuid4().hex #salt is stored in hexadecimal value
return hashlib.sha256(salt.encode() + password.encode()).hexdigest() + ':' + salt
def check_password(hashed_password, user_password):
# hexdigest is used as an algorithm for storing passwords
password, salt = hashed_password.split(':')
return password == hashlib.sha256(salt.encode()
+ user_password.encode()).hexdigest()
new_pass = raw_input('Please enter required password ')
hashed_password = hash_password(new_pass)
print('The string to store in the db is: ' + hashed_password)
old_pass = raw_input('Re-enter new password ')
if check_password(hashed_password, old_pass):
print('Yuppie!! You entered the right password')
else:
print('Oops! I am sorry but the password does not match')
순서도
다음 순서도를 사용하여이 프로그램의 논리를 설명했습니다.
산출
우리 코드는 다음과 같은 출력을 생성합니다.
두 번 입력 한 비밀번호는 해시 기능과 일치합니다. 이렇게하면 두 번 입력 한 암호가 정확하여 유용한 데이터를 수집하고 암호화 된 형식으로 저장하는 데 도움이됩니다.
이 장에서는 분석 및 증거 과정에서 가져온 텍스트 데이터 크래킹에 대해 알아 봅니다.
암호화의 일반 텍스트는 메시지와 같이 일반적으로 읽을 수있는 텍스트입니다. 반면에 암호 텍스트는 일반 텍스트를 입력 한 후 가져온 암호화 알고리즘의 출력입니다.
일반 텍스트 메시지를 암호 텍스트로 변환하는 방법에 대한 간단한 알고리즘은 적으로부터 일반 텍스트를 비밀로 유지하기 위해 Julius Caesar가 발명 한 Caesar 암호입니다. 이 암호는 메시지의 모든 문자를 알파벳에서 세 자리 씩 "앞으로"이동시키는 것을 포함합니다.
다음은 데모 그림입니다.
a → D
b → E
c → F
....
w → Z
x → A
y → B
z → C
예
Python 스크립트를 실행할 때 입력 된 메시지는 패턴 증거에 사용되는 모든 문자 가능성을 제공합니다.
사용되는 패턴 증거의 유형은 다음과 같습니다.
- 타이어 트랙 및 마크
- Impressions
- Fingerprints
모든 생체 인식 데이터는 벡터 데이터로 구성되며, 완전한 증거를 수집하기 위해 크랙해야합니다.
다음 Python 코드는 일반 텍스트에서 암호 텍스트를 생성하는 방법을 보여줍니다.
import sys
def decrypt(k,cipher):
plaintext = ''
for each in cipher:
p = (ord(each)-k) % 126
if p < 32:
p+=95
plaintext += chr(p)
print plaintext
def main(argv):
if (len(sys.argv) != 1):
sys.exit('Usage: cracking.py')
cipher = raw_input('Enter message: ')
for i in range(1,95,1):
decrypt(i,cipher)
if __name__ == "__main__":
main(sys.argv[1:])
산출
이제이 코드의 출력을 확인하십시오. 간단한 텍스트 "Radhika"를 입력하면 프로그램은 다음과 같은 암호 텍스트를 생성합니다.
Virtualization서버, 워크 스테이션, 네트워크 및 스토리지와 같은 IT 시스템을 에뮬레이션하는 프로세스입니다. 운영 체제, 서버, 저장 장치 또는 네트워크 프로세스의 실제 버전이 아닌 가상의 생성 일뿐입니다.
가상 하드웨어의 에뮬레이션에 도움이되는 주요 구성 요소는 hyper-visor.
다음 그림은 사용되는 두 가지 주요 시스템 가상화 유형을 설명합니다.
가상화는 여러 가지 방식으로 전산 법의학에서 사용되었습니다. 워크 스테이션을 각 조사에 대해 검증 된 상태로 사용할 수 있도록 분석가에게 도움이됩니다. 특히 가상 머신에 보조 드라이브로 드라이브의 dd 이미지를 첨부하여 데이터 복구가 가능합니다. 증거를 수집하기 위해 동일한 머신을 복구 소프트웨어로 사용할 수 있습니다.
다음 예제는 Python 프로그래밍 언어를 사용하여 가상 머신 생성을 이해하는 데 도움이됩니다.
Step 1 − 가상 머신의 이름을 'dummy1'로 지정합니다.
모든 가상 머신에는 최소 용량 (바이트)으로 512MB의 메모리가 있어야합니다.
vm_memory = 512 * 1024 * 1024
Step 2 − 가상 머신은 계산 된 기본 클러스터에 연결되어야합니다.
vm_cluster = api.clusters.get(name = "Default")
Step 3 − 가상 머신은 가상 하드 디스크 드라이브에서 부팅해야합니다.
vm_os = params.OperatingSystem(boot = [params.Boot(dev = "hd")])
모든 옵션은 가상 머신에 vms 컬렉션의 add 메소드를 사용하기 전에 가상 머신 매개 변수 객체로 결합됩니다.
예
다음은 가상 머신을 추가하기위한 완전한 Python 스크립트입니다.
from ovirtsdk.api import API #importing API library
from ovirtsdk.xml import params
try: #Api credentials is required for virtual machine
api = API(url = "https://HOST",
username = "Radhika",
password = "a@123",
ca_file = "ca.crt")
vm_name = "dummy1"
vm_memory = 512 * 1024 * 1024 #calculating the memory in bytes
vm_cluster = api.clusters.get(name = "Default")
vm_template = api.templates.get(name = "Blank")
#assigning the parameters to operating system
vm_os = params.OperatingSystem(boot = [params.Boot(dev = "hd")])
vm_params = params.VM(name = vm_name,
memory = vm_memory,
cluster = vm_cluster,
template = vm_template
os = vm_os)
try:
api.vms.add(vm = vm_params)
print "Virtual machine '%s' added." % vm_name #output if it is successful.
except Exception as ex:
print "Adding virtual machine '%s' failed: %s" % (vm_name, ex)
api.disconnect()
except Exception as ex:
print "Unexpected error: %s" % ex
산출
우리 코드는 다음과 같은 출력을 생성합니다.
현대 네트워크 환경의 시나리오는 많은 어려움으로 인해 조사가 어려울 수 있습니다. 이는 침해 지원에 대응하거나, 내부자 활동을 조사하거나, 취약성과 관련된 평가를 수행하거나, 규정 준수를 검증 할 때 발생할 수 있습니다.
네트워크 프로그래밍의 개념
다음 정의는 네트워크 프로그래밍에 사용됩니다.
Client − 클라이언트는 개인용 컴퓨터 및 워크 스테이션에서 실행되는 네트워크 프로그래밍의 클라이언트-서버 아키텍처의 일부입니다.
Server − 서버는 동일한 컴퓨터 나 다른 컴퓨터에있는 다른 컴퓨터 프로그램에 서비스를 제공하는 클라이언트-서버 아키텍처의 일부입니다.
WebSockets− WebSocket은 지속적인 TCP 연결을 통해 실행되는 클라이언트와 서버 간의 프로토콜을 제공합니다. 이를 통해 TCP 소켓 연결간에 양방향 메시지를 동시에 전송할 수 있습니다.
WebSocket은 서버가 클라이언트에 정보를 보낼 수 있도록하는 많은 다른 기술을 따릅니다. 업그레이드 헤더를 핸드 쉐이킹하는 것 외에 WebSockets는 HTTP와 독립적입니다.
이러한 프로토콜은 제 3 자 사용자가 보내거나받는 정보를 확인하는 데 사용됩니다. 암호화는 메시지 보안에 사용되는 방법 중 하나이므로 메시지가 전송 된 채널을 보호하는 것도 중요합니다.
클라이언트가 사용하는 다음 Python 프로그램을 고려하십시오. handshaking.
예
# client.py
import socket
# create a socket object
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# get local machine name
host = socket.gethostname()
port = 8080
# connection to hostname on the port.
s.connect((host, port))
# Receive no more than 1024 bytes
tm = s.recv(1024)
print("The client is waiting for connection")
s.close()
산출
다음 출력을 생성합니다-
통신 채널 요청을 수락하는 서버에는 다음 스크립트가 포함됩니다.
# server.py
import socket
import time
# create a socket object
serversocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# get local machine name
host = socket.gethostname()
port = 8080
# bind to the port
serversocket.bind((host, port))
# queue up to 5 requests
serversocket.listen(5)
while True:
# establish a connection
clientsocket,addr = serversocket.accept()
print("Got a connection from %s" % str(addr))
currentTime = time.ctime(time.time()) + "\r\n"
clientsocket.send(currentTime.encode('ascii'))
clientsocket.close()
Python 프로그래밍의 도움으로 생성 된 클라이언트와 서버는 호스트 번호를 수신합니다. 처음에 클라이언트는 호스트 번호로 전송 된 데이터에 대해 서버에 요청을 보내고 서버는 요청을 수락하고 즉시 응답을 보냅니다. 이런 식으로 우리는 안전한 통신 채널을 가질 수 있습니다.
Python 프로그램의 모듈은 코드 구성에 도움이됩니다. 관련 코드를 단일 모듈로 그룹화하는 데 도움이되므로 이해하고 사용하기가 더 쉽습니다. 바인딩 및 참조에 사용할 수있는 임의로 이름이 지정된 값을 포함합니다. 간단히 말해서 모듈은 함수, 클래스 및 변수를 포함하는 Python 코드로 구성된 파일입니다.
모듈 (파일)에 대한 Python 코드는 .py 필요할 때 컴파일되는 확장.
Example
def print_hello_func( par ):
print "Hello : ", par
return
수입 명세서
Python 소스 파일은 다음을 실행하여 모듈로 사용할 수 있습니다. import다른 패키지 또는 타사 라이브러리를 가져 오는 문. 사용되는 구문은 다음과 같습니다-
import module1[, module2[,... moduleN]
Python 인터프리터가 import 문을 만나면 검색 경로에있는 지정된 모듈을 가져옵니다.
Example
다음 예를 고려하십시오.
#!/usr/bin/python
# Import module support
import support
# Now you can call defined function that module as follows
support.print_func("Radhika")
다음 출력을 생성합니다-
모듈은 Python 코드로 가져온 횟수에 관계없이 한 번만로드됩니다.
From ... import 문
From속성은 모듈에서 현재 네임 스페이스로 특정 속성을 가져 오는 데 도움이됩니다. 구문은 다음과 같습니다.
from modname import name1[, name2[, ... nameN]]
Example
함수를 가져 오려면 fibonacci 모듈에서 fib, 다음 문장을 사용하십시오.
from fib import fibonacci
모듈 찾기
모듈을 가져올 때 Python 인터프리터는 다음 시퀀스를 검색합니다.
현재 디렉토리.
모듈이 존재하지 않으면 Python은 쉘 변수 PYTHONPATH에서 각 디렉토리를 검색합니다.
셸 변수 위치가 실패하면 Python은 기본 경로를 확인합니다.
전산 법의학은 Python 모듈과 타사 모듈을 사용하여 정보를 얻고 증거를 더 쉽게 추출합니다. 추가 장에서는 필요한 출력을 얻기 위해 모듈 구현에 중점을 둡니다.
DShell
DshellPython 기반 네트워크 포렌식 분석 툴킷입니다. 이 툴킷은 미 육군 연구소에서 개발했습니다. 이 오픈 소스 툴킷의 출시는 2014 년이었습니다.이 툴킷의 주요 초점은 포렌식 조사를 쉽게 수행하는 것입니다.
툴킷은 다음 표에 나열된 수많은 디코더로 구성됩니다.
Sr. 아니. | 디코더 이름 및 설명 |
---|---|
1 | dns DNS 관련 쿼리를 추출하는 데 사용됩니다. |
2 | reservedips DNS 문제에 대한 솔루션 식별 |
삼 | large-flows 넷 플로우 목록 |
4 | rip-http HTTP 트래픽에서 파일을 추출하는 데 사용됩니다. |
5 | Protocols 비표준 프로토콜 식별에 사용 |
미 육군 연구소는 다음 링크에서 GitHub의 복제 저장소를 유지했습니다.
https://github.com/USArmyResearchLab/Dshell
클론은 스크립트로 구성됩니다. install-ubuntu.py () 이 툴킷 설치에 사용됩니다.
설치에 성공하면 나중에 사용할 실행 파일과 종속성이 자동으로 빌드됩니다.
종속성은 다음과 같습니다-
dependencies = {
"Crypto": "crypto",
"dpkt": "dpkt",
"IPy": "ipy",
"pcap": "pypcap"
}
이 툴킷은 일반적으로 인시던트 또는 경고 중에 기록되는 pcap (패킷 캡처) 파일에 대해 사용할 수 있습니다. 이러한 pcap 파일은 Linux 플랫폼의 libpcap 또는 Windows 플랫폼의 WinPcap에 의해 생성됩니다.
Scapy
Scapy는 네트워크 트래픽을 분석하고 조작하는 데 사용되는 Python 기반 도구입니다. 다음은 Scapy 툴킷에 대한 링크입니다.
http://www.secdev.org/projects/scapy/
이 툴킷은 패킷 조작을 분석하는 데 사용됩니다. 다양한 프로토콜의 패킷을 디코딩하고 캡처 할 수 있습니다. Scapy는 네트워크 트래픽에 대한 자세한 설명을 조사자에게 제공한다는 점에서 Dshell 툴킷과 다릅니다. 이러한 설명은 실시간으로 기록되었습니다.
Scapy는 타사 도구 또는 OS 지문을 사용하여 플롯 할 수 있습니다.
다음 예를 고려하십시오.
import scapy, GeoIP #Imports scapy and GeoIP toolkit
from scapy import *
geoIp = GeoIP.new(GeoIP.GEOIP_MEMORY_CACHE) #locates the Geo IP address
def locatePackage(pkg):
src = pkg.getlayer(IP).src #gets source IP address
dst = pkg.getlayer(IP).dst #gets destination IP address
srcCountry = geoIp.country_code_by_addr(src) #gets Country details of source
dstCountry = geoIp.country_code_by_addr(dst) #gets country details of destination
print src+"("+srcCountry+") >> "+dst+"("+dstCountry+")\n"
이 스크립트는 서로 통신하는 네트워크 패킷의 국가 세부 정보에 대한 자세한 설명을 제공합니다.
위의 스크립트는 다음 출력을 생성합니다.
Searching확실히 법의학 조사의 기둥 중 하나입니다. 오늘날 수색은 증거를 실행하는 수사관만큼만 좋다.
메시지에서 키워드를 검색하는 것은 키워드의 도움으로 증거를 검색 할 때 법의학에서 중요한 역할을합니다. 특정 파일에서 검색 할 내용과 삭제 된 파일의 내용에 대한 지식은 경험과 지식이 모두 필요합니다.
Python에는 표준 라이브러리 모듈이있는 다양한 내장 메커니즘이 있습니다. search조작. 기본적으로 수사관은 검색 작업을 사용하여 "누가", "무엇", "어디", "언제"등과 같은 질문에 대한 답을 찾습니다.
예
다음 예제에서는 두 개의 문자열을 선언 한 다음 find 함수를 사용하여 첫 번째 문자열에 두 번째 문자열이 포함되어 있는지 여부를 확인했습니다.
# Searching a particular word from a message
str1 = "This is a string example for Computational forensics of gathering evidence!";
str2 = "string";
print str1.find(str2)
print str1.find(str2, 10)
print str1.find(str2, 40)
위의 스크립트는 다음 출력을 생성합니다.
“find”Python의 함수는 메시지 나 단락에서 키워드를 검색하는 데 도움이됩니다. 이것은 적절한 증거를 수집하는 데 중요합니다.
Indexing실제로 조사관이 파일을 완전히 살펴보고 잠재적 인 증거를 수집 할 수 있도록합니다. 증거는 파일, 디스크 이미지, 메모리 스냅 샷 또는 네트워크 추적에 포함될 수 있습니다.
인덱싱은 다음과 같이 시간이 많이 걸리는 작업의 시간을 줄이는 데 도움이됩니다. keyword searching. 법의학 조사에는 색인을 사용하여 키워드를 빠르게 찾는 대화 형 검색 단계도 포함됩니다.
인덱싱은 또한 정렬 된 목록에 키워드를 나열하는 데 도움이됩니다.
예
다음 예는 사용 방법을 보여줍니다. indexing 파이썬에서.
aList = [123, 'sample', 'zara', 'indexing'];
print "Index for sample : ", aList.index('sample')
print "Index for indexing : ", aList.index('indexing')
str1 = "This is sample message for forensic investigation indexing";
str2 = "sample";
print "Index of the character keyword found is "
print str1.index(str2)
위의 스크립트는 다음 출력을 생성합니다.
사용 가능한 리소스에서 귀중한 정보를 추출하는 것은 디지털 포렌식의 중요한 부분입니다. 사용 가능한 모든 정보에 액세스하는 것은 적절한 증거를 검색하는 데 도움이되므로 조사 프로세스에 필수적입니다.
데이터를 포함하는 리소스는 데이터베이스와 같은 단순한 데이터 구조이거나 JPEG 이미지와 같은 복잡한 데이터 구조 일 수 있습니다. 간단한 데이터 구조는 간단한 데스크톱 도구를 사용하여 쉽게 액세스 할 수 있으며 복잡한 데이터 구조에서 정보를 추출하려면 정교한 프로그래밍 도구가 필요합니다.
Python 이미징 라이브러리
Python Imaging Library (PIL)는 Python 인터프리터에 이미지 처리 기능을 추가합니다. 이 라이브러리는 다양한 파일 형식을 지원하며 강력한 이미지 처리 및 그래픽 기능을 제공합니다. 다음에서 PIL의 소스 파일을 다운로드 할 수 있습니다.http://www.pythonware.com/products/pil/
다음 그림은 PIL의 이미지 (복잡한 데이터 구조)에서 데이터를 추출하는 전체 흐름도를 보여줍니다.
예
이제 실제로 어떻게 작동하는지 이해하는 프로그래밍 예제를 살펴 보겠습니다.
Step 1 − 정보를 추출해야하는 위치에서 다음 이미지가 있다고 가정합니다.
Step 2− PIL을 사용하여이 이미지를 열면 먼저 다양한 픽셀 값을 포함하는 증거를 추출하는 데 필요한 포인트가 표시됩니다. 다음은 이미지를 열고 픽셀 값을 기록하는 코드입니다.
from PIL import Image
im = Image.open('Capture.jpeg', 'r')
pix_val = list(im.getdata())
pix_val_flat = [x for sets in pix_val for x in sets]
print pix_val_flat
Step 3 − 우리 코드는 이미지의 픽셀 값을 추출한 후 다음 출력을 생성합니다.
제공된 출력은 RGB 조합의 픽셀 값을 나타내며 증거에 필요한 데이터를 더 잘 보여줍니다. 가져온 데이터는 배열 형식으로 표시됩니다.
하드 디스크와 같은 표준 컴퓨터 하드웨어에 대한 법의학 조사 및 분석은 안정적인 분야로 발전했으며 비표준 하드웨어 또는 일시적인 증거를 분석하는 기술의 도움을받습니다.
스마트 폰은 디지털 조사에 점점 더 많이 사용되고 있지만 여전히 비표준으로 간주됩니다.
법의학 분석
법의학 조사는 스마트 폰에서 수신 된 전화 또는 전화 건 번호와 같은 데이터를 검색합니다. 여기에는 문자 메시지, 사진 또는 기타 유죄 증거가 포함될 수 있습니다. 대부분의 스마트 폰에는 암호 또는 영숫자를 사용하는 화면 잠금 기능이 있습니다.
여기에서는 Python이 화면 잠금 암호를 해독하여 스마트 폰에서 데이터를 검색하는 데 어떻게 도움이되는지 보여주는 예제를 살펴 보겠습니다.
수동 검사
Android는 PIN 번호 또는 영숫자 비밀번호로 비밀번호 잠금을 지원합니다. 두 암호문의 제한은 4 ~ 16 자리 숫자 또는 문자 여야합니다. 스마트 폰의 비밀번호는 Android 시스템에 다음과 같은 특수 파일에 저장됩니다.password.key 에 /data/system.
Android는 비밀번호의 솔트 된 SHA1-hashsum 및 MD5-hashsum을 저장합니다. 이러한 암호는 다음 코드에서 처리 할 수 있습니다.
public byte[] passwordToHash(String password) {
if (password == null) {
return null;
}
String algo = null;
byte[] hashed = null;
try {
byte[] saltedPassword = (password + getSalt()).getBytes();
byte[] sha1 = MessageDigest.getInstance(algo = "SHA-1").digest(saltedPassword);
byte[] md5 = MessageDigest.getInstance(algo = "MD5").digest(saltedPassword);
hashed = (toHex(sha1) + toHex(md5)).getBytes();
} catch (NoSuchAlgorithmException e) {
Log.w(TAG, "Failed to encode string because of missing algorithm: " + algo);
}
return hashed;
}
다음의 도움으로 암호를 해독하는 것은 불가능합니다. dictionary attack 해시 된 암호가 salt file. 이salt64 비트 임의의 정수를 16 진수로 표현한 문자열입니다. 액세스하기 쉽습니다.salt 사용하여 Rooted Smartphone 또는 JTAG Adapter.
루팅 된 스마트 폰
파일 덤프 /data/system/password.key SQLite 데이터베이스에 저장됩니다. lockscreen.password_salt키. 아래에settings.db, 암호가 저장되고 값이 다음 스크린 샷에 명확하게 표시됩니다.
JTAG 어댑터
JTAG (Joint Test Action Group) 어댑터로 알려진 특수 하드웨어를 사용하여 salt. 마찬가지로Riff-Box 또는 JIG-Adapter 동일한 기능에 사용할 수도 있습니다.
Riff-box에서 얻은 정보를 사용하여 암호화 된 데이터의 위치를 찾을 수 있습니다. salt. 다음은 규칙입니다-
연관된 문자열 "lockscreen.password_salt"를 검색하십시오.
바이트는 솔트의 실제 너비를 나타냅니다. length.
스마트 폰에 저장된 비밀번호 / 핀을 얻기 위해 실제로 검색하는 길이입니다.
이러한 규칙 세트는 적절한 솔트 데이터를 가져 오는 데 도움이됩니다.
시간 동기화를 위해 가장 널리 사용되는 프로토콜은 NTP (Network Time Protocol)를 통해 수행됩니다.
NTP는 사용자 데이터 그램 프로토콜 (UDP)을 사용하여 최소 시간을 사용하여 주어진 시간 원본과 동기화하려는 서버와 클라이언트간에 패킷을 통신합니다.
Network Time Protocol의 특징은 다음과 같습니다.
기본 서버 포트는 123입니다.
이 프로토콜은 국립 연구소에 동기화 된 액세스 가능한 많은 시간 서버로 구성됩니다.
NTP 프로토콜 표준은 IETF에 의해 관리되며 제안 된 표준은 "네트워크 시간 프로토콜 버전 4 : 프로토콜 및 알고리즘 사양"[NTP RFC]이라는 제목의 RFC 5905입니다.
운영 체제, 프로그램 및 응용 프로그램은 NTP를 사용하여 적절한 방식으로 시간을 동기화합니다.
이 장에서는 타사 Python 라이브러리 ntplib에서 실행 가능한 Python과 함께 NTP를 사용하는 방법에 초점을 맞 춥니 다. 이 라이브러리는 결과를 로컬 시스템 시계와 비교하는 무거운 작업을 효율적으로 처리합니다.
NTP 라이브러리 설치
그만큼 ntplib 에서 다운로드 할 수 있습니다. https://pypi.python.org/pypi/ntplib/ 다음 그림과 같이.
라이브러리는 NTP 프로토콜 필드를 변환 할 수있는 방법을 사용하여 NTP 서버에 대한 간단한 인터페이스를 제공합니다. 이는 윤초와 같은 다른 키 값에 액세스하는 데 도움이됩니다.
다음 Python 프로그램은 NTP 사용법을 이해하는 데 도움이됩니다.
import ntplib
import time
NIST = 'nist1-macon.macon.ga.us'
ntp = ntplib.NTPClient()
ntpResponse = ntp.request(NIST)
if (ntpResponse):
now = time.time()
diff = now-ntpResponse.tx_time
print diff;
위의 프로그램은 다음과 같은 출력을 생성합니다.
시간의 차이는 위의 프로그램에서 계산됩니다. 이러한 계산은 법의학 조사에 도움이됩니다. 얻은 네트워크 데이터는 하드 드라이브에서 찾은 데이터 분석과 근본적으로 다릅니다.
시간대의 차이 또는 정확한 시간대를 확보하면이 프로토콜을 통해 메시지를 캡처하기위한 증거를 수집하는 데 도움이 될 수 있습니다.
법의학 전문가들은 일반적으로 일반적인 범죄에서 디지털 증거를 분석하기 위해 디지털 솔루션을 적용하기가 어렵다는 것을 알게됩니다. 대부분의 디지털 조사 도구는 단일 스레드이며 한 번에 하나의 명령 만 실행할 수 있습니다.
이 장에서는 일반적인 포렌식 문제와 관련 될 수있는 Python의 다중 처리 기능에 초점을 맞출 것입니다.
다중 처리
다중 처리는 둘 이상의 프로세스를 지원하는 컴퓨터 시스템의 기능으로 정의됩니다. 다중 처리를 지원하는 운영 체제를 사용하면 여러 프로그램을 동시에 실행할 수 있습니다.
다음과 같은 다양한 유형의 다중 처리가 있습니다. symmetric 과 asymmetric processing. 다음 다이어그램은 일반적으로 법의학 조사에서 따르는 대칭 다중 처리 시스템을 나타냅니다.
예
다음 코드는 Python 프로그래밍에서 내부적으로 서로 다른 프로세스가 나열되는 방식을 보여줍니다.
import random
import multiprocessing
def list_append(count, id, out_list):
#appends the count of number of processes which takes place at a time
for i in range(count):
out_list.append(random.random())
if __name__ == "__main__":
size = 999
procs = 2
# Create a list of jobs and then iterate through
# the number of processes appending each process to
# the job list
jobs = []
for i in range(0, procs):
out_list = list() #list of processes
process1 = multiprocessing.Process(
target = list_append, args = (size, i, out_list))
# appends the list of processes
jobs.append(process)
# Calculate the random number of processes
for j in jobs:
j.start() #initiate the process
# After the processes have finished execution
for j in jobs:
j.join()
print "List processing complete."
여기에서 기능 list_append() 시스템의 프로세스 집합을 나열하는 데 도움이됩니다.
산출
우리 코드는 다음과 같은 출력을 생성합니다.
이 장에서는 다음의 도움으로 휘발성 메모리를 조사하는 데 중점을 둘 것입니다. Volatility, 다음 플랫폼에 적용 할 수있는 Python 기반 포렌식 프레임 워크 : Android 과 Linux.
휘발성 메모리
휘발성 메모리는 시스템의 전원이 꺼 지거나 중단 될 때 내용이 지워지는 스토리지 유형입니다. 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
디지털 조사의 주요 관심사는 암호화 또는 기타 형식을 사용하여 중요한 증거 또는 데이터를 보호하는 것입니다. 기본적인 예는 암호를 저장하는 것입니다. 따라서 이러한 귀중한 데이터를 보호하기 위해서는 디지털 포렌식 구현을위한 Linux 운영 체제의 사용을 이해해야합니다.
모든 로컬 사용자에 대한 정보는 대부분 다음 두 파일에 저장됩니다.
- /etc/passwd
- etc/shadow
첫 번째는 필수이며 모든 비밀번호를 저장합니다. 두 번째 파일은 선택 사항이며 해시 된 암호를 포함하여 로컬 사용자에 대한 정보를 저장합니다.
모든 사용자가 읽을 수있는 파일에 암호 정보를 저장하는 보안 문제와 관련하여 문제가 발생합니다. 따라서 해시 된 암호는/etc/passwd, 콘텐츠가 특수 값 "으로 대체됩니다.x".
해당 해시를 찾아야합니다. /etc/shadow. 설정/etc/passwd 세부 사항을 재정의 할 수 있습니다. /etc/shadow.
Linux의 두 텍스트 파일에는 한 줄에 하나의 항목이 포함되며 항목은 콜론으로 구분 된 여러 필드로 구성됩니다.
형식 /etc/passwd 다음과 같습니다-
Sr. 아니. | 필드 이름 및 설명 |
---|---|
1 | Username 이 필드는 사람이 읽을 수있는 형식의 속성으로 구성됩니다. |
2 | Password hash Posix crypt 기능에 따라 암호화 된 형식의 암호로 구성됩니다. |
해시 비밀번호가 다음과 같이 저장되는 경우 empty이면 해당 사용자가 시스템에 로그인 할 때 암호가 필요하지 않습니다. 이 필드에 느낌표와 같이 해시 알고리즘으로 생성 할 수없는 값이 포함 된 경우 사용자는 암호를 사용하여 로그온 할 수 없습니다.
잠긴 암호를 가진 사용자는 SSH 키와 같은 다른 인증 메커니즘을 사용하여 계속 로그온 할 수 있습니다. 앞서 언급했듯이 특별한 값 "x"는 섀도우 파일에서 비밀번호 해시를 찾아야 함을 의미합니다.
그만큼 password hash 다음을 포함합니다-
Encrypted salt − encrypted salt 화면 잠금, 핀 및 암호를 유지하는 데 도움이됩니다.
Numerical user ID−이 필드는 사용자의 ID를 나타냅니다. Linux 커널은이 사용자 ID를 시스템에 할당합니다.
Numerical group ID −이 필드는 사용자의 기본 그룹을 나타냅니다.
Home directory −이 디렉토리를 참조하여 새 프로세스가 시작됩니다.
Command shell −이 옵션 필드는 시스템에 성공적으로 로그인 한 후 시작되는 기본 셸을 나타냅니다.
디지털 포렌식에는 증거 추적과 관련된 정보 수집이 포함됩니다. 따라서 사용자 ID는 레코드를 유지하는 데 유용합니다.
Python을 사용하면이 모든 정보를 분석 지표에 대해 자동으로 분석하여 최근 시스템 활동을 재구성 할 수 있습니다. Linux Shell을 구현하면 추적이 간단하고 쉽습니다.
Linux를 사용한 Python 프로그래밍
예
import sys
import hashlib
import getpass
def main(argv):
print '\nUser & Password Storage Program in Linux for forensic detection v.01\n'
if raw_input('The file ' + sys.argv[1] + ' will be erased or overwrite if
it exists .\nDo you wish to continue (Y/n): ') not in ('Y','y') :
sys.exit('\nChanges were not recorded\n')
user_name = raw_input('Please Enter a User Name: ')
password = hashlib.sha224(getpass.getpass('Please Enter a Password:')).hexdigest()
# Passwords which are hashed
try:
file_conn = open(sys.argv[1],'w')
file_conn.write(user_name + '\n')
file_conn.write(password + '\n')
file_conn.close()
except:
sys.exit('There was a problem writing the passwords to file!')
if __name__ == "__main__":
main(sys.argv[1:])
산출
암호는 16 진수 형식으로 저장됩니다. pass_db.txt다음 스크린 샷과 같이. 텍스트 파일은 전산 법의학에서 나중에 사용할 수 있도록 저장됩니다.
IOC (Indicators of Compromise)는 "시스템 또는 네트워크에서 잠재적으로 악의적 인 활동을 식별하는 시스템 로그 항목 또는 파일에서 발견 된 데이터를 포함하는 포렌식 데이터 조각"으로 정의됩니다.
IOC를 모니터링함으로써 조직은 공격을 감지하고 신속하게 조치하여 이러한 침해가 발생하지 않도록 방지하거나 초기 단계에서 공격을 중지하여 피해를 제한 할 수 있습니다.
다음과 같은 포렌식 아티팩트를 쿼리 할 수있는 몇 가지 사용 사례가 있습니다.
- MD5로 특정 파일 찾기
- 실제로 메모리에 저장된 특정 엔티티 검색
- Windows 레지스트리에 저장된 특정 항목 또는 항목 집합
위의 모든 조합은 아티팩트 검색에서 더 나은 결과를 제공합니다. 위에서 언급했듯이 Windows 레지스트리는 IOC 생성 및 유지 관리에 완벽한 플랫폼을 제공하며 이는 계산 포렌식에 직접적으로 도움이됩니다.
방법론
파일 시스템의 위치를 찾고 특히 지금은 Windows 레지스트리를 찾습니다.
포렌식 도구로 디자인 된 아티팩트 세트를 검색하십시오.
불리한 활동의 징후를 찾으십시오.
조사 라이프 사이클
조사 라이프 사이클은 IOC를 따르며 레지스트리에서 특정 항목을 검색합니다.
Stage 1: Initial Evidence− 호스트 또는 네트워크에서 손상 증거가 탐지됩니다. 응답자는 구체적인 법의학 지표 인 정확한 솔루션을 조사하고 식별합니다.
Stage 2: Create IOCs for Host & Network− 수집 된 데이터에 따라 IOC가 생성되며 Windows 레지스트리로 쉽게 가능합니다. OpenIOC의 유연성은 지표를 만드는 방법에 대한 무제한의 순열을 제공합니다.
Stage 3: Deploy IOCs in the Enterprise − 지정된 IOC가 생성되면 조사관은 Windows 레지스터의 API를 사용하여 이러한 기술을 배포합니다.
Stage 4: Identification of Suspects− IOC 배포는 정상적인 방식으로 용의자를 식별하는 데 도움이됩니다. 추가 시스템도 식별됩니다.
Stage 5: Collect and Analyze Evidence − 용의자에 대한 증거를 수집하고 그에 따라 분석합니다.
Stage 6: Refine & Create New IOCs − 조사 팀은 기업에서 발견 된 증거와 데이터 및 추가 인텔리전스를 기반으로 새로운 IOC를 생성하고주기를 지속적으로 개선 할 수 있습니다.
다음 그림은 조사 라이프 사이클의 단계를 보여줍니다-
Cloud computing인터넷을 통해 사용자에게 제공되는 호스팅 서비스 모음으로 정의 할 수 있습니다. 이를 통해 조직은 가상 머신 (VM), 스토리지 또는 애플리케이션을 유틸리티로 포함하는 리소스를 소비하거나 계산할 수 있습니다.
Python 프로그래밍 언어로 애플리케이션을 빌드 할 때의 가장 중요한 이점 중 하나는 cloud게다가. 이는 Python이 클라우드 서버에서 실행될 수 있으며 데스크톱, 태블릿 또는 스마트 폰과 같은 편리한 장치에서도 실행될 수 있음을 의미합니다.
흥미로운 관점 중 하나는 다음 세대를 통해 클라우드 기반을 만드는 것입니다. Rainbow tables. 몇 가지 고려 사항이 필요한 단일 및 다중 처리 버전의 응용 프로그램을 통합하는 데 도움이됩니다.
파이 클라우드
Pi Cloud는 Python 프로그래밍 언어를 Amazon Web Services의 컴퓨팅 성능과 통합하는 클라우드 컴퓨팅 플랫폼입니다.
다음을 사용하여 Pi 클라우드를 구현하는 예를 살펴 보겠습니다. rainbow tables.
레인보우 테이블
ㅏ rainbow table 주어진 해시 알고리즘에 특정한 암호화 된 암호의 가능한 모든 일반 텍스트 순열 목록으로 정의됩니다.
Rainbow 테이블은 해시 된 암호 목록을 생성하는 표준 패턴을 따릅니다.
텍스트 파일은 암호화 할 암호의 문자 또는 일반 텍스트를 포함하는 암호를 생성하는 데 사용됩니다.
이 파일은 저장할 주요 기능을 호출하는 Pi 클라우드에서 사용됩니다.
해시 된 암호의 출력도 텍스트 파일에 저장됩니다.
이 알고리즘은 데이터베이스에 암호를 저장하고 클라우드 시스템에 백업 저장소를 갖는데도 사용할 수 있습니다.
다음 내장 프로그램은 텍스트 파일에 암호화 된 암호 목록을 생성합니다.
예
import os
import random
import hashlib
import string
import enchant #Rainbow tables with enchant
import cloud #importing pi-cloud
def randomword(length):
return ''.join(random.choice(string.lowercase) for i in range(length))
print('Author- Radhika Subramanian')
def mainroutine():
engdict = enchant.Dict("en_US")
fileb = open("password.txt","a+")
# Capture the values from the text file named password
while True:
randomword0 = randomword(6)
if engdict.check(randomword0) == True:
randomkey0 = randomword0+str(random.randint(0,99))
elif engdict.check(randomword0) == False:
englist = engdict.suggest(randomword0)
if len(englist) > 0:
randomkey0 = englist[0]+str(random.randint(0,99))
else:
randomkey0 = randomword0+str(random.randint(0,99))
randomword3 = randomword(5)
if engdict.check(randomword3) == True:
randomkey3 = randomword3+str(random.randint(0,99))
elif engdict.check(randomword3) == False:
englist = engdict.suggest(randomword3)
if len(englist) > 0:
randomkey3 = englist[0]+str(random.randint(0,99))
else:
randomkey3 = randomword3+str(random.randint(0,99))
if 'randomkey0' and 'randomkey3' and 'randomkey1' in locals():
whasher0 = hashlib.new("md5")
whasher0.update(randomkey0)
whasher3 = hashlib.new("md5")
whasher3.update(randomkey3)
whasher1 = hashlib.new("md5")
whasher1.update(randomkey1)
print(randomkey0+" + "+str(whasher0.hexdigest())+"\n")
print(randomkey3+" + "+str(whasher3.hexdigest())+"\n")
print(randomkey1+" + "+str(whasher1.hexdigest())+"\n")
fileb.write(randomkey0+" + "+str(whasher0.hexdigest())+"\n")
fileb.write(randomkey3+" + "+str(whasher3.hexdigest())+"\n")
fileb.write(randomkey1+" + "+str(whasher1.hexdigest())+"\n")
jid = cloud.call(randomword) #square(3) evaluated on PiCloud
cloud.result(jid)
print('Value added to cloud')
print('Password added')
mainroutine()
산출
이 코드는 다음 출력을 생성합니다.
암호는 다음 스크린 샷과 같이 볼 수있는 텍스트 파일에 저장됩니다.