サーバー: 2007年1月アーカイブ
NuOnceをSun Cobalt, Class Cat Cute, BlueQuartz (2003年)からの移行用へと新調した。
旧サーバから新サーバへCGIを移行したが、一部上手く動かないものがある。
それは$ENV{'REMOTE_USER'}を拾ってるスクリプトである。
#!/usr/bin/perl
use Data::Dumper;
print "Content-Type: text/plain\n\n";
print Dumper \%ENV;
上のスクリプトを用意して
% w3m 'http://ユーザ:パス@ホスト/dump_env.cgi?aaa=aab' | grep \'REDIRECT | sort
'REDIRECT_QUERY_STRING' => 'aaa=aab',
'REDIRECT_REMOTE_USER' => 'ユーザ',
'REDIRECT_SCRIPT_URI' => 'http://ホスト/dump_env.cgi',
'REDIRECT_SCRIPT_URL' => '/dump_env.cgi',
'REDIRECT_STATUS' => '200',
'REDIRECT_UNIQUE_ID' => 'VJaXrH3OfAYAACdRTN8AAAAZ',
'REDIRECT_URL' => '/dump_env.cgi',
ふみゅ。
元のREMOTE_USERハッシュキーは存在せず、接頭辞REDIRECTが付いてるのに置きかわってる。
Apache2.0.48ぐらいから、そういう動作のよう。
BlueQuartzのCGIはCGIWrapが担当していて、Apacheが渡すまえに置きかえている。
で、正しいかな。
.htaccessに
Options +ExecCGI
#AddHandler cgi-wrapper .cgi
AddHandler cgi-script .cgi
とすれば、「接頭辞REDIRECT置き換え」はされないが、今度はユーザ権限がApacheのまま。
$ENV{'REMOTE_USER'} 系のスクリプトを書き直さずに動かすにはどうしたらいいんだろうか・・・
キー:internal redirect, internal_redirect
先日インストしたNuOnceで見事にハマりました。
Sendmailで外から受信、SMTP経由で外へ送信は問題ないものの
CGIやPHPから送れないという症状。
具体的には
% cat | /usr/sbin/sendmail -t -n -oi メアド
test
detu
CTRL-D
で
/home/ユーザ/dead.letter... Saved message in /home/ユーザ/dead.letter
と死んでしまう。
CGIで
open(MAIL, "| /usr/sbin/sendmail -t -n -oi メアド");
などとしていると、上のエラーが
print "Content-Type: text/plain\n\n";
などより先に出力されてしまったりして、malformed headerエラー。
(CPANレス系のCGIですが・・・)
% tail /var/log/maillog
すると
Jan 4 23:17:12 www sendmail[1919]: l04EH9f8001919: to=メアド, ctladdr=ユーザ (501/501), delay=00:00:03, xdelay=00:00:00, mailer=relay, pri=30008, relay=[127.0.0.1] [127.0.0.1], dsn=5.6.0, stat=Data format error
"Data format error"じゃ、分からんじゃんけ!
で解決の切っ掛けは-vオプション。
% cat | /usr/sbin/sendmail -v -t -n -oi メアド
〜省略〜
553 5.3.0 <ユーザ@ホスト名>... No such user here
/home/ユーザ/dead.letter... Saved message in /home/ユーザ/dead.letter
どうやら、No such user hereとバウンスされている様。
% grep 'No such user here' /etc/mail/*
すると
/etc/mail/virtusertable:@ホスト名 error:nouser No such user here
とバウンス壁が用意されてる。
このルールはBQの「仮想サイト」に登録されると、作られる。
結論
BlueQuartz(NuOnce Installer)では
「システムのTCP/IPのホスト名とドメインネーム」で設定したFQDNは
「仮想ホスト」に登録しないこと!
(登録すると、その「仮想ホスト」に登録したユーザしかコマンドインターフェイスではメールが送れなくなります)

