Golang 또는 C의 메모리에서 실행 파일 실행
컴퓨터 프로그래밍에서는 메모리에서 실행 파일을 실행해야 하는 상황이 발생합니다. 이 기사에서는 Linux 환경에서 Go 또는 C를 사용하여 이 작업을 수행하는 기술을 살펴봅니다.
접근 방식: 메모리 수정 및 실행
메모리에서 실행 파일을 실행하려면, 먼저 실행 가능한 바이너리가 포함된 메모리 영역의 권한을 변경해야 합니다. 이렇게 하면 메모리에 실행 가능한 코드로 액세스할 수 있습니다. C에서는 이 작업에 mprotect() 시스템 호출을 활용할 수 있습니다.
메모리 권한을 수정한 후 바이너리가 있는 메모리 주소로 점프하여 바이너리를 직접 실행할 수 있습니다. Go에서는 mmap() 및 mprotect() 시스템 호출을 사용하여 이를 수행할 수 있습니다. mmap() 호출은 메모리를 프로그램의 주소 공간에 매핑하는 반면, mprotect()는 매핑된 메모리의 보호를 조정합니다.
다음은 Go에서 이를 달성할 수 있는 방법의 예입니다.
import ( "syscall" "unsafe" ) func executeBuffer(buffer []byte) error { const RWX = syscall.PROT_READ | syscall.PROT_WRITE | syscall.PROT_EXEC // Map the memory addr, err := syscall.Mmap(0, 0, len(buffer), syscall.MAP_PRIVATE, syscall.MAP_ANONYMOUS) if err != nil { return err } // Copy the data into mapped memory copy(addr, buffer) // Change the protection err = syscall.Mprotect(addr, len(buffer), RWX) if err != nil { return err } (*func())(unsafe.Pointer(uintptr(addr)))() return nil }
참고: 이 기술은 메모리 권한 수정이 필요하고 잠재적으로 시스템 안정성에 영향을 미칠 수 있으므로 작은 실행 파일을 실행하는 데 가장 적합합니다. 프로그램. 또한, Linux가 아닌 환경에서 사용할 계획이라면 이 접근 방식의 이식성을 확인해 볼 가치가 있습니다.
위 내용은 Linux의 Go 또는 C에서 메모리에서 실행 파일을 어떻게 실행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!