"; //print_r($_POST); //echo "
get
"; //print_r($_GET); /* * P-BBS by ToR * http://php.s3.to * * 2000/12/02 pre 完成 * 2001/03/06 v1.0 完成ー * 2001/03/11 v1.1 HTML書き出すOnOff、書き込み後Locationで飛ばす、管理モードpass→apass * 2001/04/16 v1.2 過去ログ対応、>がつくと色変わる。デザイン変更 * 2001/04/24 v1.23 書き込み後表示関数化、ページング変更、管理モード実行後修正、ホスト表示、Re:[2] * 2001/05/04 v1.231 クッキーをHTMLに書き出してしまうバグ修正,過去ログモードの非表示
* 2001/05/17 v1.232 文字数制限、行数制限追加 * 2001/05/27 v1.24 autolink修正、書き込み後refreshで飛ばす * 2001/06/02 v1.25 GET投稿禁止、外部投稿禁止 * 2001/11/15 v1.26 >の後のスペース無くす。PHP3の時レスで
となるバグ修正 * 2002/05/25 v1.27 i18n削除、空白チェック修正 * * 2002/06/25 v1.3 register_globals=offに対応、各所修正、複数削除対応 * 2002/06/28 L96.L102 $_POST→$_GET、L202 $_SERVER[REQUEST_METHOD] * * シンプルな掲示板です。管理モード付 * 空のログファイルを用意して、パーミッションを606にしてください * HTMLを書き出す場合は、そのディレクトリが707か777じゃないとダメです */ //-------------設定ここから------------- /* に入れるタイトル */ $title1 = 'P-BBS'; /* 掲示板のTOPタイトル(HTML可)*/ $title2 = '<font size=5 face=Verdana color=gray><b>P-BBS</b></font>'; /* <body>タグ */ $body = '<body bgcolor="#ddf2ed" text="#444444" link="#0000AA">'; /* 管理者用パスワード。必ず変更して下さい。*/ $admin_pass = '0123'; /* ログ保存ファイル */ $logfile = 'bbs.log'; /* TOPページをHTMLに書き出すか (yes=1 no=0)*/ $htmlw = 0; /* 静的HTMLを書き出す場合のHTMLファイル */ $html_file = 'pbbs.html'; /* 戻り先(HOME)*/ $home = 'http://hogehoge.com'; /* 一ページあたりの表示記事数 */ $page_def = 10; /* 最大記録件数 これを越えると古い物から過去ログへ移ります。*/ $max = 30; /* 文字数制限(名前、題名、本文)全角だとこの半分です */ $maxn = 40; $maxs = 40; $maxv = 1500; /* 本文の改行数制限 */ $maxline = 25; /* 同一ホストからの連続投稿を制限 --> 秒数を記述するとその時間以上を経過しないと連続投稿できない*/ $w_regist = 30; /* 文中で自動リンクするかどうか(yes=1 no=0)*/ $autolink = 1; /* HTMLタグを有効にするか(yes=1 no=0)*/ $tag = 0; /* タイトル無しで投稿された場合 */ $mudai = '(無題)'; /* >がついた時の色 */ $re_color = "#225588"; /* ホストを表示するか(表示しない=0 <!-->内で表示=1 表示=2)*/ $hostview = 1; /* 外部書き込み禁止にする?(する=1,しない=0) */ define("GAIBU", 0); /* 使用するファイルロックのタイプ(mkdir=1 flock=2 使わない=0)*/ define("LOCKEY", 2); //通常は2でOK /* mkdirロックを使う時はlockという名でディレクトリを作成して777にしてください */ define("LOCK" , "lock/plock"); //lockの中に作るロックファイル名 /* 過去ログ作成する? */ $past_key = 1; /* 過去ログ番号ファイル */ $past_no = "pastno.log"; /* 過去ログ作成ディレクトリ(書き込み権限必要) */ $past_dir = "./"; /* 過去ログ一つに書き込む行数 */ $past_line= "50"; //---------設定ここまで-------------- function head(&$dat){ //ヘッダー表示部 global $logfile,$title1,$title2,$body,$htmlw,$max,$page_def; //クッキーを頂きます if(get_magic_quotes_gpc()) $p_bbs = $_COOKIE[p_bbs]; if(!$htmlw) list($r_name,$r_mail) = explode(",", $p_bbs); if($_GET[mode] == "resmsg"){ //レスの場合 $res = file($logfile); $flag = 0; while (list($key, $value) = each ($res)) { list($rno,$date,$name,$email,$sub,$com,$url) = explode("<>", $value); echo $rno; if ($_GET[no] == $rno){ $flag=1; break; } } if ($flag == 0) error("該当記事が見つかりません"); if(ereg("Re\[([0-9]+)\]:", $sub, $reg)){ $reg[1]++; $r_sub=ereg_replace("Re\[([0-9]+)\]:", "Re[$reg[1]]:", $sub); }elseif(ereg("^Re:", $sub)){ $r_sub=ereg_replace("^Re:", "Re[2]:", $sub); }else{ $r_sub = "Re:$sub"; } $r_com = ">$com"; $r_com = eregi_replace("<br( /)?>","\r>",$r_com); } $head='<html><head> <META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=Shift_JIS"> <title>'.$title1.' '; $dat=$head.$body.'
'.$title2.'

お名前
メール
題名 


URL 
削除キー (記事の削除用。英数字で8文字以内)

新しい記事から表示します。最高'.$max.'件の記事が記録され、それを超えると古い記事から過去ログへ移ります。
1回の表示で'.$page_def.'件を越える場合は、下のボタンを押すことで次の画面の記事を表示します。
'; } function foot(&$dat){ //フッター表示部 global $home,$past_key; $dat.='
No pass
[ ホーム ] [ 管理 ] '; if($past_key) $dat.='[ 過去ログ ]'; $dat.='

- P-BBS -
'; } function Main(&$dat){ //記事表示部 global $logfile,$page_def,$autolink,$re_color,$hostview; $view = file($logfile); $total = sizeof($view); $total2= $total; $page = $_GET[page]; (isset($page)) ? $start = $page : $start = 0; $end = $start + $page_def; $st = $start + 1; for($s = $start;$s < $end;$s++){ if(!$view[$s]) break; list($no,$now,$name,$email,$sub,$com,$url,$host,$pw) = explode("<>", $view[$s]); if($url){ $url = "http://$url";} if($email){ $name = "$name";} // >がある時は色変更 $com = eregi_replace("(^|>)(>[^<]*)", "\\1\\2", $com); // URL自動リンク if ($autolink) { $com=auto_link($com); } // Host表示形式 if($hostview==1){ $host=""; } elseif($hostview==2){ $host="[ $host ]"; } else{ $host=""; } $dat.='
['.$no.'] '; $dat.=''.$sub.'
'; $dat.=' Name:'.$name.' Date: '.$now.''; $dat.='

'.$com.'
'; $dat.='

'.$url.'
'.$host.'

'; $p++; } //end for $prev = $page - $page_def; $next = $page + $page_def; $dat.= sprintf("


%d 番目から %d 番目の記事を表示
Page:[ ",$st,$st+$p-1); ($page > 0) ? $dat.='<< ' : $dat.=' '; $p_no=1;$p_li=0; while ($total > 0) { if ($page == $p_li) { $dat.="$p_no "; }else{ $dat.=''.$p_no.' '; } $p_no++; $p_li = $p_li + $page_def; $total = $total - $page_def; } ($total2 > $next) ? $dat.=' >>' : $dat.=" "; $dat.=" ]\n"; } function regist(){ //ログ書き込み global $tag,$past_key,$maxn,$maxs,$maxv,$maxline; global $logfile,$max,$w_regist,$autolink,$mudai; if($_SERVER[REQUEST_METHOD] != "POST") error("不正な投稿をしないで下さい"); if(GAIBU && !eregi($_SERVER["PHP_SELF"],$_SERVER["HTTP_REFERER"])) error("外部から書き込みできません"); $name = $_POST[name]; $email = $_POST[email]; $com = $_POST[com]; $sub = $_POST[sub]; $url = $_POST[url]; $password = $_POST[password]; // フォーム内容をチェック if(!$name||ereg("^( | )*$",$name)){ error("名前が書き込まれていません"); } if(!$com||ereg("^( | |\t|\r|\n)*$",$com)){ error("本文が書き込まれていません"); } if(!$sub||ereg("^( | )*$",$sub)){ $sub=$mudai; } if(strlen($name) > $maxn){ error("名前が長すぎますっ!"); } if(strlen($sub) > $maxs){ error("タイトルが長すぎますっ!"); } if(strlen($com) > $maxv){ error("本文が長すぎますっ!"); } $times = time(); $check = file($logfile); $tail = sizeof($check); list($tno,$tdate,$tname,$tmail,$tsub,$tcom,,,$tpw,$ttime) = explode("<>", $check[0]); if($name == $tname && $com == $tcom) error("二重投稿は禁止です"); if ($w_regist && $times - $ttime < $w_regist) error("連続投稿はもうしばらく時間を置いてからお願い致します"); // 記事Noを採番 $no = $tno + 1; // ホスト名を取得 $addr = $_SERVER["REMOTE_ADDR"]; $host=@gethostbyaddr($addr); // 削除キーを暗号化 if ($password) { $PW = crypt(($password),aa); } $now = gmdate( "Y/m/d(D) H:i",time()+9*60*60); $url = ereg_replace( "^http://", "",$url); if (get_magic_quotes_gpc()) {//\を削除 $com = stripslashes($com); $sub = stripslashes($sub); $name = stripslashes($name); $email = stripslashes($email); $url = stripslashes($url); } if ($tag == 0){ $sub = htmlspecialchars($sub);//タグっ禁止 $name = htmlspecialchars($name); $com = htmlspecialchars($com); $email = htmlspecialchars($email); $url = htmlspecialchars($url); $com = str_replace("&", "&", $com); } $com = str_replace( "\r\n", "\r", $com); //改行文字の統一。 $com = str_replace( "\r", "\n", $com); /* \n数える(substr_countの代わり)*/ $temp = str_replace("\n", "\n"."a",$com); $str_cnt=strlen($temp)-strlen($com); if($str_cnt > $maxline){ error("行数が長すぎますっ!"); } $com = ereg_replace("\n(( | |\t)*\n){3,}","\n",$com);//連続する空行を一行 $com = str_replace("\n", "
", $com); //改行文字の前に
を代入する。 $new_msg="$no<>$now<>$name<>$email<>$sub<>$com<>$url<>$host<>$PW<>$times\n"; //クッキー保存 $cookvalue = implode(",", array($name,$email)); setcookie ("p_bbs", $cookvalue,time()+14*24*3600); /* 2週間で期限切れ */ $old_log = file($logfile); $line = sizeof($old_log); $new_log[0] = $new_msg;//先頭に新記事 if($past_key && $line >= $max){//はみ出した記事を過去ログへ for($s=$max; $s<=$line; $s++){//念の為複数行対応 past_log($old_log[$s-1]); } } for($i=1; $i<$max; $i++) {//最大記事数処理 $new_log[$i] = $old_log[$i-1]; } renewlog($new_log);//ログ更新 } function usrdel(){ //ユーザー削除 global $logfile; if ($_POST[no] == "" || $_POST[pwd] == "") error("削除Noまたは削除キーが入力モレです"); $logall = file($logfile); $flag=0; while(list(,$lines)=each($logall)){ list($ono,$dat,$name,$email,$sub,$com,$url,$host,$opas) = explode("<>",$lines); if ($_POST[no] == $ono) { $flag=1; $pass=$opas; } else { $pushlog[]=$lines; } } if ($flag == 0) { error("該当記事が見当たりません"); } if ($pass == "") { error("該当記事には削除キーが設定されていません"); } // 削除キーを照合 $match = crypt(($_POST[pwd]),aa); if (($match != $pass)) { error("削除キーが違います"); } // ログを更新 renewlog($pushlog); } function admin(){ //管理機能 global $admin_pass,$logfile,$head,$body; if ($_POST[apass] && $_POST[apass] != "$admin_pass") error("パスワードが違います"); echo $head.$body; echo "[掲示板に戻る]\n"; echo "
\n"; echo "管理モード\n"; echo "
\n"; if (!$_POST[apass]) { echo "

パスワードを入力して下さい

\n"; echo "
\n"; echo "\n"; echo ""; echo "
\n"; }else { // 削除処理 if (is_array($_POST[del])) { // 削除情報をマッチングし更新 $delall = file($logfile); for ($i=0; $i",$delall[$i]); if (in_array($no,$_POST[del])) $delall[$i] = ""; } // ログを更新 renewlog($delall); } // 削除画面を表示 echo "
\n"; echo "\n"; echo "\n"; echo "

削除したい記事のチェックボックスにチェックを入れ、削除ボタンを押して下さい。\n"; echo "

\n"; echo ""; echo ""; echo "\n"; $delmode = file($logfile); while (list($l,$val)=@each($delmode)){ list($no,$date,$name,$email,$sub,$com,$url, $host,$pw,$tail,$w,$h,$time,$chk) = explode("<>",$val); list($date,$dmy) = split("\(", $date); if ($email) { $name="$name"; } $com = str_replace("
","",$com); $com = strip_tags($com); if(strlen($com) > 60){ $com = substr($com,0,60) . " ."; } echo ($l % 2) ? "" : ""; echo ""; echo ""; echo ""; echo "\n\n"; } echo "
削除記事No投稿日題名投稿者コメントホスト名
$no$date$sub$name$com$host
\n"; echo "

"; echo "

\n"; } echo "
\n"; } function renewlog($arrline){//ログ更新 入力:配列 global $logfile; $fp = fopen($logfile, "w"); flock($fp, 2); fputs($fp, implode('',$arrline)); fclose($fp); } function MakeHtml(){ //HTML生成 global $html_file; head($buf); Main($buf); foot($buf); $hp = @fopen ($html_file,"w"); flock($hp,2); fputs($hp, $buf); fclose($hp); } function ShowHtml(){ head($buf); Main($buf); foot($buf); echo $buf; } function past_log($data){//過去ログ作成 global $past_no,$past_dir,$past_line,$autolink; $fc = @fopen($past_no, "r") or die(__LINE__.$past_no."が開けません"); $count = fgets($fc, 10); fclose($fc); $pastfile = $past_dir."index".$count.".html"; if(file_exists($pastfile)) $past = file($pastfile); if(sizeof($past) > $past_line){ $count++; $pf = fopen($past_no, "w"); fputs($pf, $count); fclose($pf); $pastfile = $past_dir."index".$count.".html"; $past = ""; } list($pno,$pdate,$pname,$pemail,$psub, $pcom,$purl,$pho,$ppw) = explode("<>", $data); if($purl){ $purl = "HP";} if($pemail){ $pname = "$pname";} // >がある時は色変更 $pcom = eregi_replace("(>)([^<]*)", "\\1\\2", $pcom); // URL自動リンク if ($autolink) { $pcom=auto_link($pcom); } $dat.="
[$pno] $psub Name:$pname Date:$pdate $purl
    $pcom
\n"; $np = fopen($pastfile, "w"); fputs($np, $dat); if($past){ while(list(, $val)=each($past)){ fputs($np, $val); } } fclose($np); } function past_view(){ global $past_no,$past_dir,$past_line,$body; $fc = @fopen($past_no, "r") or die(__LINE__.$past_no."が開けません"); $count = fgets($fc, 10); fclose($fc); $pno = htmlspecialchars($_GET[pno]); if(!$pno) $pno = $count; echo '■ 過去ログ '.$pno.' ■ '.$body.'[掲示板に戻る]
■ 過去ログ '.$pno.' ■

new← '; $pastkey = $count; while ($pastkey > 0) { if ($pno == $pastkey) { echo "[$pastkey]"; } else { echo "[$pastkey]"; } $pastkey--; } echo ' →old

'.$past_line.'件ずつ表示'; $pastfile = $past_dir."index".$pno.".html"; if(!file_exists($pastfile)) error("
過去ログがみつかりません"); include($pastfile); die(""); } function auto_link($proto){//自動リンク $proto = ereg_replace("(https?|ftp|news)(://[[:alnum:]\+\$\;\?\.%,!#~*/:@&=_-]+)","\\1\\2",$proto); return $proto; } function error($mes){ //エラーフォーマット global $body; ?>







"; break; case 'admin': admin(); break; case 'usrdel': usrdel(); if($htmlw) MakeHtml(); ShowHtml(); break; case 'past': past_view(); break; default: ShowHtml(); break; endswitch; ?>