ホームページ >バックエンド開発 >Golang >Linux 上の Go または C でメモリから実行可能ファイルを実行するにはどうすればよいですか?

Linux 上の Go または C でメモリから実行可能ファイルを実行するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-11-30 08:36:141030ブラウズ

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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。