메모리에서 바이너리 실행
소프트웨어 엔지니어링 영역에서는 메모리에서 직접 바이너리를 실행하는 것이 유리할 수 있는 시나리오를 자주 접합니다. 이 위업을 달성하는 방법을 살펴보겠습니다.
전제 조건:
컴파일 중에 매우 흔히 발생하는 바이너리가 변수에 저장되는 상황을 생각해 보세요. 다음과 같은 바이트 배열이 있습니다.
[]byte{'s','o','m','e',' ','b','y','t','e','s'}
우리의 목표는 이 바이너리를 디스크에 다시 쓰거나 exec 또는 fork와 같은 외부 명령을 사용할 필요 없이 프로그램 내에서 실행하는 것입니다.
해결책:
Linux를 예로 들어 메모리 영역을 유리하게 조작할 수 있습니다. mprotect() 시스템 호출을 사용하면 메모리 영역의 보호를 수정할 수 있습니다. 구체적으로 데이터 영역에서 코드 영역으로 변경할 수 있습니다. 이를 통해 메모리에서 직접 코드를 실행할 수 있습니다.
메모리 영역이 다시 보호되면 해당 영역으로 점프하여 바이너리를 실행할 수 있습니다.
위 내용은 Linux의 메모리에서 직접 바이너리를 실행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!