質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

1回答

947閲覧

((void (*)())buf)(); の意味について

Prometheus

総合スコア10

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2020/06/16 08:16

前提・実現したいこと

picoCTF2019のhandy-shellcodeという問題を解いていたところ、以下のようなソースコードが提示されました。

その中の、

C言語

1((void (*)())buf)();

という部分が具体的にどのようなことをしているのかが分かりません。

該当のソースコード

C言語

1#include <stdio.h> 2#include <stdlib.h> 3#include <string.h> 4#include <unistd.h> 5#include <sys/types.h> 6 7#define BUFSIZE 148 8#define FLAGSIZE 128 9 10void vuln(char *buf){ 11 gets(buf); 12 puts(buf); 13} 14 15int main(int argc, char **argv){ 16 17 setvbuf(stdout, NULL, _IONBF, 0); 18 19 // Set the gid to the effective gid 20 // this prevents /bin/sh from dropping the privileges 21 gid_t gid = getegid(); 22 setresgid(gid, gid, gid); 23 24 char buf[BUFSIZE]; 25 26 puts("Enter your shellcode:"); 27 vuln(buf); 28 29 puts("Thanks! Executing now..."); 30 31 ((void (*)())buf)(); 32 33 34 puts("Finishing Executing Shellcode. Exiting now..."); 35 36 return 0; 37}

試したこと

https://teratail.com/questions/181805

なども読みましたが、よく分かりませんでした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

(void ()()) は、戻り値なしの関数アドレスを示します
ということで、
(void (
)())buf bufのアドレスを、関数アドレスにキャストしてます
ということで、

((void (*)())buf)();

bufのアドレスを関数アドレスにキャストして、関数として実行させていますね

投稿2020/06/16 08:22

y_waiwai

総合スコア88042

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Prometheus

2020/06/16 08:42

解答ありがとうございます。 入力時点では変数であるbufを、関数として実行できるようにする、ということでしょうか?
y_waiwai

2020/06/16 08:46

そういうことですね。 きっとそのバッファには機械語のデータが展開されるんでしょう
Prometheus

2020/06/16 08:48

そういうことだったんですね。ようやく腑に落ちました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問