POTI-boardのログファイルの上限を2MBに

ぷち的ココロ♪

総レス数がまだ2800を超えた程度なのに、親記事のナンバーの低いスレが消えてしまっていました。
親記事ナンバー+5000レスをスレの消える寿命に設定するにはどうしたらいいのでしょうか?

スクリプトをちょっと見ただけなので間違いかもしれませんが
バッファに1000000byte読み込む処理があったので
logファイルの上限がおそらく約1Mbyteだと思います。
その上限を超えたので2800でレスが消えたのではないでしょうか
POTI-boardのログファイルの上限の1000000byteは15年前に設定されたものです。
パソコンに搭載されているメモリはこの15年で…。
今ではメモリ4GB…それでも少ないという時代になりましたが、15年前はハードディスクが8GBだったり…。
2倍の2MBに拡張しても問題なさそうな気がしたので、2倍の2000000byte…だと2MB以下になってしまうので該当箇所を
$buf=fread($fp,2097152);
$buf=fread($tp,2097152);
に書き換えました。
5MBのログに書き込み処理を行うと、2MBになる事を確認しました。

お絵かき掲示板交流サイトで使っているPOTI-boardのログの上限は5MBですが動作が重くなるようならログをリセットして運用するつもりです。
配布するスクリプトも5MB…だと、無料のサーバなどで問題がでるかもしれませんし、動作が重くなるかもしれません。
2倍の2MBならという判断です。

お絵かき掲示板 POTI-board Notice削減お絵かき掲示板 POTI-board Notice削減
if(isset($savepng)){
$dat['savetypes'].= "<option value='PNG'".$savepng.">PNG</option>\n";
}
if(isset($savejpeg)){
$dat['savetypes'].= "<option value='JPEG'".$savejpeg.">JPEG</option>\n";
}
保存形式をAUTO、PNG、JPEGから選択するテンプレートは今はほとんど使われていません。NEOでは何を選択してもPNGになるのであまり意味がありません。しかし、しぃペインターでは有効な設定なので、テンプレートに選択項目が無くてもNoticeが出ないように書き直しました。

お絵かき掲示板 POTI-board Notice削減お絵かき掲示板 POTI-board Notice削減
// if(!$com&&!@is_file($dest)) error(MSG008,$dest);

if(!$com&&!@is_file($dest)) error(MSG008);
画像が無い事を確認してエラー画面を表示しているのに、画像に関する処理をしようとしてNoticeがでていたので書き直しました。
<!--(// しぃで反映されない上にお絵かき画面でパレット変更できるのでコメント化
パレット<select name=palette><option value="" selected> デフォルト</option>
{$palette}
</select>
)-->
v1.32の MONO WHITEでコメントアウトされ、そのほかのテンプレートでも使用されていない機能でNoticeがでていたので、
//v1.32のMONO WHITEでコメントアウト、対応テンプレートが無いパレット選択用データ(selectタグ用option配列)
// $lines = file(PALETTEFILE);
// foreach ( $lines as $line ) {
// $line=preg_replace("/[\t\r\n]/","",$line);
// list($pid,$pname,) = explode(",", $line);
//if(isset($palette)){
// $dat['palette'] .= '<option value="'.$pid.'">'.CleanStr($pname)."</option>\n";
//}
// }
該当箇所をコメントアウトしました。

お絵かき掲示板 POTI-board Notice削減お絵かき掲示板 POTI-board Notice削減
if(isset($textonly) && $textonly){//画像なしの時
$upfile=$upfile_name=$pictmp=$picfile="";
if(!isset($resto)){$resto="";}
}
画像アップロード画面で、画像なしにチェックを入れた時に、Noticeが発生していたので、textonlyの時は画像に関する変数を空文字に。
また、変数が定義されていてtrueの時は…という処理をifの入れ子にしていましたが&&でつなぐだけで良かったので書き直しました。

お絵かき、レスでお絵かき、画像アップロード、レス画像アップロード、文字だけ…。
数時間テストしましたがとりあえずNoticeなし。
ただし、設置時にできる[1]を削除しないとNoticeが出ます。
ログの形式が[1]だけ異なっている事が原因なので、それを修正できればでなくなる筈なのですが…。
そして、管理画面で記事を削除するとNoticeが発生…。
2行程度ですが…。

この変更は、POTI-board改 v1.45.5 lot.181129に反映されました。

お絵かき掲示板はこちら。

POTI-boardのエラーを減らすために 動画再生編

PaintBBS NEOが動画の記録と再生に対応したので、絵板に動画へのリンクが増えて来ました。

動画を見ようとしてクリックすると…。

POTI-board お絵かき掲示板の改造

動画ファイルが存在しないというWarningが発生する事例が何件が…。
リロードしても動画ファイルは見当たらないまま…。

POTI-boardの動画再生のurlは画像のファイル名と紐付けられているので、続きから描いて画像のファイル名が変われば動画のurlも変わってしまいます。

つまり、掲示版を開いて動画のリンクをクリックしたタイミングによっては動画のファイルが無いかもしれません。
Google検索結果から動画のリンクを開いた時にも、動画がなくてWarningが発生していました。
if(file_exists($pchfile)){//動画が差し換えられていた時
$datasize = filesize($pchfile);
$size = getimagesize($picfile);
if(!$sp) $sp = PCH_SPEED;
$picw = $size[0];
$pich = $size[1];
$w = $picw;
$h = $pich + 26;
if($w < 200){$w = 200;}
if($h < 226){$h = 226;}
}
else{
$w=$h=$picw=$pich=$datasize="";
}
file_existsでファイルの存在を確認してから処理するようにしました。

POTI-board お絵かき掲示板の改造
動画が無い時は表示しないだけなのですが…。

POTI-board お絵かき掲示板の改造

.htaccessで、キャッシュの有効期限を過去にすればキャッシュされなくなるので問題ないのですが、投稿してもリロードしないと画面が更新されない、これはバグだ…と言われてしまったりもしているので、urlパラメータを追加してキャッシュを表示しないように。

さくらのブログの管理画面から記事を見るのリンクをクリックした時にurlのあとにつく、
?1542988451と同じ形式のurlパラメータです。
投稿するたびに変化するurlパラメータで、ブラウザに別のurlと認識させて、キャッシュを表示しないようにします。
<Files ~ "\.html?$">
<IfModule mod_headers.c>
Header set Pragma no-cache
Header set Cache-Control no-cache
Header set Expires "Thu, 01 Dec 1994 16:00:00 GMT"
</IfModule>
</Files>
.htaccessの使い方がわかっている方なら、これをコピペしてPOTI-boardのフォルダに入れるだけでHTMLファイルをキャッシュしないようにする事ができます。
サーバによってはうまくいかない場合もあるようですがさくらのレンタルサーバはこの設定で問題ありませんでした。
.htaccessでキャッシュの有効期限を過去にしたほうが、見た目もスマートだし掲示版を開いた時にキャッシュが表示される事もありません。
.htaccessで設定できない場合には有効かもしれない機能の追加…でした。

この変更は、POTI-board改 v1.45.3 lot.181122に反映されました。

お絵かき掲示板はこちら。

POTI-boardのエラーを減らすために 設置直後のNotice編

お絵かき掲示板交流サイトに4種類の掲示版を設置していましたが、PaintBBS NEOの描画アニメに対応できて、TwitterやFacebookに投稿した画像を表示できる仕組みも利用できるのはPOTI-boardだけだったので、6つの絵板をすべてPOTI-boardにしました。

そうなると…。
お絵かき掲示板の改造で注力するべきは、POTI-board…という事でNoticeを減らすための作業をすすめる事に。
前回の作業で、大量のNoticeはでなくなった筈だったのですが…。

POTI-board お絵かき掲示板の改造

まだログが20行存在していないのに過去の20行の二重投稿をチェックしようとしてNoticeが発生。
// 連続・二重投稿チェック (v1.32:仕様変更)
if($countline >= 21){//存在する行数のみチェック
$chkline=20;
}
else{
$chkline=$countline-1;
}
// for($i=0;$i<20;$i++){
for($i=0;$i<$chkline;$i++){
ログファイルが何行あるのかチェックして存在する行の数だけループするように書き換えました。

POTI-board お絵かき掲示板の改造

二重投稿のチェックが有効で、かつNoticeが出ない事を確認。
設置時にできる[1]のログの書式が他のものとは異なるため、[1]が残っているとNoticeが2行発生しますが、画面が埋まるほどのNoticeが発生する訳ではないので、許容範囲…ですね。

POTI-board お絵かき掲示板の改造

まだログが200行存在していないのに、過去の200行の画像重複をチェックしようとしてNoticeが発生。
// アップロード処理
if(isset($dest)){//未定義エラー対策
$countline=(count($line));
if($countline >= 201){//存在する行数のみチェック
$chkline=200;
}
else{
$chkline=$countline-1;
}
if($dest&&@file_exists($dest)){
// for($i=0;$i<200;$i++){ //画像重複チェック
for($i=0;$i<$chkline;$i++){ //画像重複チェック
こちらも、ログファイルが何行あるのかチェックして存在する行の数だけループするように書き換えました。

POTI-board お絵かき掲示板の改造

画像重複のチェックが有効で、かつNoticeが出ない事を確認しました。
// if($tree[$i]==""){
//空文字ではなく未定義になっている
if(!isset($tree[$i])){
また、カタログモードの時に、Noticeが発生していたのでしらべてみたら、空文字ではなく、未定義になっていたので書き直しました。

この変更は、POTI-board改 v1.45.3 lot.181122に反映されました。

お絵かき掲示板はこちら。

POTI-boardのメタタグにリンクのタグが入ると表示されてしまう

POTI-board メタタグにリンクのタグ

上のほうに、https://pbbs.sakura.ne.jp/のURLがでてしまっていますが…。
<meta property="og:description" content="<a href="https://pbbs.sakura.ne.jp/" target="_blank">https://pbbs.sakura.ne.jp/</a>">
のようのように、og:descriptionにリンクのタグが入るとこうなります。
コメントを表示するための変数からタグを除去して、別な変数として設定する事にしました。
//メタタグに使うコメントから
//タグを除去
$descriptioncom=strip_tags($com);

// 親記事格納
$dat['oya'][$oya] = compact('src','srcname','size','painttime','pch','continue','thumb','imgsrc','w','h','no','sub','name','now','com','descriptioncom','limit','skipres','resub','url','email','id','updatemark','trip','tab','fontcolor');
// 変数クリア
unset($src,$srcname,$size,$painttime,$pch,$continue,$thumb,$imgsrc,$w,$h,$no,$sub,$name,$now,$com,$descriptioncom,$limit,$skipres,$resub,$url,$email);
タグを除去したあと、テンプレートで別な変数として使えるようにしないといけないので、変数の一覧も変更しました。
<!--{each oya}-->
<meta property="og:description" content="{$oya/descriptioncom}" />
<!--{/each}-->
のように書けばスレッドの親のコメントからタグを除去したものをテンプレートに使う事ができるようになります。
使用例。
<!--SNS-->
<!--{def sharebutton}-->
<!--{each oya}-->
<meta name="Description" content="{$oya/descriptioncom}">

<meta name="twitter:card" content="summary" />
<meta property="og:title" content="[{$oya/no}] {$oya/sub} by {$oya/name} - {$title}" />
<meta property="og:type" content="article" />
<meta property="og:url" content="{$rooturl}{$self}?res={$oya/no}" />
<!--{def oya/src}-->
<meta property="og:image" content="{$rooturl}{$oya/imgsrc}" />
<!--{/def}-->
<meta property="og:site_name" content="" />
<meta property="og:description" content="{$oya/descriptioncom}" />
<!--{/each}-->
<!--{/def}-->

<!--/SNS-->

POTI-board用テンプレート PINK を配布します。: STP^3

配布しているテンプレートはこの変数に対応しています。
タグを除去した親のコメントをTwitterカードに表示できるようになります。
このSNS用のメタタグは、config.phpでシェアボタンを使う設定しないと出てきません。
積極的にお絵かき掲示板の存在をアピールしたい人もいればひっそりと描きたい人もいる筈なので切り替えられるようにしておきました。

この変更は、POTI-board改v1.45.2 lot.181110に反映されました。

お絵かき掲示板はこちら。

POTI-boardでしぃペインターを使う時の幅と高さを変更

お絵かき掲示板交流サイトは、Googleで「しぃペインター」で検索すると上位に出てきます。
でも、Javaの有償化とか…Macで唯一の頼りだったSafariがJavaの対応を終了したり…。
おそらくもう使う事ができなくなって終わりだろう…と思っていました。
ところが、CheerpJ Applet RunnerというChromeのプラグインを使えば、動作するらしい…。
以下はお絵かき掲示板Art.netのテキスト掲示版のそとさんの書き込みを抜粋したものです。
SetEnvIfNoCase Request_URI \.jar$ no-gzip dont-vary

と、記入した.htaccessファイルを作成して、
relmフォルダに配置することで動きました。(Apache2.2)
<script>
function cheerpJLoad() {
var jEnabled = navigator.javaEnabled();
if(!jEnabled){
var sN = document.createElement("script");
sN.src = "https://cjrtnc.leaningtech.com/latest/loader.js";
var s0 = document.getElementsByTagName("script")[0];
s0.parentNode.insertBefore(sN, s0);
sN.addEventListener("load", function(){ cheerpjInit(); }, false);
}
}
window.addEventListener("load", function() { cheerpJLoad(); }, false);
</script>
今後も必要になるので転載させていただきました。
ということは、今後もJavaアプレットが動くかもしれない…という事ですね。
POTI-boardでしぃペインターを使ってみると…。

CheerpJでしぃペインター

レイヤーやテクスチャなどのパレットがキャンバスを覆ってしまいます。
窓ボタンを押せば全画面表示になりますが動的パレットを使う事ができません。
BBSNoteには、アプレットフィットボタンがあるので横幅をモニターに合わせる事ができるのですが…。

しぃペインターの時の幅と高さをPaintBBSとは違う値に設定して調整する事にしました。
// $w = $picw + 150;
if(!$useneo && $shi){
$w = $picw + 465;//しぃぺの時の幅
$h = $pich + 120;//しぃぺの時の高さ
}
else{
$w = $picw + 150;//PaintBBSの時の幅
$h = $pich + 170;//PaintBBSの時の高さ
}

CheerpJでしぃペインター CheerpJでしぃペインター

しぃペインターのパレットを快適に使うには、最低でもこれだけの幅は必要…と判断しました。
また、しぃペインターではアプレットの高さをやや低めに設定しないと、投稿ボタンがキャンバスより上の位置になるためボタンを押しにくくなってしまいます。
そのあたりも考慮しました。

この変更は、POTI-board改v1.45.2 lot.181110に反映されました。

お絵かき掲示板はこちら。

POTI-boardのエラーを減らすためにE_NOTICE削減編

Noticeが投稿時に300行以上発生していたので修正しました。
また、設置時にできる[1]を編集すると、その後の書き込みでWarningが発生するので修正しました。

数値にNULLが入るので、(int)で処理

[1]を編集すると、連続投稿の時間を計算している箇所にNULLが入りWarningが発生するので…。
//文字列を整数に
$ltime = (int)$ltime;
if(RENZOKU && $time - $ltime < RENZOKU){error(MSG020,$dest);}
if(RENZOKU2 && $time - $ltime < RENZOKU2 && $upfile_name){error(MSG021,$dest);}

数値にNULLが入るので、(int)で処理

空文字だったところがint(0)になりました。

Warningが出ていますが、var_dump()で変数を確認すると出る箇所なので仕方がありません。通常の使用では発生しません。

投稿時に大量のNoticeが発生するのを修正投稿時に大量のNoticeが発生するのを修正

投稿時に大量のNoticeが発生。
ログがあまり多くなかった時にはあまり気にならなかったのですが、運営中のレス数が1600件ほどあるPOTI-boardではレスを送信するたびに300行以上のNoticeが発生しました。
// レス記事一括格納
if(isset($rres)){//未定義エラー対策
$dat['oya'][$oya]['res'] = $rres[$oya];
}

レスがついていないスレッドの数だけエラーが出るので、未定義の場合は処理しないように書き直しました。
その他、画像アップロードの時と、お絵かきの投稿の時と、文字だけの投稿の時に、それぞれ未定義になる変数が存在していたので空文字を入れるようにしました。
//未定義エラー対策
if(isset($picfile)){//お絵かきの時
$upfile=$upfile_name="";
if(!isset($resto)){$resto="";}//レスではなかった時
}
elseif(isset($upfile)){//画像アップロードの時
$pictmp=$picfile="";
if(!isset($resto)){$resto="";}
}
else{//文字だけの時
$upfile=$upfile_name=$pictmp=$picfile="";
if(!isset($resto)){$resto="";}
}
regist($name,$email,$sub,$com,$url,$pwd,$upfile,$upfile_name,$resto,$pictmp,$picfile);

htmltemplate.incの79行目で発生するNoticeも投稿時にくりかえし出てきます。
まず、var_dump()で変数の内容を確認。

投稿時に大量のNoticeが発生するのを修正
//未定義エラー対策
if(isset($match[1])){
$ind=$this->getIndex($match[1],$multilabels);
}
else{
$ind=$this->getIndex("",$multilabels);
}
($match[1]))が未定義の時は、代わりに空文字が入るようにしました。
この変更を行っても$indに入る文字列は同じである事を確認しました。

気を使った点…。
変数に空文字を入れて対処した事で動作がおかしくなっていないか?
画像アップロードに必要な変数に空文字が入れば画像がありませんとなるし、お絵かきの投稿の時に必要な変数に空文字が入ればやはり画像がありませんになってしまいます。

新規スレッドに画像アップロード、お絵かき、文字だけの投稿。
レスで画像アップロード、お絵かき、文字だけの投稿。
続きから描く、動画表示。
ひととおりテストして、運営している絵板サイトにも導入してトラブルが起きていない事を確認したので、公開版の候補にする事にしました。
それから…。
salt パラメータは必須ではありませんが、これを省略すると crypt() が作るハッシュが弱いものになってしまいます。 PHP 5.6 以降は、このパラメータを省略した場合に E_NOTICE が発生するようになりました。
time()をsaltに使い差し換え時の動作に問題がないことを確認しました。
//差し換え時の認識コード追加
if($type=='rep'){
// $repcode = substr(crypt(md5($no.getenv("REMOTE_ADDR").$pwd.date("Ymd", time()))),-8);
$repcode = substr(crypt(md5($no.getenv("REMOTE_ADDR").$pwd.date("Ymd", time())),time()),-8);
この変更は、POTI-board改v1.45.2 lot.181110に反映されました。

お絵かき掲示板はこちら。