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

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

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

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Q&A

解決済

3回答

4750閲覧

cgi-binディレクトリの必要性について

stmkza

総合スコア478

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

0グッド

0クリップ

投稿2018/02/04 14:30

ApacheなどのWebサーバーソフトではデフォルトでcgi-binディレクトリ内でないとCGIを実行できないようになっていますが、この設定の利点は何があるのでしょうか?

自分には全く利点がないように思えるのですが、実はセキュリティ上で大きな利点があるとかはないですか?

そうすると、自分はDocumentRootにExecCGIを許可していますが、それがセキュリティ的にまずいということになる気がしますが、それについても回答をお願いしたいです。

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

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

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

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

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

guest

回答3

0

ベストアンサー

単なる歴史的経緯だと思います。
cgi-binディレクトリ以外でもCGIプログラムが実行できるようになっても元のままがデフォルトとして残っているのでしょう。

投稿2018/02/04 14:54

otn

総合スコア84505

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

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

mike2mike4

2018/02/04 15:31

なるほど、それは知りませんでした。ありがとうございます。
guest

0

CGIプログラムは単にサーバで実行されるプログラムにすぎないので、サーバ上でプログラムを実行出来る権限がない(FTPなどでしかアクセスしかできない)ユーザーでもWebサーバ経由でプログラムを実行出来てしまいます。cgi-binが分離されていることで、デフォルトの状態でも「コンテンツを設置更新できるユーザー(DcoumentRootにアクセス出来るユーザー)」「CGIプログラムを設置できるユーザー(cgi-binにアクセス権があるユーザー)」を容易に分離出来ます。

またcgi-binに置かれたファイルはすべてCGIプログラムと見なされるので、実行されるか権限などに問題があればエラーになります。DocumentRoot以下でCGIプログラムを実行しようとした場合、設定ミスなどでソースコードが表示されてしまうような状況がありがちです。

デフォルトでCGIを有効にしつつ任意の場所でCGIが実行出来るようにはなっていないという、利便性とセキュリティのバランスが考えられた設定です。

投稿2018/02/06 14:00

suzukis

総合スコア1449

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

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

0

パーミッションで隔離して、セキュリティを確保しようとしているのでは?

投稿2018/02/04 14:41

mike2mike4

総合スコア894

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問