アプリ版:「スタンプのみでお礼する」機能のリリースについて

こちらの、Freecart.jpにて、CGIをダウンロードし、
ショッピングカートを利用しております。
http://www.freecart.jp/cart1.html

ほぼ問題なく動作しているのですが、
2つ、問題があります。

(1)環境によって、「クッキーを受け付けるようになっていません。」というようなエラー画面が表示される。
イマイチ原因がわからず、解決できずに困っています。
・クッキーを受け付ける設定になっているにも関わらず表示されます。
・Macユーザーに多いですが、Win(IE)でも稀に起きるそうです。
・カートに入れた時に表示されます。
私自身、Safariでアクセスした際に、一度クッキーエラーが出ましたが、
再度アクセスすると消えました。
もちろんクッキーを受け付ける設定にしております。
こういった現象をなくし、修正したいです。
初心者ですが、どうかお力添えのほどよろしくお願いいたします。

カートに入れた時にアクセスするCGIは、setcook.cgiです。
この中で、クッキー関連の記述と思われるのが、
----------
foreach (split(/; /,$ENV{'HTTP_COOKIE'})) {
($key,$value) = split(/=/);
if ($key eq "fileid") {
$filename= $value;
$cookiecheck= 1;
$datafile="./tmp/$filename.txt";
}
}

$hostname = $ENV{'REMOTE_ADDR'};
open (CDATA,"$hostcheckfile");
flock(CDATA,2);
$checkhostname = <CDATA>;
close (CDATA);
$hostname2=$hostname;
if ($cookiecheck eq "1") {$hostname2 = "";}
open (CDATA,">$hostcheckfile");
print CDATA $hostname2;
close (CDATA);
flock(CDATA,8);

if($filename eq ""){
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime(time);
$fdate = sprintf("%02d%02d%02d%02d%02d%02d",$year -90,$mon +1,$mday,$hour,$min,$sec);
if($filename eq ""){$filename="d$fdate";}
$datafile="./tmp/$filename.txt";
print "Pragma: no-cache\n";
print "P3P: CP=\"NOI ADMa\"\n";
print "Set-Cookie: ";
print "fileid=$filename; ";
#print "expires=$cookieexpires; ";
print "path=$path; ";
print "domain=$domain\n";
}

if($cookiecheck ne "1"){
if($hostname eq $checkhostname){&cookieerror;}
}
----------
です。
クッキーにもCGIにも疎く、ご教授頂ければと思います。

(2)注文が完了すると、自動返信メールが送られるのですが、
自動返信メールが文字化けするという報告があります。
・OutLookExpressを使用している方からの報告でしたが、
 私自身のOutLookExpressでは文字化けが起きませんでした。
 また、その方も長年使用していて今まで文字化けが起きたことがないそうです。
・CGI、メールヘッダ、フッタ、HTMLの文面はすべて、SHIFT-JISで書かれています。
なんとか文字化けが起きないようにしたいです。
ほかに必要な情報があれば補足致します。
よろしくお願いいたします。

A 回答 (3件)

>要求ヘッダというのは、​

http://www.studyinghttp.net/cookies
>このサイトにあるような形のものでしょうか。
 これは、サーバーからの応答ヘッダです。
 確認は、fie\refox3.57 + LiveHTTP hedarsが分かりやすいです。
 現状、firefox3.6には未対応のようです。

>要求ヘッダにcookieがない状況を作り出したり、自分の使っているブラウザにあるかどうかを確認する方法はありますか?
 これもFirefoxが楽です。ツール→プライバシー→Cookieで、サイトごとのCookieの確認や削除ができます。

>大変恐縮ですが、Cookieを発行して、再読み込みをするには、どのように書き換えればよいでしょうか。
 ブラウザからの要求ヘッダに、
Cookie: **************************
 がないとき、簡単なHTMLを
Set-Cookie付で発行します。HTML自体はrefreshを短時間で設定すれば良いですね。
 再要求の要求か否かは、QUERY_STRINGかHTTP REFERERなどで判別してください。

>(2)文字化けについてですが、&jcode::convert(\$messagen,'jis');
>のような変換を行うようにしました。これで正しく回避できているでしょうか?
 そうです。
 当然、ヘッダの該当部分も
Content-Type: text/plain; charset=ISO-2022-JP
 に変更してください。
また、メッセージタイトルに日本語が含まれる場合はBase64エンコードが必要です。
Subject: =?ISO-2022-JP?B?[この部分Base64エンコードされた文字列]=?=

 詳しくは適当なメールフォームCGIのマニュアルをご覧ください。

この回答への補足

再びの回答ありがとうございます!

(1)については、あらかじめクッキーを発行することで、対応することができました!
今のところ、正常に動いているようです。

(2)の文字化けについては、
件名の変換方法で止まっております。
送信しているところは、このとうな感じです。
-----------
if($emailh eq "1"){
if (!open(MAIL,"|$sendmail $email")) { &error; }
&jis("Subject:$confmailtitle"); print MAIL "$msg\n";
print MAIL "To: $email\n";
print MAIL "From: $myaddress1\n";
print MAIL "Content-type:text/plain; charset=ISO-2022-JP\n";
print MAIL "Content-Transfer-Encoding:7bit\n";
print MAIL "\n";
print MAIL "$header\n";
$count = 1;
while ($count <= $ncount ){
&sub2;}
print MAIL "$messagetotal";
print MAIL "$message\n";
print MAIL "$footer";
close(MAIL);
}
sub jis { $msg = $_[0]; &jcode::convert(\$msg, 'jis'); }
-----------
$confmailtitleを変えていけばよいと思うのですが、
うまく行きません…。
どのように変換するのがよいのでしょうか?

補足日時:2010/02/13 13:21
    • good
    • 0

ISO-2022-JPに変換後Base64エンコードですから


use MIME::Base64;
****************
$encoded_data = encode_base64($data);
で、

print MAIL "To: $email\n";
print MAIL "From: $myaddress1\n";
もbase64で変換すると
日本語 <abc@hoge.com>
も扱えるよ。
    • good
    • 0
この回答へのお礼

本当に本当にありがとうございます!!!!!!!!
無事、すべて解決致しました。
感謝感謝です。

お礼日時:2010/02/13 16:17

 Cookieは、ブラウザからの要求ヘッダに含まれていないと、そのように判定する場合があります。

要求ヘッダにcookieがない場合は、Cookieを発行して、再読み込みをするようにしましょう。

>CGI、メールヘッダ、フッタ、HTMLの文面はすべて、SHIFT-JISで書かれています。
>なんとか文字化けが起きないようにしたいです。

 これは、間違いです。

 必ず、ISO-2022-JP にしましょう。
 またヘッダは、Base64エンコードしましょう。

RFC2822 ( http://www.puni.net/~mimori/rfc/rfc2822.txt )
RFC2821 1~3章 ( http://www.puni.net/~mimori/rfc/rfc2821a.txt )
RFC2821 4,5章 ( http://www.puni.net/~mimori/rfc/rfc2821b.txt )
RFC2821 6章~ ( http://www.puni.net/~mimori/rfc/rfc2821c.txt )

この回答への補足

回答ありがとうございます。
(1)について、
要求ヘッダというのは、http://www.studyinghttp.net/cookies
このサイトにあるような形のものでしょうか。

要求ヘッダにcookieがない状況を作り出したり、自分の使っているブラウザにあるかどうかを確認する方法はありますか?(検証のためです。)

大変恐縮ですが、Cookieを発行して、再読み込みをするには、どのように書き換えればよいでしょうか。

(2)文字化けについてですが、
&jcode::convert(\$messagen,'jis');
のような変換を行うようにしました。これで正しく回避できているでしょうか?
(私自身のOutLookExpressでは元々文字化けが起きず、検証できずで…すみません。)

補足日時:2010/02/13 00:26
    • good
    • 0

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