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