トップページphp
1001コメント299KB

【PHP】下らねぇ質問はID出して書き込みやがれ 90

■ このスレッドは過去ログ倉庫に格納されています
00012009/11/14(土) 17:31:22ID:???
質問者はまず>>1を良く読むこと(必須!)
過去スレ、関連スレ、FAQなどは>>2-10辺り
次スレは>>980が立てる。10分以内に立たない場合、宣言してから立てたい人が立てること。

◆前スレ
【PHP】下らねぇ質問はID出して書き込みやがれ 89
http://pc11.2ch.net/test/read.cgi/php/1255263534/

◆質問用テンプレ
【OS名】vine linux
【PHPのバージョン】php5.26
【連携ソフトウェア】mysql
【質問内容】

◆質問する時の注意
・ スレを上げて自分のIDを表示させること。(メール欄に何も記述しない。専ブラのsageチェックを外す)
・ 己の行った操作、変更などを詳しく明記すること。
・ エラーメッセージはそのまま表記すること。「エラーが出ます」だけでは回答不可。
・ 質問者として、態度をわきまえること。
・ 事前に関連リンクの公式マニュアル、リファレンス本くらいはちゃんと目を通しておくこと。
(PHPで最良の教本はこの公式マニュアル。市販の書籍は嘘が多いので鵜呑みにしない。)

◆質問後の注意
・2回目以降は最初に質問した際のレス番号を入れて、偽者防止に必ずIDを表示させること。
・解決しなくても回答をもらった場合はお礼を言うこと。
 (荒らし、煽りは除く。煽られたときも、無闇に反論せずスルーすること。)

◆回答者への注意
・誰にレスしているのか分からないと困るので、>>(アンカー)をつけて回答すること。

【その他諸注意】
・SQL・正規表現・PEAR・テンプレート(Smarty等)・フレームワークは各該当スレへ
001182009/11/16(月) 11:56:21ID:???
>>9

他のサンプルコードは動いていました
似たようなコードを実行したときには、このようにphpの内容がブラウザに出力されていませんでした

>>9さんの言われているように、今FireBugでスクリプトを開いて見てみたところ、ソースが(<?php〜?>の中が)表示されていました
http://localhostから出力したからなのか、自分には知識が乏しいので分かりませんが、こういう場合はどのようにすれば解消するのでしょうか?


>>10

そうなのでしょうか
よく分からないのですが、一応他のサンプルなどは動いています
ただし、それらが動作するからといってApacheに関連付けられているのかは自分には分かっていないのですが・・・

001282009/11/16(月) 12:05:29ID:???
ごめんなさい、書き忘れました

結局この場合、上記のサンプルコードが間違っているのではなく、自分のPHP又はApacheの設定がおかしいという事なのでしょうか?
一応単純に
<? php
print "山田";
?>
と打つと、ブラウザには(localhostから出力していますが)山田と表示されます
0013nobodyさん2009/11/16(月) 13:17:29ID:???
>>1
001482009/11/16(月) 13:18:33ID:???
再びごめんなさい・・・。ありがとうございます、問題が解決しました。お騒がせしました
0015nobodyさん2009/11/16(月) 13:20:55ID:???
はい?
0016nobodyさん2009/11/16(月) 13:32:47ID:???
せめて何だったのか書いてくれるとあなたの書き込みが無駄にならずにすむ。
001782009/11/16(月) 14:11:11ID:bvqRdc2u
すみません、>>14は自分ではありません・・・
001882009/11/16(月) 14:29:25ID:bvqRdc2u
今コマンドプロンプトから構文エラーチェックをしてみたのですが、構文エラーなしと書かれていました
う〜ん、なんでブラウザにprint後のコードが出力されるのでしょうか・・・?
0019nobodyさん2009/11/16(月) 14:56:43ID:+MFbLdTc
phpスクリプトをシンボリックリンクで置くのはダメなんでしょうか?
hoge.php はちゃんと動くんですが,
他の場所に hoge.php を置いてシンボリックリンクで参照すると
403 Forbidden になります.
CentOS + lighttpd + php-cgi です.
0020nobodyさん2009/11/16(月) 15:14:29ID:???
>>19
シンボリックリンク使える。
webサーバの設定でシンボリックリンクの許可をしておかないと駄目
lighttpdは使った事無いけど、
ググったらでてきた↓↓の設定はしてある?

server.follow-symlink = "enable"
0021nobodyさん2009/11/16(月) 17:02:14ID:???
>>18
ソースうp
002282009/11/16(月) 17:32:02ID:bvqRdc2u
>>21

>>7-8にコードは書いております
構文チェックはphp -lで行いました
0023nobodyさん2009/11/16(月) 18:18:13ID:???
データベースに「"」を含む項目あるか?
0024nobodyさん2009/11/16(月) 18:40:26ID:???
いやだから.phpファイルがPHPに関連付けられてないからでしょ
0025nobodyさん2009/11/16(月) 18:55:01ID:???
php そのファイル で動きますか?

apacheとかIISは分かります?

0026nobodyさん2009/11/16(月) 20:34:49ID:HkdbmVie
javascriptで、テキストボックスに文字列を追加していきたいんですがどうやったらいいでしょうか。
 
具体的には、1ページ内に、
”明日””今日””昨日”のように複数の文字列の下に、追加ボタンをおいて、
押された順番に、例えば、
明日昨日今日と押したら、
明日
昨日
今日
となるように、
テキストボックスに改行しながら文字列を追加していくような感じのを作りたいんです。

よろしくお願いします<m(__)m>
0027nobodyさん2009/11/16(月) 20:45:41ID:HkdbmVie
すいませんこちらPHP専用のようでした
取り消してこちらに移動させてもらいます<m(__)m>

△▲ WebProg 初心者の質問 Part21 ▼▽
http://pc11.2ch.net/test/read.cgi/php/1257701535/
0028nobodyさん2009/11/16(月) 22:35:06ID:???
>>8
<?からBRの後の>がタグと解釈されてるだけ、だな。
ブラウザのソースの表示で見たら、全部見えるかも。
0029nobodyさん2009/11/16(月) 23:19:35ID:???
cli版はモジュールとして動かすのと挙動が同じだと思ってるksな8
0030nobodyさん2009/11/16(月) 23:40:57ID:DxyMrPHB
$a['test']['a1'] = 1;
$a['test']['a2'] = 2;

$b['test']['b3'] = 3;
$b['test']['b4'] = 4;

上記のような配列があり、array_merge()的な手法で下記のように結合したいのですがどうすればいいでしょうか?

$ab = array {
 ["test"]=>
  array {
   ["a1"] => 1
   ["a2"] => 2
   ["b3"] => 3
   ["b4"] => 4
 }
}

ちなみに、array_merge()では["test"]キーで上書きされてしまいます。
よろしくお願いします。
0031nobodyさん2009/11/16(月) 23:55:57ID:???
>>30
惜しい
array_merge_recursive()
0032nobodyさん2009/11/17(火) 00:02:14ID:149D2nEE
>>31
うぉぉおおぉ!
ありがとうございます!!
0033nobodyさん2009/11/17(火) 00:07:29ID:???
$c = array_merge_recursive($a,$b);
0034nobodyさん2009/11/17(火) 10:32:58ID:???
それphp5.3からじゃん
ほんと使えねえksだな
0035nobodyさん2009/11/17(火) 11:03:39ID:???
どこの誤爆かな?
0036nobodyさん2009/11/18(水) 03:36:08ID:/HH3qrl4
PHP5.3の開発環境でデータベース接続に関してですが
PEAR::DBとPEAR::MDB2とPDOの3つでテストしているのですが
MySQLとPostgreSQLに関しては上記の3種類で問題なくselectを発行して結果が返ってくるのですが
SQLite2のデータベースファイルに関してですがPDOでは問題ないのですが
PEAR::DBとPEAR::MDB2で問題が発生しました。
それぞれ接続
$db = DB::connect('sqlite:///ファイル名');
$db = MDB2::connect('sqlite:///ファイル名');
って感じで書いています。

PEAR::DB用
$result = $db->query(SELECT文);
while($row = $result->fetchRow(DB_FETCHMODE_ASSOC)){
 print_r($row);
 echo "<br>";
}

PEAR::MDB2用
$result = $db->query(SELECT文);
while($row = $result->fetchRow(MDB2_FETCHMODE_ASSOC)){
 print_r($row);
 echo "<br>";
}
としてそれぞれ処理しているのですがループに一回も入らず終了してしまいます。
同じソースをPHP5.2.1の環境で使う場合は問題なく動きました。

MDB2のバージョンは2.4.1
MDB2_Driver_sqliteのバージョンは1.4.1を利用しています。
なにか対処の方法ってありますか?
0037nobodyさん2009/11/18(水) 03:49:00ID:???
とりあえず変数の中身やPHPのエラーを表示させてみたら?
0038nobodyさん2009/11/18(水) 04:13:07ID:/HH3qrl4
>>37
どうもです。とりあえず書き込みした後テストしてわかったのですが
キモはdisconnectみたいです。
>>36で書いた処理は大まかな処理で実際にはDB接続&SQL発行部分はクラス化していて
大まかな処理は(下記はPEAR::DB用でPEAR::MDB2利用時にはDBの部分をMDB2にしてある)
$sql_UTF8 = "SET NAMES utf8";
$db = DB::connect($this->DB_connect);
if (DB::isError( $db )) {
die($db->getMessage());
}
$res = $db->query($sql_UTF8);
$result = $db->query($sql);
if (DB::isError( $result )) {
die($result->getMessage());
}
$db->disconnect();
return $result;
って感じの処理です。
PHP5.3環境においてSQLite利用時のみ$db->disconnect()の段階で取得していたSQLの結果を破棄してしまっているようです。
$db->disconnect();をコメントアウトしておくと取得できました。
PostgreSQLとMySQLは保持したまま。

また、PHP5.2.1環境下ではSQLite環境下でも$db->disconnect();しても値は残ったままのようです。

なにかしら対策の方法ってありますか?
それとも俺の書き方自身に問題があるでしょうか?
0039nobodyさん2009/11/18(水) 07:17:47ID:???
>>38
sqlite_close()の中で結果セットまで削除する仕様が原因だね
MySQLではmysql_close()が呼ばれていても
"mysql result"リソースのデストラクタが働くまでは参照可能
嘘言ってたら許してくれ

まぁ実装に左右されたくなかったら
結果セットが必要なくなってから切断する設計にするべき
0040nobodyさん2009/11/18(水) 10:00:16ID:xkg9vx1z
mysqlのpdoを使いたいのですがwindowsではどのようにしてインストールと設定を行うのでしょうか?
php5.2.10です
0041nobodyさん2009/11/18(水) 10:52:23ID:???
http://php.net/manual/ja/book.pdo.php
書いてあるよ
0042nobodyさん2009/11/18(水) 12:27:53ID:/HH3qrl4
>>39
ありがとうございました。
>sqlite_close()の中で結果セットまで削除する仕様が原因だね
PEAR::DBにしてもPEAR::MDB2にしても各DB関数のラッパーと考えると
PHPのバージョンで>sqlite_close()の挙動が変わったと言うことですね。

>結果セットが必要なくなってから切断する設計にするべき
さてこれどう実装したものか。
俺の実装の仕方が
1.PHPメイン

2.SQL文生成クラス

3.SQL送信クラス(>>38はその一部)
ってやり方やっているんだよね。
2.でメインのPHPから渡された引数を元にSQL文を生成して
3.で2.で生成されたSQL文をDBに接続してSQL発行してDB切断
で処理が2.に戻ってwhile($row = $result->fetchRow(DB_FETCHMODE_ASSOC)){でループさせて結果を取得
って一連の流れをどうにかしないとダメって事か?さてどう作り直したらいい事か?なんかアイディアありませんか?
0043nobodyさん2009/11/18(水) 12:29:21ID:???
普通はSQL発行するたびに接続と切断を繰り返したりしないかと
0044nobodyさん2009/11/18(水) 12:38:39ID:/HH3qrl4
>>43
一回の処理でSQLが発行されるのは1回がほとんどだからこの様な実装方式にしています。
0045nobodyさん2009/11/18(水) 12:38:54ID:???
そうですか
0046nobodyさん2009/11/18(水) 12:55:03ID:???
DBから結果が返ったら、さっさと自分の側に取り込まないか?
取り込んどきゃ、ライブラリ側管理のデータがどうなろうが影響無いと思うんだが。

まあ、大抵ちょー大量に返ってくるというのなら、また違うかもしれん。
0047nobodyさん2009/11/18(水) 13:18:45ID:???
>>46
だからその処理は2.のクラスでやっている。
で取得したDBのデータそのものを使うのは1.の部分。
ちなみに3.のクラスはSQL送信だけではなくて
PEAR::DB、PEAR:MDB2、PDOのラッパー(実行環境によって使えるライブラリが変わったときにソースの修正をせずに済むようにするため)
としてさらにはMySQL、PostgreSQL、SQLiteのラッパーとしての
役割を持たせた物。
だから下手に2.の部分と統合されられない。
0048nobodyさん2009/11/18(水) 13:23:33ID:???
なんでSQL文生成クラスがバッファリングw
DB駆動クラス(他から見れば、そいつがDBと言ってもいい)がやるならともかく。
0049nobodyさん2009/11/18(水) 13:38:27ID:???
>>47
急に偉そうになったな
ルールも守ってないし
0050nobodyさん2009/11/18(水) 13:45:40ID:/HH3qrl4
>>48
SQL生成クラスって書き方したが
実際には
・SQLの生成
・DB送信/管理クラスにSQLを送る
・結果セットからwhile($row = $result->fetchRow(DB_FETCHMODE_ASSOC)){でループさせて配列に格納。
・配列をメイン処理に返す
って感じの処理です。
さらにこの「SQL生成クラス」に関してですが一つだけではなくて2つあります。

一つはselect専用のDB検索用
もう一つはInsert/Update/Deleteを発行するDB操作用。
分けた理由は管理者画面においては両方を使うが
一般ユーザ利用の部分に必要なのはDB検索用の方だけだから
ユーザ利用の方でバクなどでのセキュリティー対策として
一つにしておいてDB操作の処理のメソッドが万が一呼ばれることの内容にするため
(自分がソース間違えて呼び出したりなどに対する自己防衛と)
や一般ユーザ利用部分の軽量化のため。


>>49
>ルールも守ってないし
2chビューワでいつもの癖でsageのチェックボックスつけて送信してしまいました。
0051nobodyさん2009/11/18(水) 13:47:55ID:???
>>50
>だからその処理は2.のクラスでやっている。
などと言ってるけどその設計から見直したら?っていう話なのでは?
アドバイスしても「俺のクラスではこうなんだ」としか言われなかったら
はいそうですかどうぞご自由にと何も言うことなくなる。
0052nobodyさん2009/11/18(水) 14:01:36ID:/HH3qrl4
>>51
現状できあがったシステムで(今まではPEAR::DB+PostgreSQLの環境)
PEAR::DB、PEAR::MDB2、PDOやMySQL、PostgreSQL、SQLiteなマルチな環境下で動くようにバージョンアップ作業していたときに
ついでに5.3での挙動もチェックしちゃえってテストしていたときに発生した問題で
根本的な設計をし直したらシステム全体も書き換えになってしまうので最低限の変更でなんとかならないかと今回の質問をしたのです。
って内情まで説明しないとダメですか?
0053nobodyさん2009/11/18(水) 14:07:58ID:???
あのね、自分の思ってることが言葉で説明しなくても自動的に他人に伝わることはありえないんだよ?
0054nobodyさん2009/11/18(水) 14:20:43ID:???
ふむふむ、クラスの内部でちょこっとデータ保持するようにすると、
システム全体も書き換えになってしまう、と。

どんな作りやねんw

まあそれでも、他者が作ったそういうものでも何とかしなきゃならん仕事での立場だとしたら、
もしそうならちょこっと同情はする。
0055nobodyさん2009/11/18(水) 14:22:49ID:???
>>49
お前みたいな知識も無い素人PHP外野専門はROMってろ
0056nobodyさん2009/11/18(水) 14:38:02ID:/HH3qrl4
>>54
>システム全体も書き換えになってしまう、と。
ごめん。書き方が変だった。
このシステム全体はSQL周りのクラスって事。

本来はSQL送信/管理しているクラスだけですませたかった。
SQL生成や取得した結果セット用のクラスは極力いじりたくなかった。

自分でも「SQL生成や取得した結果セット用」クラスまでいじるなら
「SQL送信/管理クラス」に今まで一つだったメソッドを
・接続メソッド
・SQL送信メソッド
・接続解除メソッド
にわけて
「SQL生成や取得した結果セット用」内からは今までは一回だけメソッドを呼び出していたのを
それぞれ上記のメソッドを順番で呼び出せば済むって事はわかってているんですよね。

それかPHP5.3利用時にはSQLite利用時はPDO限定にするかって事ですね。

後、今環境が無いのですが試せてないのですが
5.2.1ではsqlite_close()後も結果セットは保持されていますけど
sqlite_close()の挙動ですがPHPも5.2.1ではテストしているけど5.2.1以降の5.2系では挙動って変わっていますか?
0057nobodyさん2009/11/18(水) 14:46:27ID:xi1WciP2
GDを使って画像のサイズを取得しようとしています。
$images = getimagesize("http://localhost/images/logo.gif");
というURLだと取得できないのですが、
$images = getimagesize("http://www.google.co.jp/intl/ja_jp/images/logo.gif");
というGoogleのロゴのサイズを取得しようとしたら出来ました。

getimagesizeを使う場合、localhostからは取得できないのでしょうか?
もし出来ない場合、どうやってローカルサーバの画像を参照すればいいのか
方法を教えていただければと思います。
0058nobodyさん2009/11/18(水) 14:49:42ID:???
とりあえず、
ローカルPC上のブラウザから"http://localhost/images/logo.gif"が見えてるよね?
0059572009/11/18(水) 14:52:09ID:xi1WciP2
はい。見えてます。
0060nobodyさん2009/11/18(水) 14:57:17ID:/HH3qrl4
>>59
そのローカル環境のファイル壊れてないよね?
一応、>>57のソースを元に
$images = getimagesize("http://www.google.co.jp/intl/ja_jp/images/logo.gif");
print_r($images);
echo "<br>\n";
$images2 = getimagesize("http://localhost/work/GD/logo.gif");
print_r($images2);
ってソースを書いてテストしたけど問題なく取得できた。
ローカルでのlogo.gifはgoogleのロゴをそのまま保存して利用。

ちなみに
$images = getimagesize("./logo.gif");
の様に相対パスで書いた場合はどうなる?
0061nobodyさん2009/11/18(水) 15:01:07ID:???
なんか見落としてる予感だわな
エラーメッセージは出ないのか
0062572009/11/18(水) 15:04:24ID:xi1WciP2
>>60
相対パスや絶対パスだと普通に表示されます。
なぜかURLにするとずっと読み込み状態で、
停止してもエラーメッセージなどは出ません。

ローカルサーバがWindowsXPのApacheだからでしょうか?PHPは5.2.5です
0063nobodyさん2009/11/18(水) 15:15:31ID:???
>>62
max_execution_timeやdefault_socket_timeoutの値を変えてエラーがどうなるか試してみたら?
0064nobodyさん2009/11/18(水) 15:18:25ID:???
>>61
その場合、php.iniの中身も確認しないとダメかもね。
display_errorsやerror_reportingまわりがどうなっているか確認しないとダメかも。下手したら非表示になっていたりして
(以前どこだったかな。レンタルサーバでこれのレベルが下げてあってエラーも警告も出なかったことある。)

>>62
後、
header("Content-type: image/gif");
$filename = "http://localhost/work/GD/logo.gif";
$f = fopen($filename, "rb");
$buf = stream_get_contents($f);
fclose($f);
echo $buf;
なソースを書いてphp側で画像取得できるのか?
これすらNGだとPHPよりapache側の根本的な設定に問題がありそう。

>>60は俺だけど今度は回答側に回ったのにsage付け忘れました。すみませんでした。
0065572009/11/18(水) 15:24:10ID:xi1WciP2
みなさんありがとうございます。たぶん、サーバの設定の問題かも知れません。
先ほどサブのPCで同じ事をしたらサイズが取得できました。
php.iniの設定や>>64さんが書かれている内容も参考にしてみます。
0066nobodyさん2009/11/18(水) 15:55:00ID:jaz8gdLl
data.txtから最終行を読み込んで表示した後、 <br> その最終行をdata.txtから削除するにはどんな方法でやれば良いでしょうか?

0067nobodyさん2009/11/18(水) 16:00:18ID:???
fileでよみこんでend使ってunsetして書き込み
0068nobodyさん2009/11/18(水) 16:29:22ID:jaz8gdLl
>>67
ありがとうございます。
0069392009/11/18(水) 19:57:24ID:???
>>56
確かに5.3で挙動が変わってるナー
バッファリングした結果セットをでっちあげちまえばいいんだ

class BufferedResult {
  private $buffer;
  public function __construct($result) { while ($row = $result->fetchRow()) { $this->buffer[] = $row; }}
  public function fetchRow($mode) { return array_shift($this->buffer); }
  public function fetchAll() { return array_splice($this->buffer, 0); }
}

こんなクラスを作ってこうだ

+ if (SQLite使用時 && version_compair(PHP_VERSION, '5.3') >= 0) {
+   $result = BufferedResult($result);
+ }
$db->disconnect();
return $result;
0070nobodyさん2009/11/18(水) 20:36:09ID:???
$resultは参照になってると思うが大丈夫かい?
0071nobodyさん2009/11/18(水) 20:36:48ID:???
>>69
訳してくだはい
0072nobodyさん2009/11/18(水) 20:37:46ID:???
>>71
え、何を?
0073nobodyさん2009/11/18(水) 21:20:51ID:nmLyX5fb
HTML4.01とXHTML1.0のタイプ別にDTDから要素と属性を取得するプログラムって探してもなかったのですが需要がないのでしょうか?
自分も書いてみたもののスマートな感じではないので勉強のためにソースを探しています
どなたかご存知の方いらっしゃいましたら教えてください
0074nobodyさん2009/11/18(水) 21:23:06ID:???
誰得?
0075nobodyさん2009/11/18(水) 21:35:27ID:???
何のためにそんなの作るの?
IDEのコード補完で勝手にやってくれるでしょ
0076nobodyさん2009/11/18(水) 21:40:40ID:/HH3qrl4
>>69
ありがとうございます。
書いていただいてソースを元に
public function __construct($result,$Lib_Kind){
if($Lib_Kind==1){
while ($row = $result->fetchRow(DB_FETCHMODE_ASSOC)) {
$this->buffer[DB_FETCHMODE_ASSOC][] = $row;
}
while ($row = $result->fetchRow(DB_FETCHMODE_ORDERED)) {
$this->buffer[DB_FETCHMODE_ORDERED][] = $row;
}
while ($row = $result->fetchRow(DB_FETCHMODE_OBJECT)) {
$this->buffer[DB_FETCHMODE_OBJECT][] = $row;
}
}elseif($Lib_Kind==2){
while ($row = $result->fetchRow(MDB2_FETCHMODE_ASSOC)) {
$this->buffer[MDB2_FETCHMODE_ASSOC][] = $row;
}
while ($row = $result->fetchRow(MDB2_FETCHMODE_ORDERED)) {
$this->buffer[MDB2_FETCHMODE_ORDERED][] = $row;
}
while ($row = $result->fetchRow(MDB2_FETCHMODE_OBJECT)) {
$this->buffer[MDB2_FETCHMODE_OBJECT][] = $row;
}
}
}
public function fetchRow($mode){ return array_shift($this->buffer[$mode]);}
$Lib_Kindが1だったらPEAR::DB、2だったらPEAR::MDB2使用
とソース書き直してみました。

0077nobodyさん2009/11/18(水) 21:43:23ID:/HH3qrl4
>>69
>確かに5.3で挙動が変わってるナー
どうせやるなら他のDB系関数の挙動も変更すればいいのに
それにしてもなんでこんな中途半端(SQLiteのみ)な仕様変更したんだろう?
0078nobodyさん2009/11/18(水) 21:47:22ID:???
>>76
なんで全部fetchしてんの?
あとfetchAllがあるよ
0079nobodyさん2009/11/18(水) 22:10:31ID:???
>>78
とりあえずMDB2で説明すると
http://pear.php.net/manual/ja/package.database.mdb2.intro-fetch.php
while ($row = $result->fetchRow()) {
だった場合拾う値はデフォルトである
MDB2_FETCHMODE_ORDEREDのみの型。
MDB2_FETCHMODE_ASSOCやMDB2_FETCHMODE_OBJECT の値も別途取得する処理を書いておく必要がある。
ただしMDB2_FETCHMODE_OBJECTの書き方はオブジェクトとして取得するのでなんか変な気がする。
0080nobodyさん2009/11/18(水) 22:22:48ID:???
>>75
>勝手にやってくれる?

kwsk
0081nobodyさん2009/11/18(水) 23:08:03ID:???
>>76
こういうコードがサーバー落とすんだなw
0082nobodyさん2009/11/18(水) 23:22:39ID:???
>>81
だったら君はどんなコード書く?
元々SQLiteは大規模開発にはむかないDB。
そんなSQLite限定で利用すると考えればそんなに負荷がかかるかな?
0083nobodyさん2009/11/18(水) 23:27:05ID:nmLyX5fb
>>75
strictで使える要素と属性、framesetで使える要素と属性・・・のように必要なものだけを取得するようなことをしてます
目的はdoctype別補完辞書作成の為なんです
IDEは全て試したわけではありませんがaptanaとDreamweaverを試した限りではあるdoctyleに対応しない属性が出てきますし足りない属性も出てきます

反応良かったらコード公開するつもりでした
質問は締め切りROMに戻ります
ますありがとうございました
0084nobodyさん2009/11/18(水) 23:44:48ID:???
>$Lib_Kindが1だったらPEAR::DB、2だったらPEAR::MDB2使用

クラス使う意味が半分かそれ以上消えとるな。
0085nobodyさん2009/11/19(木) 00:01:54ID:???
>>84
kwsk
0086nobodyさん2009/11/19(木) 00:29:52ID:???
20年ほど前の、プログラミング言語C++でもしっかり明記されとるわな。
switch〜caseは止めれって。(if〜elseifの羅列も同じこと)

C++には相変わらずinterfaceは導入されて無い(よね?)けど、
それ以降出てきた言語たちにはinterfaceなんて有りがたいものが
あるんだから、よりその言葉に従うのが楽だわな。
0087nobodyさん2009/11/19(木) 00:48:25ID:???
>>86
でも、それってPHP5だけを考慮に入れた場合は良いけど、PHP4まで考慮に入れたシステムの場合NGでは?
PHP4が、サポート終了ってなっているがPHP4系がいまだに使われているサーバなんて大量にまだあるからPHP4に対するプログラムの
サポートってなかなか切れないよ。
0088872009/11/19(木) 01:03:22ID:???
追加。
今回のようなマルチな環境に対応させるくらいのシステムなんだから古いシステムも考慮した上での作りだと思うよ。
そもそも、新しいのだけを考慮しているシステムならPHP4どころかPEAR::DBもシステムから外すべき物。
http://pear.php.net/package/DB
>This package has been superseded, but is still maintained for bugs and security fixes. Use MDB2 instead.
ぶっちゃけな訳しかたすると「バグとセキュリティーのためにサポートは続くがMDB2って言う後継出ているからそっち使えよ。」
PEARはPHPで書かれたライブラリだから必ずしもpearコマンドでインストール必要もなく
インストールされてないレンタルサーバでもアーカイブDLしてきてプログラムから呼び出すパスを、通せばいくらでも使える。
と言うわけで、プログラムの更新作業するのにDBは、「いらない子」。
MDB2とPDOをサポートするだけのプログラムにした方が良い。
PEAR::DB,PEAR::MDB2,PDOとサポートさせるプログラムを書いている奴が、PHP4のサポートをごっそりと打ち切ったプログラム書くのか?
0089872009/11/19(木) 01:27:04ID:???
>>87,>88書いて気になったけどここ見ている人たちってDB関連は、
・PEAR::DB
・PEAR::MDB2
・PDO
・そんなものラッパ使わない。各DB関数直接使う
どれが多い?
それと
・必須環境はPHP5以降。PHP4は切り捨てた。
・必須環境はPHP4以降。PHP4もサポートし続ける。
に関してもどうしている?


0090nobodyさん2009/11/19(木) 01:39:54ID:???
・PHP5or4のみでサポートされている関数は使わない
・せっかく専用の関数が有るのだからそれらを纏めて抽象化
0091nobodyさん2009/11/19(木) 01:57:50ID:???
>>89
IDと元質問のレス番号出しなさい。
0092nobodyさん2009/11/19(木) 01:59:56ID:???
>>79
>別途取得する処理を書いておく必要がある
それがアホ設計だと言ってるんだがw
デザインパターンとか知らんのかね
0093nobodyさん2009/11/19(木) 02:00:09ID:7S9/ReIJ
>>86
教科書通りのお手本を書く場合ならそれでいいけど、interfaceの実装はPHP5から。
さて私はPHP4の動作を対象外にしてまでinterfaceを使うべきですか?
PHP4を対象外にするならPHP5もPHP5.1から動作対象としてDBもPEAR::DBとPEAR::MDB2も切り捨ててより速度が出るPDOだけにしますよww
0094nobodyさん2009/11/19(木) 02:03:51ID:???
そうしろよ
0095nobodyさん2009/11/19(木) 02:32:52ID:7S9/ReIJ
>>92
デザインパターンの有効性って再利用時などに使いやすくなどだよね。
一時しのぎようのクラスにまでそのものが必要かどうかの天秤にかけると別にデザインパターンに
沿った作りにしないでもごり押しでソース書いておけばとりあえずはいいや。って結論になったアホな俺。

>>94
単純に切り捨てができれば苦労しない。
0096nobodyさん2009/11/19(木) 03:12:12ID:???
再利用だのそんな問題ではなく
>>76を見て何とも思わないん?
まぁ書いた本人だから思わないんだろうけど、今後もプログラム書いていくなら
もうちょっとここの人達の意見にも耳を傾けてみたほうが幸せになれるんじゃないかなと思う次第
0097nobodyさん2009/11/19(木) 03:41:33ID:???
>>76
継承を覚えろ。
0098nobodyさん2009/11/19(木) 06:08:18ID:BO5FZy2H
$str='["tes0",1,"tes1",2,3,["tes2",4],5]';
このような文字列を
$array=['tes0',1,'tes1',2,3,['tes2',4],5];
みたいに配列として扱いたく、
[の数とexplode使って、forしながら配列にしてみたのですが、
もっと簡単に変換できる方法はありますでしょうか。
アドバイスよろしくおねがいします。
0099nobodyさん2009/11/19(木) 07:18:55ID:???
それ何のデータ?
0100nobodyさん2009/11/19(木) 08:25:02ID:BO5FZy2H
>>99
すいませんjavascriptとごっちゃになってしまっていました。
$arrayの方は、
$arr=array(
           'test0',
           1,
           'test1',
           2,
           3,
           array('test2',4),
           5
           );
でした。
$strを受け取ったときに、この$arrへ変換するにはどんな方法があるのかなぁ、と。
0101nobodyさん2009/11/19(木) 08:27:27ID:???
>>100
json_decode
0102nobodyさん2009/11/19(木) 08:38:29ID:BO5FZy2H
>>101
おぉ!やりたいことができました
ありがとうございましたm(_ _)m
0103nobodyさん2009/11/19(木) 13:19:46ID:MI354vJb
htmlのヘッダとフッタが全ページ共通の場合で質問です
smartyとかcakephpとかテンプレートエンジンやフレームワークを使うより
includeで呼び出すほうが処理が軽いと思うのですが違うのでしょうか?
0104nobodyさん2009/11/19(木) 13:31:12ID:???
>>103
あってるよ

そもそもテンプレートやフレームワークは軽くするためのモノじゃないし。
余計な処理が増えるんだから素の状態と比較したら重くなって当然
0105nobodyさん2009/11/19(木) 15:20:18ID:???
くだらんかどうかは分からないけど
はまりにはまってどうしようもないから助けて

標準入力stdinを受け取りたいんだけど、
起動時点で標準入力が渡されていたら受取り、
そうでなければデフォルト値を使用ってしたいんです。
でも、標準入力を読み込みに行くと、空の場合、入力待ちになっちゃう
この入力待ちをさせない方法ってありますか?
0106nobodyさん2009/11/19(木) 15:21:56ID:JXswh9pT
ID出してなかった。すんませんです。
0107nobodyさん2009/11/19(木) 15:31:35ID:???
マルチ乙
0108nobodyさん2009/11/19(木) 20:21:52ID:AL4i469V
環境 Fedora1064bit Apache/2.2.13 PHP/5.2.10の鯖で、
Hello-UP アップローダー
http://idol.nm.land.to/
を使用しているのですが、ある特定の条件により、
特定のページ、upload.php?id=以降のページが画面が真っ白(読み込み中状態)で開かなくなってしまいます。
errorではなく、読み込みに時間がかかっている感じです。
その間、upload.phpは問題なく表示されます。あと、パスワード付きのページの入り口upload.php?mode=pass&idd=も開けます。
ただし、正しい・間違い関係なくパスの入力後の動作が、upload.php?id=と同じく表示されません。
表示されずにどんどんプロセスだけが増えていき、数十分でサーバー自体が繋がらなくなってしまいます。

特定の条件とは、受信パス付きファイルがアップロードされた直後なのですが、
起き出したのは最近です。

アクセスが多い少ないは余り関係が無く起るようです。
そして、画面が真っ白(読み込み中状態)のときに、
/sbin/fuser -kn tcp 80
/etc/rc.d/init.d/httpd restart
をすると、ぱっと開きます。なので何らかの原因で処理が出来ない物と思われます。
ログを見てもプロセスが増大してのTimeOutの記述しかなく、具体的な原因が分からない状態です。

どうぞよろしくお願いします<m(__)m>
0109nobodyさん2009/11/19(木) 20:24:47ID:JXswh9pT
>>107
マルチじゃないんだが
ちなみにマルチと思われるレスを教えて下され
0110nobodyさん2009/11/19(木) 20:56:58ID:???
>>109
煽り合いしたいならよそでやってね。
■ このスレッドは過去ログ倉庫に格納されています