메모리 내 바이너리 실행
개발자는 애플리케이션의 일부로 바이너리를 실행해야 하는 경우가 많습니다. 그러나 바이너리를 디스크에 저장한 다음 "exec" 또는 "fork"를 호출하는 기존 접근 방식은 비효율적일 수 있습니다. 이 기사에서는 디스크 쓰기가 필요 없이 메모리에서 직접 바이너리를 실행하는 방법을 살펴봅니다.
배경
제공된 코드 조각에서 바이너리 데이터는 다음 위치에 저장됩니다. "myExec"이라는 변수. 목표는 이 바이너리를 파일 시스템에 다시 쓰지 않고 실행하는 것입니다.
C 및 Linux의 솔루션
C에서 mprotect() 시스템 호출을 사용하면 메모리 영역의 보호를 수정합니다. 이는 데이터 영역을 코드 영역으로 변환할 수 있음을 의미합니다. 이 변환이 완료되면 메모리 영역으로 점프하여 실행할 수 있습니다.
다음은 이 작업을 수행할 수 있는 방법의 예입니다.
#include <sys/mman.h> int main() { // Assume we have an array of bytes representing the binary data. char myExec[] = {'s', 'o', 'm', 'e', ' ', 'b', 'y', 't', 'e', 's'}; // Convert the data region into a code region. mprotect(myExec, sizeof(myExec), PROT_READ | PROT_WRITE | PROT_EXEC); // Execute the code. ((void (*)())myExec)(); return 0; }
위 내용은 Linux의 C 메모리에서 직접 바이너리를 실행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!