SSIで躓きました・・・(;;)

なべちゃん 1998/08/24(月) 14:54:44
htmlと同じ階層から <!-- #exec cmd="aaa.pl"--> で呼び出すのはOKなんですが、一階層下から <!-- #exec cmd="../aaa.pl" --> とすると何も起こらないんです。そういう仕様なのでしょうか? それとも、別の方法でなければならないのですか? 教えてください。
SHUICHI.T [E-Mail] [HomePage] 1998/08/24(月) 17:01:17
<!--#exec cmd="../aaa.pl" -->
の "../aaa.pl" の直後のスペースは単なる書き間違えでしょうか?
なべちゃん 1998/08/24(月) 18:25:13
書き間違いです。実際は詰まってます。"../aaa.pl" という相対パス表記に問題があるようなのですが、、、
織田信長 1998/08/24(月) 19:54:01
ファイル名がaaa.plということはperlスクリプトだと思います。
そこで臭いのが、スクリプトの中で

$file = 'log.dat';
open(LOG,"$file");

みたいことしてませんか?
私も以前このケースで引っかかりました。
一応、同じケースだという仮定でお答えします。

SSIで指定されたaaa.plは、当然叩かれた場所(この場合、aaa.plが置いてある一個下のディレクトリ)を基点にして実行されます。
ここで注意が必要なのが、現実にはlog.datは上のディレクトリに置いてあるということです。
しかし、スクリプトにとってのカレントは下ですから、当然File Not Foundとなるのです。
この説明でお分かりでしょうか?スクリプト言語特有の現象です。

対策としては、

・C言語などでコマンドを作る。
・絶対パスを使う。
・パスは引数で渡す。

などでしょうか。
匿名希望 1998/08/24(月) 21:34:57
>SSIで指定されたaaa.plは、当然叩かれた場所(この場合、aaa.plが置いてある一個下のディレクトリ)を基点にして
>実行されます。

SSI一般ではなく、cmd引数で呼んだ場合ですね。

cmd引数で呼ぶとCGI変数が取れないので、cgi引数で呼ぶことも
考えるとよいでしょう。(少なくとも僕はcmd引数は使わない。)

>この説明でお分かりでしょうか?スクリプト言語特有の現象です。
>対策としては、
>・C言語などでコマンドを作る。

「スクリプト言語」の定義はともかく、なにもPerlでは起きてCでは
起きないということはないでしょう。これは無関係ですね。

SSIはセキュリティーホールになるので、色々制限を加えている
プロバイダーが少なくないですが、絶対パスや../式で上位の
階層を呼べないようにしているところもあります。これを許すと、
SSIのセキュリティーホールを突いて/usr/sbin/など好きなところ
の実行ファイルを実行されかねないので、それを嫌ったのでしょう。

かりに/home/foo/public_htmlにスクリプトがあるとして、
'../../usr/sbin/'で'/usr/sbin/'にたどり着く。
匿名希望 1998/08/26(水) 10:31:59
>これを許すと、SSIのセキュリティーホールを突いて/usr/sbin/
>など好きなところの実行ファイルが実行される

これは、そのページの所有者によって、ということではなく、外部の
クラッカーによって、ということでしょう。例えば掲示板で不用意に
もSSIが使えるようになっていると、部外者がそのことを利用して掲
示板にSSI命令を書き込むことになる。