2011年10月1期WebProg配布スクリプトの読めない部分を解説しちゃる
TOP カテ一覧 スレ一覧 削除依頼 ▼
・ 次のスレ
災害復興支援IT開発ボランティア Blogツール"teeter totter"を応援するスレ 天才WEBプログラマの方々に一生のお願い… プログラマーは団結して47氏を救え!!
配布スクリプトの読めない部分を解説しちゃる
1 :04/09/11 〜 最終レス :2011/11/05(土)?2BP(1960) Perl、PHPなんでもござれ。 配布スクリプトの中でよくわからん構文などがあったら解読&解説しちゃる。
2 : ここは他人のソースが読めない>>1 =本7の教えてスレです
3 : >>2 漏れがスレ立てるといっつも本7とか言われるYO!
4 : つまり糞スレしか立ててないということだな。
5 : >>1 >>3 ガンガレ! こっそり応援しちゃる
6 : じゃwemaっていうWIKI派生のスクリプト一式お願いします。
7 : >>5 マリガトー。 >>6 あくまで一部。 数行がどうしてもわからん!ってときに解説します。
8 : >>1 解説してください。 $str =~ s/"/"/g;#" セミコロンのあとの#"って意味があるんでつか? 答えは漏れも知ってるんでつが、>>1 さんの実力が知りたいんでつ。
9 : >>1 Wemaの一部ということで。 wema.cgi:289 if id.nil? or id == '' nfn = "#{dir}/#{Time.now.strftime("%Y%m%d%H%M%S")}#{$$}.txt" else nfn = "#{dir}/#{id.sub(/id/,'')}.txt" end ここの処理は何やってるんでしょ?
10 : よ-し、お姉さん質問しちゃうよ-- jcode.plの読み方がわかりません。 今はじぇーこーどぴーえると読んでいますが もっとかわいい呼び方を教えてください。
11 : おまいら、あんまり>>1 をイジメんなよ。 もう出てこれないだろうなw
12 : これでも>>1 は懲りずに別の教えてスレをまた立てるんだろうな
13 : なんだ、>>1 は一つも答えずに逃げたのか。
14 : >>1 ももういないと思うので>>8 の答えキボンage
15 : 意味っつーかコメントアウトしてるじゃん。
16 : 色が変になるのを止めてるんだろ
17 : "が1個しかないとエディタによっては色が変になってしまうってコトですね そのため対応する"をコメントにして記入してあると。
18 : 漏れの使ってるのではならない。 でも一つ目の"以降が行末まで全部色が変わっちゃうから"をエスケープしてる。
19 : google mapのJavaScriptヨロ
20 : マジレス希望。 グラフ出力のPHPコードらしいのだが、よく分からん。 誰か頭のいい人解説して下さい。 sub graphGet { my($len,$out,$min); my($max,$now,$width,$height,$gif_name,$gif_name2) = @_; if($now){ $len = int($now / $max * $width); if($len > $width){ $max = $width . 'px'; $out = "<img src=\"$GIF_URL/$gif_name\" width=\"$max\" height=\"$height\">"; }elsif($len <= 0){ $aaa = $max; $max = $width . 'px'; $out = "<img src=\"$GIF_URL/$gif_name2\" width=\"$max\" height=\"$height\" alt=\"$aaa / $now\">"; }else{ $max = $len . 'px'; $min = $width - $len;$min = $min . 'px'; $out = "<img src=\"$GIF_URL/$gif_name\" width=\"$max\" height=\"$height\">"; $out .= "<img src=\"$GIF_URL/$gif_name2\" width=\"$min\" height=\"$height\">"; } }else{ $max = $width . 'px'; $out = "<img src=\"$GIF_URL/$gif_name2\" width=\"$max\" height=\"$height\" alt=\"1\">"; } return $out; }
21 : >>20 どうみてもPerl
22 : 本当にありがとうございました
23 : >>21 え。perlなの? 解説よろしくお願い!
24 : >>23 #grapGetという名前の関数(サブルーチン)を定義 sub graphGet { #関数内だけで使うmy変数を宣言 my($len,$out,$min); #引数を変数に代入 my($max,$now,$width,$height,$gif_name,$gif_name2) = @_; 以下略 #$outを戻り値にして終了 return $out; }
25 : >>20 このスクリプトは恐らく何かの改造版。 一応動いてはいたがある日改造者のもとへ一通のメールが来た。 しかし改造したやつのレベルは低くオリジナルにあった不具合を解決できるはずもなかった。 「いい機会だ。このままサイトを閉鎖しよう」 そう思い立った改造者はユーザーに何の挨拶もなく消えていったのであった。 数年後、ユーザーがネットを検索していると得体の知れないサブルーチンだけが キャッシュとして残っていることに気づいた。 「まさかこの関数はあのスクリプトのものではないか!」 ユーザーはあの時の思いを熱く語ろうとしている。 そんな関数。
26 : >>20 $max, グラフの最大値 $now, グラフの表示値 $width, グラフ全体の幅 $height, グラフの高さ $gif_name, 表示値用の画像 $gif_name2 グラフ残りの部分用の画像 $out グラフのhtml
27 : >>24 お〜!ありがとうございます。 以下略と言うのが、ナマゴロシ。。 やっぱり、コレくらいのスクリプトだったら、すぐにパパパって分かっちゃうもんですか? >>25 ん〜、イミフだが 自作だって言ってたような気が。。。 >>26 レスありがとうございます。 ところで、$gif_name2 グラフ残りの部分用の画像 と言うのは何のことですか??背景?
28 : >>27 ┌───────────┬────────┐ │ $gif_name .│ $gif_name2 │ └───────────┴────────┘
29 : >>28 ありがとう。 $gif_name の部分がグラフで $gif_name2 は枠内の、グラフじゃない部分の埋め合わせのためにあるんだね!背景として枠を調整するためにある。という解釈でいいのかな?
30 : $page = ($page == int($page) ? $page : int($page + 1)); これの ? と : の意味が良くわかりません・・・。 どなたか教えてくださいm(_ _)m
31 : 解決しました
32 : usr/bin/perl sub uri_decode{ my $str = shift; $str =~ tr/+/ /; $str =~ s/%([0-9A-Fa-f][0-9A-Fa-f])/pack('H2', $1)/eg; return $str; } このpack('H2', $1)の意味がわかりません。教えてください。 検索してみたんですが'H'が意味する「ニブル」ってどういうものですか? '$1'ってところも記述ミスな気がするんですが
33 : >>32 http://e-words.jp/w/E3838BE38396E383AB.html http://www.kt.rim.or.jp/~kbk/perl-5.8/perlretut.html#extracting_matches 例えば $str = "%41"; の場合、$1 には "41" が代入される。これを "H2"、 つまり2桁のニブル表現と解釈してバイトデータに pack する。 "41" という文字列 → ニブルの 4 と 1 → 二進数の 0100 と 0001 → pack して 01000001 → 十進値 65 のバイトデータ → ASCII の "A"
34 : >>33 詳しくありがとうございます。 良く分かりました。 でも、"$1"と言うのはこの場合許されるんでしょうか? スカラ名の最初の一文字に数字を使用するのは好ましくないですよね? "$i"のミスタイプかも知れないのですが… ここらへんお願いします
35 : >34 $1、$2・・・は「スカラー変数」じゃないぞ。 「正規表現に関する特殊変数」だ。
36 : >>34 とりあえず示された URL のページくらいは読もうか。 perlvar にも $<digits> として載っている。 http://perldoc.jp/docs/perl/5.6.1/perlvar.pod >>35 $1、$2 …は「ユーザ定義変数」ではないがれっきとした「スカラー変数」 なので、その表現では君が本当に言わんとしている事が正しく伝わらない。 ちなみに「ユーザ定義の変数名や関数名に使える文字列」を指すには 「識別子」という単語があって、/^(?:[A-Za-z]|_\w)\w*\z/ にマッチする ものとなる。 http://www.kt.rim.or.jp/~kbk/perl5.005/perldata.html この命名規則に沿っていないのにエラー無しに使えていれば、それは 特殊変数という事だ。シンボリックリファレンスや encoding プラグマを 使えば無茶な名前も付けられるがお勧めはしない。
37 : このスクリプトの書き方で、おかしい所を指摘してくれませんか? #!/usr/bin/perl require "../lib/jcode.pl"; require "../lib/mimew.pl"; $mailto ='hoge@hogehoge.jp'; $subject ='タイトルだよ'; $mail = $cgi->('mail'); $name = $cgi->('name'); $kana = $cgi->('kana'); $subject = mimeencode($subject); open(MAIL, "| /usr/lib/sendmail -t"); print MAIL "To: $mailto\n"; print MAIL "From: $mail\n"; print MAIL "Subject: $subject\n"; print MAIL "Content-Type: text/plain;\n\n"; print MAIL "お名前は= $name\n"; print MAIL "フリガナは= $kana\n"; close(MAIL); 年始早々、このような低レベルの質問で申し訳ありません。 よろしくお願い致します。
38 : >>37 自作CGIを評価するスレ http://pc8.2ch.net/test/read.cgi/php/1049514428/
39 : >>35-36 助かりましたありがとうございました 今外出中で、携帯なので帰ったらURL見させてもらいます。
40 : >>38 なになに?どういうこと? 見たけど何かヒントあったの? あっちで聞けってことか...orz 教えてくれよ いや、教えてください。
41 : >37 はどこかで配布されてるスクリプトなのかね? そうでないのならスレ違いだ
42 : >37 20世紀のスクリプト
43 : >>41 スレ違い須磨祖。他ってくる
44 : スクリプト自体は少し前のもので、現在はもう作者の継続サイトはないようです。 しかも質問部分は長いのですが、「それでもよい」という方がいらっしゃいましたら解説お願いします。 この中の database.cgi の 312 行目以降すべて (キーワード処理部分と検索部分) が 全般にわたってまったくわかりません。一挙でなくて少しずつでもよいので、各行最後までお願いします。 http://hpcgi2.nifty.com/wanchan/dl.cgi/database.lzh?name=database.lzh&rootcheck=1
45 : >>44 311行以前もわかってないだろ
46 : 312 行目以降をお願いします。
47 : このスクリプトの解説をお願いします http://osiire.x0.com/uploader/upload.cgi?mode=dl&file=4591 キー1212
48 : >>47 スクリプトについているコメント通りとしか言いようがないです。 どこがわからないのか教えてください。
49 : じゃあ、とりあえず if(substr($buf, 0, 3) != '+OK') die($buf); $buf = _sendcmd("USER $user"); $buf = _sendcmd("PASS $pass"); $data = _sendcmd("STAT");//STAT -件数とサイズ取得 +OK 8 1234 sscanf($data, '+OK %d %d', $num, $size); を解説してもらえませんか
50 : まず、_sendcmdという関数が下の方にあると思うけど これは、POPサーバーにコマンドを送って結果の一行だけ受け取る関数 で、それを使って USER PASSの各コマンドでユーザー名とパスワードを送って STATで件数とサイズを取得している。 これらはPOPプロトコルのコマンドだから「POP コマンド」あたりでググると意味がわかると思う。
51 : >>49 それの何がわからないというの 文字列$bufの先頭3文字が'+OK'じゃなかったら$bufを表示して終了。 _sendcmd関数に引数"USER $user"を渡して戻り値を$bufに代入。 引数"PASS $pass"で同上。 引数"STAT"で戻り値を$dataに入れる。$dataのフォーマットはコメントに記載 $dataから件数とサイズをそれぞれ$numと$sizeへ代入する。
52 : お願いします。
53 : Perlで 1 while $MSG =~ s/^(\d+)(\d\d\d)/$1,$2/; の頭の"1"ってどういう意味ですか?
54 : >>52 >質問部分は長いのですが、「それでもよい」という方がいらっしゃいましたら解説お願いします。 そんな暇な人はいらっしゃらないようですね。
55 : wikiのページを見ていたらこんなのがありました。 ↓↓↓ #$fp = fopen( "php://stdin", "r" ); #$response = trim( fgets( $fp ) ); #fclose( $fp ); $response="yes"; これは、どういうことなのでしょうか? php://stdinとは何なのでしょうか?
56 : >>55 標準入力から一行読み込んで $response に代入、というのを コメントアウトして、$response は 'yes' 決め打ちにしている。 http://www.php.net/manual/ja/wrappers.php.php
57 : >if(substr($buf, 0, 3) != '+OK') die($buf); 質問主じゃないけどちょっとしつもーん。 これって、 if (substr($buf, 0, 3) != '+OK') {die($buf);} を省略してるんだよね? 省略した書き方っていろいろあるけど、他にはどんな感じで書けるんでしょ。 die($buf) if substr( $buf, 0, 3) != '+OK'; if (substr($buf, 0, 3) != '+OK') or die($buf); こんな感じでいいのかな。 あと、 !=は数字の比較とかに使うと思ってたんだけど、文字列の比較に使ってもOKなもの?
58 : if (substr($buf, 0, 3) != '+OK') or die($buf); じゃなくて if (substr($buf, 0, 3) == '+OK') or die($buf); かも。
59 : $fp = fsockopen($host, 80, &$errno, &$errstr, $time_out); if(!$fp) { echo "Connect Error! $errstr ($errno)"; }else { fputs($fp,$dat); if($timeout<time()) die("Time out Error!"); while (!feof($fp) && $he != "\r\n"){ $he= fgets($fp, 512); } while(!feof($fp) && time()<$timeout) { $line = fgets($fp,1024); よろ
60 : >>57-58 PHP http://www.php.net/manual/ja/language.control-structures.php http://www.php.net/manual/ja/language.operators.comparison.php http://www.php.net/manual/ja/language.operators.logical.php 【PHP】下らねぇ質問はここに書き込みやがれ Part19 http://pc8.2ch.net/test/read.cgi/php/1144513878/ Perl http://www.kt.rim.or.jp/~kbk/perl5.005/perlsyn.html http://perldoc.jp/docs/perl/5.6.1/perlop.pod の Equality Operators の項と Logical or and Exclusive Or の項 Perlコーディング初心者質問スレ Part 47 http://pc8.2ch.net/test/read.cgi/php/1141195171/
61 : ブックマークした!わざわざ調べてくれてありがと! 探す単語の目安がわからなくて見つからずに困ってたんだよね。
62 : 2chはsubbbs.cgi廃止したけど、なんでbbs.cgiがまともに走ってんの? どう考えてもスレ立てが出来なくなると思うんだけど。 誰か記述分かる人おながいします。
63 : これだけじゃたりないかもしれませんがお願いします。 if ($FORM{mode} eq 'i') { foreach ($startpage..$endpage) { if ($ThreadData[$_] eq '') { next; } my $icnt = $_ + 1; my $rcnt = $_ + 1; $icnt == $pageline ? $icnt = 0 : $icnt = $_ + 1; my ($key,$title,$cnt) = split (/\f/, $ThreadData[$_]); $ithread .= "$rcnt.<a accesskey=\"$icnt\" href=\"./read.cgi?bbs=$bbs&key=$key&ls=10&first=true&mode=i\">$title</a> ($cnt)<br>"; } $next = "<a href=./pageview.cgi?mode=i&bbs=$bbs&page=$nextpn>?次</a>" if $lpnum > $page; } href=\"./read.cgi?bbs=$bbs&key=$key&ls=10&first=true&mode=i\"の部分をいくら変えても反映されないのですが、これは他で制御しているんでしょうか・・?
64 : 事故解決しました
65 : >>62 bbs.cgiにスレ立て機能があるんだろ
66 : ここを解説してもらえませんか function convert($str) { if (function_exists('mb_convert_encoding')) { return mb_convert_encoding($str, "SJIS", "JIS,SJIS,UTF-8"); } elseif (function_exists('JcodeConvert')) { return JcodeConvert($str, 0, 2); } return true; } JISをSJISにしているだけなのでしょうか?
67 : >>66 たぶんそう。 mb_stringかJcodeConvertがあるかどうか調べて いずれかがあったら変換してるみたいだね。
68 : どうもです!
69 : >>65 どうやってもsubbbs.cgiに飛ぶだろ それとも記述書き換えたとかか?
70 : このスクリプトの説明をお願いします。 function ssl_encrypt($source,$type,$key){ //Assumes 1024 bit key and encrypts in chunks. $maxlength=117; $output=''; while($source){ $input= substr($source,0,$maxlength); $source=substr($source,$maxlength); if($type=='private'){ $ok= openssl_private_encrypt($input,$encrypted,$key); }else{ $ok= openssl_public_encrypt($input,$encrypted,$key); } $output.=$encrypted; } return $output; }
71 : 続き function ssl_decrypt($source,$type,$key){ // The raw PHP decryption functions appear to work // on 128 Byte chunks. So this decrypts long text // encrypted with ssl_encrypt(). $maxlength=128; $output=''; while($source){ $input= substr($source,0,$maxlength); $source=substr($source,$maxlength); if($type=='private'){ $ok= openssl_private_decrypt($input,$out,$key); }else{ $ok= openssl_public_decrypt($input,$out,$key); } $output.=$out; } return $output; }
72 : >>70-71 OpenSSLモジュールを使ってそれぞれ暗号化(encrypt)と復号化(decrypt)をしている関数に見える。 128バイトごとに分割しながら処理してるね。 OpenSSL関数やOpenSSLそのものについてはマニュアルやgoogle参照ということで。
73 : このスクリプトの解説をお願いします @log_lines=(); if(!$EST{html}){%Clog=();} local(@temp_lines,%temp_ref,$line,@kt,$kt,@Slog,$st_no,$end_no,$i=0,$j=0); $end_no=$EST{hyouji}*$LC_page -1; $st_no=$end_no - $EST{hyouji} +1; if(!$EST{html}){ open(IN,"$EST{log_path}$Spre_kt_file.cgi"); while($line=<IN>){ @Slog=split(/<>/,$line); @kt=split(/&/,$Slog[10]); foreach $kt(@kt){ if($LC_kt eq $kt){ $temp_ref{$Slog[0]}=$i; push(@temp_lines,$line); $i++; } $Clog{$kt}++; } } close(IN); 続く↓↓
74 : 続き foreach $line(sort{$b <=> $a}(keys %temp_ref)){ if($st_no<=$j && $j<=$end_no){ push(@log_lines,$temp_lines[$temp_ref{$line}]); } $j++; } undef(@temp_lines); undef(%temp_ref); } よろしくお願いします
75 : >>73-74 これは何のスクリプト? ログの中からなんらかの条件($LC_kt)に合ったものを読み込んで ログの一番最初のパラメータ(たぶん書き込みID?)でソートして、 指定されたページのところから 表示数文取り出して@log_linesに入れて返しているように見える。 けど、ログの形式もわかんないし、 いくつか使われてるグローバル変数の意味もわかんないし なんともいえない。 実際のログファイルを見ながらなら 読めるんじゃないかな。
76 : if(phpversion()>="4.1.0"){//PHP4.1.0以降対応 $_GET = array_map("_clean", $_GET); $_POST = array_map("_clean", $_POST);//11/8修正 extract($_GET); extract($_POST); extract($_COOKIE); extract($_SERVER); $upfile_type=_clean($_FILES['upfile']['type']); $upfile_size=$_FILES["upfile"]["size"]; $upfile_name=_clean($_FILES["upfile"]["name"]); $upfile=$_FILES["upfile"]["tmp_name"]; } を説明していただけませんか?
77 : >>76 register_globals onを前提に作ったスクリプトをoffにも対応させるためのもの と思われる
78 : 実際にはどうしているのでしょうか? 教えて頂ければ大変嬉しいです!
79 : $_POST と $_GET で渡ってきた値を _clean() という独自関数で 恐らくサニタイズしているようだね。 例えば $_POST['foo'] を $foo と使えるようにしている。 ttp://coronado.s8.xrea.com/php/function.extract.php ttp://coronado.s8.xrea.com/php/function.array-map.php $_COOKIE や $_SERVER はサニタイズしていないから危険だね。
80 : あと、アップロードしたファイルも $upfile を そのまま使っていそうだけど ttp://coronado.s8.xrea.com/php/function.is-uploaded-file.php ttp://coronado.s8.xrea.com/php/function.move-uploaded-file.php ttp://coronado.s8.xrea.com/php/features.file-upload.php でチェックすべき。
81 : >>76 レッツか
82 : >>76 バージョンを比較するなら version_compare() ttp://coronado.s8.xrea.com/php/function.version-compare.php の方が相応しいね。
83 : Perlで $ref->{q_line} = param("line") ne "" ? param("line") : $ref->{line}; というスクリプトの ? や、 : の使い方が分かりません。 何で検索していいのかも分かりません・・・orz
84 : >83 「条件演算子」で検索しる
85 : トンクス 真ん中が条件とは・・・
86 : >>83 そのサンプルに限ると3項演算子よりも $ref->{q_line} = param("line") || $ref->{line}; がシンプル。
87 : >>86 lineが0だとダメ
88 :2011/11/05(土)?2BP(1960) >>2 本7って何よ?
TOP カテ一覧 スレ一覧 削除依頼 ▲
・ 次のスレ
災害復興支援IT開発ボランティア Blogツール"teeter totter"を応援するスレ 天才WEBプログラマの方々に一生のお願い… プログラマーは団結して47氏を救え!!