> 백엔드 개발 > Golang > Linux의 Go 또는 C에서 메모리에서 실행 파일을 어떻게 실행할 수 있나요?

Linux의 Go 또는 C에서 메모리에서 실행 파일을 어떻게 실행할 수 있나요?

Barbara Streisand
풀어 주다: 2024-11-30 08:36:14
원래의
1027명이 탐색했습니다.

How Can I Execute an Executable from Memory in Go or C on Linux?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿