package stdio; ;######################################################################### ;# ;# CGI Standard Input Output Library Ver 3.41 ;# ;# Copyright(C)1997-1999 Iwao Wada. All Rights Reserved. ;# Script found at ;# ;# This script written in SHIFT-JIS & LF. ;# ;# - 利用規程 ;# ・著作権は放棄していませんが、配布・転載・改造は自由です。 ;# ・転載・再配布される場合も、必ずコピーライトを明記して下さい。 ;# ・改造版を再配布する場合は、必ずオリジナルも添付して下さい。 ;# ・このライブラリを使用した結果について一切の責任は負いません。 ;# ;# - 機能一覧 ;# ・クッキー処理 ・日付設定処理 ・フォームデコード ;# ・ファイル読込み ・データ読込み ・メール送信 ;# ・検索 ・アップロード ・文字列暗号化 ;# ・暗号照合 ・ファイルロック ・インラインリンク ;# ;# - 関数の仕様書 ;# ・すべては関数となっており、引数と戻り値を持つ。 ;# ・特に明記の無い限り、Perl5の文法は使われていない。 ;# ・引数が<***>となっているものは真偽で引数を指定する。 ;# ・引数が{***}となっているものは省略可能である。 ;# ;######################################################################### ;# ;# * クッキー設定 ;# ;# 引数 : (CookieName,Cookies,{Expires},{時差},{Domain},{Path},{}) ;# 戻値 : 正常に処理できたならば真 (失敗時は偽) ;# ;#------------------------------------------------------------------------ ;# ;# * クッキー取得 ;# クライアントからクッキーの取得を行う。名前とクッキーは"="で、各値は、 ;# "&"で、値とキーは":"で区切りられているものとする。 ;# ;# 引数 : (Cookie Name) ;# 戻値 : 各クッキーが代入されたハッシュ ;# ;#------------------------------------------------------------------------ ;# ;# * 日付設定処理 ;# ;# 引数 : ({書式},{時差},{基準},{調整秒}) ;# 戻値 : 現在日時 ;# ;# [書式の指定方法(例)] ;# ;# $date = stdio::SetTime('yyyy/mm/dd [ww] hh:mm ss',9); ;# ;# 上記のように指定すると、戻り値は 2001/09/12 [日] 14:04 24 のよう ;# な形になる。(1999年9月12日-日曜日14時4分24秒を例にしている) ;# ;# yyyy = 年-西暦4桁表記 (ex.2001) ;# yy = 年-西暦2桁表記 (ex.01) ;# y = 年-西暦1桁表記 (ex.1) ;# yyy = 年-和暦表記 (ex.14) ;# m = 月-数字1桁表記 (ex.9) ;# mm = 月-数字2桁表記 (ex.09) ;# mm2 = 月-英語略表記 (ex.Sep) ;# mm3 = 月-英語完全表記 (ex.September) ;# d = 日-数字1桁表記 (ex.12) ;# dd = 日-数字2桁表記 (ex.12) ;# ww = 曜-漢字表記 (ex.日) ;# ww2 = 曜-英語略表記 (ex.Sun) ;# ww3 = 曜-英語完全表記 (ex.Sunday) ;# h = 時-数字1桁24時間表記 (ex.14|2) ;# hh = 時-数字2桁24時間表記 (ex.14|02) ;# n = 分-数字1桁表記 (ex.4) ;# nn = 分-数字2桁表記 (ex.04) ;# s = 秒-数字1桁表記 (ex.24) ;# ss = 秒-数字2桁表記 (ex.24) ;# ap = 時-AM/PM表記 ;# ap2 = 時-am/pm表記 ;# ap3 = 時-午前/午後表記 ;# (注:apを付けると自動的に hh/h は12時間表記になる) ;# ;#------------------------------------------------------------------------ ;# ;# * デコード処理 ;# リクエストされた内容をデコード、分解する。文字コードは"sjis,jis,euc" ;# のいずれかを指定。指定しない場合は文字コードの変換は行われない。文字 ;# コードの変換には"jcode.pl"を呼び出している必要がある。 ;# ;# 引数 : ({<タグ無効>},{改行コード},{文字コード},{}) ;# 戻値 : 各要素が代入されたハッシュ ;# ;#------------------------------------------------------------------------ ;# ;# * ファイル読み込み ;# ;# 引数 : (パス,{読出開始行},{読出数},{<改行除去>},{<ロックチェック>}) ;# 戻値 : ファイル要素が代入された配列 (失敗時は偽) ;# ;#------------------------------------------------------------------------ ;# ;# * データ読み込み ;# 各レコードをフィールドごとに区切り、ハッシュに代入。これは各フィール ;# ドが"\b"で区切られている場合のみ使用可能。 ;# ;# 引数 : (読み込むレコード) ;# 戻値 : 各フィールドが代入されたハッシュ ;# ;#------------------------------------------------------------------------ ;# ;# * メール送信 ;# sendmailを使ってメールを送信。ファイルを添付する場合はそのパスを指定 ;# する。この処理は"jcode.pl"を呼び出している必要がある。日本語ヘッダー ;# ならびに添付ファイルのエンコード方式は"Base64"である。 ;# ;# 引数 : (Sendmail,To,Cc,Bcc,From,Reply-To,Subject,本文,{}, ;# {Priority},{添付ファイルのパス..}) ;# 戻値 : 正常に処理できたならば真 (失敗時は偽) ;# ;#------------------------------------------------------------------------ ;# ;# * レコード検索 ;# レコード(配列)から指定された条件で検索し、抽出されたレコードを返す。 ;# 検索条件は、0 = AND、1 = OR、2 = 検索式で指定する。検索式は、"&"と ;# "|"、"!"が使用可能。小括弧()による優先順位の指定も可能である。 ;# ;# 引数 : (キーワード,{検索条件},{曖昧検索},検索対象配列) ;# 戻値 : 抽出されたデータ配列 ;# ;#------------------------------------------------------------------------ ;# ;# * 文字列検索 ;# ;# 引数 : (検索対象文字列,キーワード,{検索条件},{曖昧検索}) ;# 戻値 : キーワードと検索条件を満たすならば真 ;# ;#------------------------------------------------------------------------ ;# ;# * アップロード ;# "multipart/form-data"からデータを取得。書式はフォームデコードと同じで ;# ある。ファイルの場合、戻り値のハッシュで"$_{*.name}"とすると、ファイ ;# ルの名前が取得可能。 ;# ;# 引数 : ({<タグ>},{改行},{文字コード}) ;# 戻値 : 各要素が代入されたハッシュ ;# ;#------------------------------------------------------------------------ ;# ;# * 暗号化処理 ;# crypt関数を使って暗号化する。引数として暗号化する文字列を渡す。暗号化 ;# された文字列が戻り値となる。暗号化できなかった場合は偽を返す。この暗号 ;# 化処理は強度を高めるため二重にしている。 ;# ;# 引数 : (平文,{<普通暗号化>}); ;# 戻値 : 暗号文(crypt関数が使えない場合は負) ;# ;#------------------------------------------------------------------------ ;# ;# * 暗号照合 ;# 前項によって暗号化された文字列が、入力された文字列かどうかを照合。こ ;# の処理では通常の方法で暗号化された文字列も照合可能。 ;# ;# 引数 : (平文,暗号文) ;# 戻値 : 照合一致した場合は真(crypt関数が使えない場合は負) ;# ;#------------------------------------------------------------------------ ;# ;# * インラインリンク ;# ;# 引数 : (リンクに変換する文字列) ;# 戻値 : (リンクに変換された文字列) ;# ;#------------------------------------------------------------------------ ;# ;# * ファイル出力 ;# ;# 引数 : (ファイルのパス) ;# 戻値 : 正常に処理できたならば真 ;# ;#------------------------------------------------------------------------ ;# ;# * ロックチェック ;# オープンしようとしているファイルがロックされているかチェックする。 ;# ;# 引数 : (データファイルのパス,<1>) ;# 戻値 : ロックされていないならば真 ;# ;#------------------------------------------------------------------------ ;# ;# * ファイルロック ;# ファイルロック、書き込みを行う。データファイルのディレクトリの属性は ;# 777である必要がある。ロック方法は 0はロックしない、1はopen()関数によ ;# るロック、2はsymlink()関数によるロック。 ;# ;# 引数 : (データファイル,ロック方法,データ) ;# 戻値 : 正常に処理できたならば真(symlink関数が使えない場合は負) ;# ;######################################################################### $version = 3.41; ;# ========================== ;# Set Cookie. ;# ========================== sub SetCookie { local(@ARG) = @_; return 0 if (!$ARG[0] || !$ARG[1]); if ($ARG[2] == -1) { $ARG[2] = ' expires=Mon, 01-Jan-1990 00:00:00 GMT;'; } elsif ($ARG[2] =~ /\d+/) { $ARG[2] = ' expires=' . &SetTime('ww2, dd-mm2-yyyy hh:nn:ss',$ARG[3],undef,86400 * $ARG[2]) . ' GMT;'; } elsif ($ARG[2]) { $ARG[2] = " expires=$ARG[2];"; } $ARG[4] = $ARG[4] ? " domain=$ARG[4]" : undef; $ARG[5] = $ARG[5] ? " path=$ARG[5]" : undef; $ARG[6] = $ARG[6] ? " secure" : undef; $ARG[7] = $ARG[7] ? undef : "Set-Cookie: "; $ARG[8] = $ARG[7] ? "\n" : undef; print "$ARG[7]$ARG[0]=$ARG[1];$ARG[2]$ARG[4]$ARG[5]$ARG[6]$ARG[8]"; undef @ARG; return 1; } ;# ========================== ;# Get Cookie. ;# ========================== sub GetCookie { local(%ARG) = (); foreach (split ";", $ENV{'HTTP_COOKIE'}) { @ARG = split "="; $ARG[0] =~ s/ //g; last if ($ARG[0] eq $_[0]); } foreach (split "&", $ARG[1]) { @ARG = split ":"; $ARG[1] =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C", hex($1))/eg; $ARG{$ARG[0]} = $ARG[1]; } undef @ARG; return %ARG; } ;# ========================== ;# Set day and time. ;# ========================== sub SetTime { local(@ARG) = @_; $ARG[2] = time if (!$ARG[2]); if ($ARG[0]) { @TIME = gmtime($ARG[2] + $ARG[1] * 3600 + $ARG[3]); } else { return gmtime($ARG[2] + $ARG[1] * 3600 + $ARG[3]); } if ($ARG[0] =~ /yyyy/) { $TIME[5] += 1900; $ARG[0] =~ s/yyyy/$TIME[5]/; } elsif ($ARG[0] =~ /yyy/) { $TIME[5] -= 88; $ARG[0] =~ s/yyy/$TIME[5]/; } elsif ($ARG[0] =~ /yy/) { $TIME[5] += 1900; $TIME[5] = substr($TIME[5],2); $ARG[0] =~ s/yy/$TIME[5]/; } else { $TIME[5] += 1900; $TIME[5] = substr($TIME[5],3); $ARG[0] =~ s/y/$TIME[5]/; } if ($ARG[0] =~ /dd/) { $TIME[3] = sprintf("%02d",$TIME[3]); $ARG[0] =~ s/dd/$TIME[3]/; } else { $ARG[0] =~ s/d/$TIME[3]/; } if ($ARG[0] =~ /ap2/) { if ($TIME[2] - 12 < 0 ) { $ARG[4] = 'am'; } elsif ($TIME[2] - 12 == 0) { $TIME[2] = 12; $ARG[4] = 'pm'; } else { $TIME[2] -= 12; $ARG[4] = 'pm'; } $ARG[0] =~ s/ap2/$ARG[4]/; } elsif ($ARG[0] =~ /ap3/) { if ($TIME[2] - 12 < 0 ) { $ARG[4] = '午前'; } elsif ($TIME[2] - 12 == 0) { $TIME[2] = 12; $ARG[4] = '午後'; } else { $TIME[2] -= 12; $ARG[4] = '午後'; } $ARG[0] =~ s/ap3/$ARG[4]/; } elsif ($ARG[0] =~ /ap/) { if ($TIME[2] - 12 < 0 ) { $ARG[4] = 'AM'; } elsif ($TIME[2] - 12 == 0) { $TIME[2] = 12; $ARG[4] = 'PM'; } else { $TIME[2] -= 12; $ARG[4] = 'PM'; } $ARG[0] =~ s/ap/$ARG[4]/; } if ($ARG[0] =~ /hh/) { $TIME[2] = sprintf("%02d",$TIME[2]); $ARG[0] =~ s/hh/$TIME[2]/; } else { $ARG[0] =~ s/h/$TIME[2]/; } if ($ARG[0] =~ /nn/) { $TIME[1] = sprintf("%02d",$TIME[1]); $ARG[0] =~ s/nn/$TIME[1]/; } else { $ARG[0] =~ s/n/$TIME[1]/; } if ($ARG[0] =~ /ss/) { $TIME[0] = sprintf ("%02d",$TIME[0]); $ARG[0] =~ s/ss/$TIME[0]/; } else { $ARG[0] =~ s/s/$TIME[0]/; } if ($ARG[0] =~ /ww2/) { @WEEK = ('Sun','Mon','Tues','Wed','Thu','Fri','Sat'); $ARG[0] =~ s/ww2/$WEEK[$TIME[6]]/; } elsif ($_[0] =~ /ww3/ ) { @WEEK = ('Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'); $ARG[0] =~ s/ww3/$WEEK[$TIME[6]]/; } else { @WEEK = ('日','月','火','水','木','金','土'); $ARG[0] =~ s/ww/$WEEK[$TIME[6]]/; } if ($ARG[0] =~ /mm2/) { @MONT = ('Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'); $ARG[0] =~ s/mm2/$MONT[$TIME[4]]/; } elsif ($ARG[0] =~ /mm3/) { @MONT = ('January','Februay','March','April','May','June','July','August','September','October','November','December'); $ARG[0] =~ s/mm3/$MONT[$TIME[4]]/; } elsif ($ARG[0] =~ /mm/) { $TIME[4] = sprintf ("%02d",$TIME[4] + 1); $ARG[0] =~ s/mm/$TIME[4]/; } else { $TIME[4] ++; $ARG[0] =~ s/m/$TIME[4]/; } return $ARG[0]; } ;# ========================== ;# Decode font-codes. ;# ========================== sub QueryString { if ($ENV{'REQUEST_METHOD'} eq 'POST') { read(STDIN, $QUERY_DATA, $ENV{'CONTENT_LENGTH'}); $QUERY_DATA .= $ENV{'QUERY_STRING'} if ($_[3]); } else { $QUERY_DATA = $ENV{'QUERY_STRING'}; } return &decode($QUERY_DATA,$_[0],$_[1],$_[2]); } sub decode { @TMP_DATA = @_; foreach (split("&", $TMP_DATA[0])) { ($name, $value) = split "="; $value =~ tr/+/ /; $value =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C", hex($1))/eg; &jcode'convert(*value,$TMP_DATA[3]) if ($TMP_DATA[3]); if ($TMP_DATA[1]) { $value =~ s/&/&/g; $value =~ s/"/"/g; $value =~ s//>/g; } else { $value =~ s///g; } $value =~ s/\t//g; if ($TMP_DATA[2] == 1) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; $value =~ s/\n/
/g; } elsif ($TMP_DATA[2] == 2) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; $value =~ s/\n//g; } elsif ($TMP_DATA[2] == 3) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; } elsif ($TMP_DATA[2] == 4) { $value =~ s/\r\n/\n/g; $value =~ s/\n/\r/g; } elsif ($TMP_DATA[2] == 5) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; $value =~ s/\n/\r\n/g; } $QUERY{$name} = $value; } return %QUERY; } ;# ========================== ;# File Read. ;# ========================== sub ReadFile { local(@FILE) = (); return -1 if (!-e $_[0]); return -2 if (!&LockCheck($_[0],$_[3])); return 0 if (!open(FILE,$_[0])); if ($_[1] || $_[2]) { $i = $j = 0; if ($_[5]) { $FILE[0] = ; } while () { s/\r|\n//g if ($_[4]); if (!$_[1] || $_[1] <= $j) { last if ($_[2] && $_[2] <= $i); push(@FILE, $_); $i ++; } $j ++; } } elsif ($_[3]) { $i = 0; while () { $FILE[$i] = $_; $i ++; } } else { @FILE = ; close(FILE); } return @FILE; } ;# ========================== ;# Data Read. ;# ========================== sub ReadData { local(%ARG) = (); foreach (@_) { @ARG = split(/=/, $_, 2); $ARG{$ARG[0]} = $ARG[1]; } undef @ARG; return %ARG; } ;# ========================== ;# Send Email. ;# ========================== sub SendMail { local($sendmail,$mailto,$mailcc,$mailbc,$from,$reply,$subject,$message,$html,$priority,@attend_file) = @_; return 0 if (!$mailto && !$mailcc && !$mailbc); return 0 if (!open(ML, "| $sendmail -t")); if ($html) { $type = 'html'; } else { $type = 'plain'; } print ML "X-HTTP-REFERER: $ENV{'HTTP_REFERER'}\n"; print ML "X-HTTP-USER-AGENT: $ENV{'HTTP_USER_AGENT'}\n"; print ML "X-REMOTE-ADDR: $ENV{'REMOTE_ADDR'}\n"; print ML "X-Priority: $priority\n" if ($priority > 0 && $priority <= 5); print ML "To: " . &encode($mailto) . "\n" if ($mailto); print ML "Cc: " . &encode($mailcc) . "\n" if ($mailcc); print ML "Bcc: " . &encode($mailbc) . "\n" if ($mailbc); print ML "From: " . &encode($from) . "\n" if ($from); print ML "Reply-To: " . &encode($reply) . "\n" if ($reply); print ML "Subject: " . &encode($subject) . "\n"; print ML "Content-Transfer-Encoding: 7bit\n"; if (@attend_file) { $bound = '===' . $$ . '==='; print ML "Content-Type: multipart/mixed; boundary=\"$bound\"\n\n"; print ML 'This is multipart message.' . "\n\n"; print ML "--$bound\n"; } print ML "Content-Type: text/$type\; charset=\"ISO-2022-JP\"\n\n"; print ML &jis($message) . "\n"; if (@attend_file) { foreach (@attend_file) { print ML "--$bound\n"; if (-e $_) { $openfile = $filename = $_; $filename =~ /([^\/\/\/]+$)/; $filename = $1; print ML "Content-Type: application/octet-stream; name=\"$filename\"\n"; print ML 'Content-Transfer-Encoding: Base64' . "\n"; print ML "Content-Disposition: attachment; filename=\"$filename\"\n\n"; if (open(FILE,"$openfile")) { $filedata .= $_ while(); close(FILE); print ML &base64encode($filedata); } print ML "\n"; $filedata = ''; } } print ML "--$bound\--\n"; } close(ML); return 1; } sub encode { local($en) = @_; local($ml) = ''; if ($en =~ /(.*)\s+<([\w-]+@[\w-]+\.[\w-\.]+)>/i) { $en = $1; $ml = $2; } if ($en =~ /[^\w\s\.\-\@\=\!\,\?\%\/\\\|\^\~\+\*\$\%\&\'\"\`\:\;\(\)\[\]\{\}\<\>\#]/) { $en = '=?ISO-2022-JP?B?' . &base64encode(jis($en)) . '?='; $en =~ s/\r\n//g; $en =~ s/\r//g; $en =~ s/\n//g; } if ($ml) { return "$en <$ml>"; } else { return $en; } } sub base64encode { local($_) = @_; local($chunk,$result); $base64_alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' . 'abcdefghijklmnopqrstuvwxyz' . '0123456789+/'; $base64_pad = '='; $uucode_alphabet = q|`!"#$%&'()*+,-./0123456789:;<=>?| . '@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_'; $uucode_pad = '`'; $tr_uucode = ' ' . $uucode_alphabet; $tr_uucode =~ s/(\W)/\\$1/g; $tr_base64 = "A".$base64_alphabet; $tr_base64 =~ s/(\W)/\\$1/g; while (s/^((.|\n){45})//) { $chunk = substr(pack("u", $&), $[+1, 60); eval qq{ \$chunk =~ tr|$tr_uucode|$tr_base64|; }; $result .= $chunk . "\n"; } if ($_) { $chunk = substr(pack("u", $_), $[+1, int((length($_)+2)/3)*4 - (45-length($_))%3); eval qq{ \$chunk =~ tr|$tr_uucode|$tr_base64|; }; $result .= $chunk . ($base64_pad x ((60 - length($chunk)) % 4)); } return $result; } sub jis { local($msg) = @_; &jcode'convert(*msg, 'jis'); return $msg; } ;# ========================== ;# Keyword Search. ;# ========================== sub SearchRecord { local($keyword,$mhmode,$ignore,@DATAS) = @_; local(@RESULT) = (); foreach (@DATAS) { $data = $_; if (SearchString($_,$keyword,$mhmode,$ignore)) { push(@RESULT,$data); } } return @RESULT; } sub SearchString { if (!$_[3]) { $_[0] =~ tr/[A-Z]/[a-z]/; $_[1] =~ tr/[A-Z]/[a-z]/; } if ($_[2] == 0) { foreach (split(" ", $_[1])) { return 0 unless (index($_[0],$_) >= 0); } return 1; } elsif ($_[2] == 1) { foreach (split(" ", $_[1])) { return 1 if (index($_[0],$_) >= 0); } return 0; } else { $i = 0; undef($seek); @STRING = (); foreach (split(/(&|\|)/, $_[1])) { $STRING[$i] .= $_; $i ++ unless ($_ eq '&' || $_ eq '|') } for ($i = 0; $i <= $#STRING; $i ++) { $key = $STRING[$i]; if ($STRING[$i] =~ /^&|\|/) { $opt = substr($key, 0, 1); $key = substr($key, 1); } $open = $1 if ($key =~ /^(\(+)/g); $clse = $1 if ($key =~ /(\)+)$/g); $key =~ s/\(//g; $key =~ s/\)//g; if ($key =~ /^!/) { $key =~ s/^!//g; $not = 1; } $find = 1 if (index($_[0],$key) >= 0); if ($not) { if ($find) { $find = 0; } else { $find = 1; } } $seek .= $opt . $open . $find . $clse; $find = $not = 0; $opt = $open = $clse = ''; } $seek =~ s/&/*/g; $seek =~ s/\|/+/g; $result = eval $seek; if ($result >= 1) { return 1; } else { return 0; } } } ;# ========================== ;# File Upload. ;# ========================== sub GetFile { @TMP_DATA = @_; $remain = $ENV{'CONTENT_LENGTH'}; binmode(STDIN); while ($remain) { $remain -= sysread(STDIN, $buf, $remain); $datas .= $buf; } while (1) { $header2 = index($datas, "\r\n\r\n", $header1) + 4; @headers = split("\r\n", substr($datas, $header1, $header2 - $header1)); foreach (@headers) { if (!$delimiter) { $delimiter = $_; } elsif (/^Content-Disposition: ([^;]*); name="([^;]*)"; filename="([^;]*)"/i) { $name = $2; $filename = $3; } elsif (/^Content-Disposition: ([^;]*); name="([^;]*)"/i) { $name = $2; } } $header3 = index($datas, "\r\n$delimiter", $header2); $size = $header3 - $header2; $value = substr($datas, $header2, $size); if (!$filename) { &jcode'convert(*value,$TMP_DATA[2]) if ($TMP_DATA[2]); if ($TMP_DATA[0]) { $value =~ s/&/&/g; $value =~ s/"/"/g; $value =~ s//>/g; } else { $value =~ s///g; } $value =~ s/\t//g; if ($TMP_DATA[1] == 1) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; $value =~ s/\n/
/g; } elsif ($TMP_DATA[1] == 2) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; $value =~ s/\n//g; } elsif ($TMP_DATA[1] == 3) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; } elsif ($TMP_DATA[1] == 4) { $value =~ s/\r\n/\n/g; $value =~ s/\n/\r/g; } elsif ($TMP_DATA[1] == 5) { $value =~ s/\r\n/\n/g; $value =~ s/\r/\n/g; $value =~ s/\n/\r\n/g; } } $QUERY{$name} = $value; $QUERY{"$name.name"} = $filename; $filename = ''; $header1 = $header3 + length("\r\n$delimiter"); if (substr($datas, $header1, 4) eq "--\r\n") { last; } else { $header1 += 2; if ($i++ > 32) { last; } next; } } return %QUERY; } ;# ========================== ;# Coding. ;# ========================== sub CryptString { local(@ARG) = @_; local(@Salt) = (); local(@Passwd) = (); @TIME = localtime(time); @RAND = ('0'..'9','A'..'Z','a'..'z','.','/'); $Salt[0] = $RAND[($TIME[0] + $TIME[1] * 60 + $TIME[2] * 60 * 60) % scalar(@RAND)] . $RAND[(time | (time << 15)) % scalar(@RAND)]; if (!$ARG[0]) { return -1 if (!eval { $Passwd[0] = crypt('check',$Salt[0]); }); return -1 if ($@); return crypt('check',$Salt[0]) eq $Passwd[0] ? 1 : 0; } if ($ARG[1]) { return -1 if (!eval { $Passwd[0] = crypt($ARG[0],$Salt[0]); }); return -1 if ($@); return $Passwd[0]; } if (length($ARG[0]) > 8) { $Passwd[1] = substr($ARG[0], 0, 8); $Passwd[2] = substr($ARG[0], 8); } else { $Passwd[1] = $ARG[0]; } $Salt[1] = substr($Passwd[1], -1, 1) . substr($Passwd[1], 0, 1); $Salt[2] = substr($Passwd[2], -1, 1) . substr($Passwd[2], 0, 1) if ($Passwd[2]); return -1 if (!eval { $Passwd[1] = crypt($Passwd[1],$Salt[1]); }); return -1 if ($@); $Passwd[2] = crypt($Passwd[2],$Salt[2]) if ($Passwd[2]); $Passwd[1] =~ s/^\$1\$//; $Passwd[2] =~ s/^\$1\$// if ($Passwd[2]); $Passwd[1] = substr($Passwd[1], 2); $Passwd[2] = substr($Passwd[2], 2) if ($Passwd[2]); $Passwd[0] = '%%%'; $Passwd[0] .= crypt($Passwd[1], $Salt[0]); $Passwd[0] .= '&&' . crypt($Passwd[2],$Salt[0]) if ($Passwd[2]); undef @ARG; return $Passwd[0]; } ;# ========================== ;# Decoding. ;# ========================== sub RecryptString { local(@ARG) = @_; local(@Salt) = (); local(@Passwd1) = (); local(@Passwd2) = (); if ($ARG[1] !~ /^%%%/) { $ARG[1] =~ s/^\$1\$//; return -1 if (!eval { $ARG[2] = crypt($ARG[0],$ARG[1]); }); return -1 if ($@); return $ARG[2] eq $ARG[1] ? 1 : 0; } $ARG[1] =~ s/^%%%//; if (length($ARG[0]) > 8) { $Passwd1[0] = substr($ARG[0], 0, 8); $Passwd2[0] = substr($ARG[0], 8); } else { $Passwd1[0] = $ARG[0]; } $Salt[0] = substr($Passwd1[0], -1, 1) . substr($Passwd1[0], 0, 1); $Salt[1] = substr($Passwd2[0], -1, 1) . substr($Passwd2[0], 0, 1) if ($Passwd2[0]); return -1 if (!eval { $Passwd1[1] = crypt($Passwd1[0],$Salt[0]); }); return -1 if ($@); $Passwd2[1] = crypt($Passwd2[0],$Salt[1]) if ($Passwd2[0]); $Passwd1[1] =~ s/^\$1\$//; $Passwd2[1] =~ s/^\$1\$// if ($Passwd2); $Passwd1[1] = substr($Passwd1[1], 2); $Passwd2[1] = substr($Passwd2[1], 2) if ($Passwd2[0]); ($Passwd1[2],$Passwd2[2]) = split(/&&/, $ARG[1]); if ($Passwd1[2] =~ /^\$1\$/) { $Passwd1[3] = substr($Passwd1[2], 4); $Passwd2[3] = substr($Passwd2[2], 4) if ($Passwd2[2]); } else { $Passwd1[3] = $Passwd1[2]; $Passwd2[3] = $Passwd2[2] if ($Passwd2[2]); } if (crypt($Passwd1[1],$Passwd1[3]) eq $Passwd1[2]) { return 1 if (!$Passwd2[2]); return 1 if (crypt($Passwd2[1],$Passwd2[3]) eq $Passwd2[2]); } undef @ARG; return 0; } ;# ========================== ;# Inline Link. ;# ========================== sub InlineLink { $_[0] = $_ if (!$_[0]); $_[0] =~ s/([^=^"^;]|^)((https?|ftp|gopher|telnet|news|wais|nntp|file):\/\/[\w|\:\@\-]+\.[\w|\:\!\#\%\=\&\-\|\@\~\+\.\?\/]+)/$1$2<\/a>/ig; $_[0] =~ s/([^=^"]|^)([\w\+-]+@[\w\+-]+\.[\w\+\.-]+)/$1$2<\/a>/ig; return $_[0]; } ;# ========================== ;# File Output. ;# ========================== sub FileOutput { return 0 if (!open(FILE,$_[0])); binmode(FILE); print while (); close(FILE); return 1; } ;# ========================== ;# Lock check. ;# ========================== sub LockCheck { return 1 if (!$_[1]); for (1 .. 5) { return 1 unless (-e "$_[0].lock"); sleep(1); } return 0; } ;# ========================== ;# File Lock. ;# ========================== sub FileLock { local($datafile,$lock,@DATA) = @_; if (!$lock) { return 0 if (!open(FILE,">$datafile")); print FILE @DATA; close(FILE); return 1; } if (!$$) { $ps = $ENV{'REMOTE_ADDR'}; } else { $ps = $$; } $tempfile = $datafile . $ps . '.tmp'; $lockfile = $datafile . '.lock'; return 0 if (!open(FILE,">$tempfile")); print FILE @DATA; close(FILE); for (1 .. 5) { if ($lock == 2) { if (eval{ symlink(".",$lockfile); }) { if (!rename($tempfile,$datafile)) { sleep(1); next; } unlink($lockfile); return 1; } if ($@) { unlink($tempfile); return -1; } } else { unless (-e $lockfile) { if (open(FILE,">$lockfile")) { close(FILE); if (!rename($tempfile,$datafile)) { sleep(1); next; } unlink($lockfile); return 1; } } } sleep(1); } unlink($tempfile) if (-e $tempfile); unlink($lockfile) if (-e $lockfile); return 0; } 1;