家・車以外で、人生で一番奮発した買い物

An HTTPdとPerlでCGIを動かそうと思います。

PerlをD:\usr\binに、An HTTPdをD:\Httpdにインストールしました。

ドキュメントルートをD:\html_publicに設定しました。D:\html_publicにindex.htmlを置き、IEでhttp://127.0.0.1/とするとindex.htmlが表示されました。

続いてhello.cgiをD:\html_publicに置き、http://127.0.0.1/hello.cgiとしました。すると「Internet Explorer ではこのページは表示できません」との表示がでました。

Perlが認識されないのであれば、hello.cgiのコードが表示されるものではないでしょうか。

あるいはAn HTTPdでは指定された拡張子以外は認識されないのかもしれないと思い直しても、一応CGIに関しては、
.pl,.cgi D:\usr\bin\perl.exe
で定義しています。

設定のどこに間違いがあるのでしょう。

A 回答 (3件)

CGI で正しい Content-Type: を吐いてますか?



HTMLの META タグだけでは不足で、レスポンスヘッダが必要かも知れませんよ。
    • good
    • 0

  #! /usr/bin/perl


  
  print "Content-type: text/plain\n\n;
  print "Hello Perl!"

これでは表示されません、コピペミスですか?。
カッコが閉じてないし、セミコロンもないし。

この回答への補足

そうそうその通り。どうしようもないミスです。ごめんなさい。

オプション一般の中の「CGI出力を検査」のチェックを入れました。すると、エラーメッセージが以下のように変わりました。
  Error 500
  CGI エラー - Content-Type ヘッダが正しくありません。
  CGI 出力メッセージ:
  
  Bareword found where operator expected at D:\html_public\hello.cgi line 4, near
  "print "Hello"
   (Might be a runaway multi-line "" string starting on line 3)
   (Do you need to predeclare print?)
  syntax error at D:\html_public\hello.cgi line 4, near "print "Hello Perl"
  Can't find string terminator '"' anywhere before EOF at D:\html_public\hello.cgi

3行目におっしゃる通りのミスがあるではありませんか。4行目に「;」が抜けているのはコピペの際に欠けたものです。結局zxcv0000さんの予見された通りでしたね。

これらを訂正してメデタク正常表記です。

ありがとうございました。

補足日時:2009/03/17 21:19
    • good
    • 0

Internet Explorer の場合は


インターネット オプション->詳細設定->ブラウズ「HTTPエラー メッセージを簡易表示する」
のチェックを外しておくと、もっとましなエラーメッセージが出ると思います。
※添付画像が削除されました。

この回答への補足

>HTMLの META タグだけでは不足で、レスポンスヘッダが必要かも知れませんよ。

今回試しているCGIはhello.cgiというファイル名の通り、もっとも初歩的なものです。
  #! /usr/bin/perl
  
  print "Content-type: text/plain\n\n;
  print "Hello Perl!"

>Internet Explorer の場合はインターネット オプション->詳細設定->ブラウズ「HTTPエラー メッセージを簡易表示する」のチェックを外しておくと、もっとましなエラーメッセージが出ると思います。

チェックをはずしてみましたが、表示は変わりませんでした。

次にhello.cgiを削除して、D:\html_publicにhello.cgiがない状態にしてhttp://127.0.0.1/hello.cgiをやってみました。するとError 404の、「見つかりません。 - CGIスクリプトまたはプログラムがありません 」というメッセージが出てきました。

hello.cgiをまたd:\html_publicに復活させてhttp://127.0.0.1/hello.cgiをやったときのログを調べました。すると、httpd.logには
  127.0.0.1 - - [17/Mar/2009:19:11:02 +0900] "GET /hello.cgi HTTP/1.1" 200 0
errors.logには
  Tue Mar 17 19:11:02 2009 Warning: CGI TerminateProcess 3120 error 5
と記述されていました。

補足日時:2009/03/17 19:19
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!


おすすめ情報