【PHP】下らねぇ質問はID出して書き込みやがれ 90
■ このスレッドは過去ログ倉庫に格納されています
0001●
2009/11/14(土) 17:31:22ID:???過去スレ、関連スレ、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等)・フレームワークは各該当スレへ
00118
2009/11/16(月) 11:56:21ID:???他のサンプルコードは動いていました
似たようなコードを実行したときには、このようにphpの内容がブラウザに出力されていませんでした
>>9さんの言われているように、今FireBugでスクリプトを開いて見てみたところ、ソースが(<?php〜?>の中が)表示されていました
http://localhostから出力したからなのか、自分には知識が乏しいので分かりませんが、こういう場合はどのようにすれば解消するのでしょうか?
>>10
そうなのでしょうか
よく分からないのですが、一応他のサンプルなどは動いています
ただし、それらが動作するからといってApacheに関連付けられているのかは自分には分かっていないのですが・・・
00128
2009/11/16(月) 12:05:29ID:???結局この場合、上記のサンプルコードが間違っているのではなく、自分のPHP又はApacheの設定がおかしいという事なのでしょうか?
一応単純に
<? php
print "山田";
?>
と打つと、ブラウザには(localhostから出力していますが)山田と表示されます
00148
2009/11/16(月) 13:18:33ID:???0015nobodyさん
2009/11/16(月) 13:20:55ID:???0016nobodyさん
2009/11/16(月) 13:32:47ID:???00178
2009/11/16(月) 14:11:11ID:bvqRdc2u00188
2009/11/16(月) 14:29:25ID:bvqRdc2uう〜ん、なんでブラウザにprint後のコードが出力されるのでしょうか・・・?
0019nobodyさん
2009/11/16(月) 14:56:43ID:+MFbLdTchoge.php はちゃんと動くんですが,
他の場所に hoge.php を置いてシンボリックリンクで参照すると
403 Forbidden になります.
CentOS + lighttpd + php-cgi です.
0020nobodyさん
2009/11/16(月) 15:14:29ID:???シンボリックリンク使える。
webサーバの設定でシンボリックリンクの許可をしておかないと駄目
lighttpdは使った事無いけど、
ググったらでてきた↓↓の設定はしてある?
server.follow-symlink = "enable"
0023nobodyさん
2009/11/16(月) 18:18:13ID:???0024nobodyさん
2009/11/16(月) 18:40:26ID:???0025nobodyさん
2009/11/16(月) 18:55:01ID:???apacheとかIISは分かります?
0026nobodyさん
2009/11/16(月) 20:34:49ID:HkdbmVie具体的には、1ページ内に、
”明日””今日””昨日”のように複数の文字列の下に、追加ボタンをおいて、
押された順番に、例えば、
明日昨日今日と押したら、
明日
昨日
今日
となるように、
テキストボックスに改行しながら文字列を追加していくような感じのを作りたいんです。
よろしくお願いします<m(__)m>
0027nobodyさん
2009/11/16(月) 20:45:41ID:HkdbmVie取り消してこちらに移動させてもらいます<m(__)m>
△▲ WebProg 初心者の質問 Part21 ▼▽
http://pc11.2ch.net/test/read.cgi/php/1257701535/
0029nobodyさん
2009/11/16(月) 23:19:35ID:???0030nobodyさん
2009/11/16(月) 23:40:57ID:DxyMrPHB$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"]キーで上書きされてしまいます。
よろしくお願いします。
0032nobodyさん
2009/11/17(火) 00:02:14ID:149D2nEEうぉぉおおぉ!
ありがとうございます!!
0033nobodyさん
2009/11/17(火) 00:07:29ID:???0034nobodyさん
2009/11/17(火) 10:32:58ID:???ほんと使えねえksだな
0035nobodyさん
2009/11/17(火) 11:03:39ID:???0036nobodyさん
2009/11/18(水) 03:36:08ID:/HH3qrl4PEAR::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:???0038nobodyさん
2009/11/18(水) 04:13:07ID:/HH3qrl4どうもです。とりあえず書き込みした後テストしてわかったのですが
キモは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:???sqlite_close()の中で結果セットまで削除する仕様が原因だね
MySQLではmysql_close()が呼ばれていても
"mysql result"リソースのデストラクタが働くまでは参照可能
嘘言ってたら許してくれ
まぁ実装に左右されたくなかったら
結果セットが必要なくなってから切断する設計にするべき
0040nobodyさん
2009/11/18(水) 10:00:16ID:xkg9vx1zphp5.2.10です
0041nobodyさん
2009/11/18(水) 10:52:23ID:???書いてあるよ
0042nobodyさん
2009/11/18(水) 12:27:53ID:/HH3qrl4ありがとうございました。
>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:???0044nobodyさん
2009/11/18(水) 12:38:39ID:/HH3qrl4一回の処理でSQLが発行されるのは1回がほとんどだからこの様な実装方式にしています。
0045nobodyさん
2009/11/18(水) 12:38:54ID:???0046nobodyさん
2009/11/18(水) 12:55:03ID:???取り込んどきゃ、ライブラリ側管理のデータがどうなろうが影響無いと思うんだが。
まあ、大抵ちょー大量に返ってくるというのなら、また違うかもしれん。
0047nobodyさん
2009/11/18(水) 13:18:45ID:???だからその処理は2.のクラスでやっている。
で取得したDBのデータそのものを使うのは1.の部分。
ちなみに3.のクラスはSQL送信だけではなくて
PEAR::DB、PEAR:MDB2、PDOのラッパー(実行環境によって使えるライブラリが変わったときにソースの修正をせずに済むようにするため)
としてさらにはMySQL、PostgreSQL、SQLiteのラッパーとしての
役割を持たせた物。
だから下手に2.の部分と統合されられない。
0048nobodyさん
2009/11/18(水) 13:23:33ID:???DB駆動クラス(他から見れば、そいつがDBと言ってもいい)がやるならともかく。
0050nobodyさん
2009/11/18(水) 13:45:40ID:/HH3qrl4SQL生成クラスって書き方したが
実際には
・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:???>だからその処理は2.のクラスでやっている。
などと言ってるけどその設計から見直したら?っていう話なのでは?
アドバイスしても「俺のクラスではこうなんだ」としか言われなかったら
はいそうですかどうぞご自由にと何も言うことなくなる。
0052nobodyさん
2009/11/18(水) 14:01:36ID:/HH3qrl4現状できあがったシステムで(今までは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
まあそれでも、他者が作ったそういうものでも何とかしなきゃならん仕事での立場だとしたら、
もしそうならちょこっと同情はする。
0056nobodyさん
2009/11/18(水) 14:38:02ID:/HH3qrl4>システム全体も書き換えになってしまう、と。
ごめん。書き方が変だった。
このシステム全体は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$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"が見えてるよね?
005957
2009/11/18(水) 14:52:09ID:xi1WciP20060nobodyさん
2009/11/18(水) 14:57:17ID:/HH3qrl4そのローカル環境のファイル壊れてないよね?
一応、>>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:???エラーメッセージは出ないのか
006257
2009/11/18(水) 15:04:24ID:xi1WciP2相対パスや絶対パスだと普通に表示されます。
なぜかURLにするとずっと読み込み状態で、
停止してもエラーメッセージなどは出ません。
ローカルサーバがWindowsXPのApacheだからでしょうか?PHPは5.2.5です
0063nobodyさん
2009/11/18(水) 15:15:31ID:???max_execution_timeやdefault_socket_timeoutの値を変えてエラーがどうなるか試してみたら?
0064nobodyさん
2009/11/18(水) 15:18:25ID:???その場合、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付け忘れました。すみませんでした。
006557
2009/11/18(水) 15:24:10ID:xi1WciP2先ほどサブのPCで同じ事をしたらサイズが取得できました。
php.iniの設定や>>64さんが書かれている内容も参考にしてみます。
0066nobodyさん
2009/11/18(水) 15:55:00ID:jaz8gdLl0067nobodyさん
2009/11/18(水) 16:00:18ID:???0068nobodyさん
2009/11/18(水) 16:29:22ID:jaz8gdLlありがとうございます。
006939
2009/11/18(水) 19:57:24ID:???確かに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:???0073nobodyさん
2009/11/18(水) 21:20:51ID:nmLyX5fb自分も書いてみたもののスマートな感じではないので勉強のためにソースを探しています
どなたかご存知の方いらっしゃいましたら教えてください
0074nobodyさん
2009/11/18(水) 21:23:06ID:???0075nobodyさん
2009/11/18(水) 21:35:27ID:???IDEのコード補完で勝手にやってくれるでしょ
0076nobodyさん
2009/11/18(水) 21:40:40ID:/HH3qrl4ありがとうございます。
書いていただいてソースを元に
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>確かに5.3で挙動が変わってるナー
どうせやるなら他のDB系関数の挙動も変更すればいいのに
それにしてもなんでこんな中途半端(SQLiteのみ)な仕様変更したんだろう?
0079nobodyさん
2009/11/18(水) 22:10:31ID:???とりあえず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の書き方はオブジェクトとして取得するのでなんか変な気がする。
0082nobodyさん
2009/11/18(水) 23:22:39ID:???だったら君はどんなコード書く?
元々SQLiteは大規模開発にはむかないDB。
そんなSQLite限定で利用すると考えればそんなに負荷がかかるかな?
0083nobodyさん
2009/11/18(水) 23:27:05ID:nmLyX5fbstrictで使える要素と属性、framesetで使える要素と属性・・・のように必要なものだけを取得するようなことをしてます
目的はdoctype別補完辞書作成の為なんです
IDEは全て試したわけではありませんがaptanaとDreamweaverを試した限りではあるdoctyleに対応しない属性が出てきますし足りない属性も出てきます
反応良かったらコード公開するつもりでした
質問は締め切りROMに戻ります
ますありがとうございました
0084nobodyさん
2009/11/18(水) 23:44:48ID:???クラス使う意味が半分かそれ以上消えとるな。
0086nobodyさん
2009/11/19(木) 00:29:52ID:???switch〜caseは止めれって。(if〜elseifの羅列も同じこと)
C++には相変わらずinterfaceは導入されて無い(よね?)けど、
それ以降出てきた言語たちにはinterfaceなんて有りがたいものが
あるんだから、よりその言葉に従うのが楽だわな。
0087nobodyさん
2009/11/19(木) 00:48:25ID:???でも、それってPHP5だけを考慮に入れた場合は良いけど、PHP4まで考慮に入れたシステムの場合NGでは?
PHP4が、サポート終了ってなっているがPHP4系がいまだに使われているサーバなんて大量にまだあるからPHP4に対するプログラムの
サポートってなかなか切れないよ。
008887
2009/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のサポートをごっそりと打ち切ったプログラム書くのか?
008987
2009/11/19(木) 01:27:04ID:???・PEAR::DB
・PEAR::MDB2
・PDO
・そんなものラッパ使わない。各DB関数直接使う
どれが多い?
それと
・必須環境はPHP5以降。PHP4は切り捨てた。
・必須環境はPHP4以降。PHP4もサポートし続ける。
に関してもどうしている?
0090nobodyさん
2009/11/19(木) 01:39:54ID:???・せっかく専用の関数が有るのだからそれらを纏めて抽象化
0092nobodyさん
2009/11/19(木) 01:59:56ID:???>別途取得する処理を書いておく必要がある
それがアホ設計だと言ってるんだがw
デザインパターンとか知らんのかね
0093nobodyさん
2009/11/19(木) 02:00:09ID:7S9/ReIJ教科書通りのお手本を書く場合ならそれでいいけど、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デザインパターンの有効性って再利用時などに使いやすくなどだよね。
一時しのぎようのクラスにまでそのものが必要かどうかの天秤にかけると別にデザインパターンに
沿った作りにしないでもごり押しでソース書いておけばとりあえずはいいや。って結論になったアホな俺。
>>94
単純に切り捨てができれば苦労しない。
0096nobodyさん
2009/11/19(木) 03:12:12ID:???>>76を見て何とも思わないん?
まぁ書いた本人だから思わないんだろうけど、今後もプログラム書いていくなら
もうちょっとここの人達の意見にも耳を傾けてみたほうが幸せになれるんじゃないかなと思う次第
0098nobodyさん
2009/11/19(木) 06:08:18ID:BO5FZy2Hこのような文字列を
$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すいませんjavascriptとごっちゃになってしまっていました。
$arrayの方は、
$arr=array(
'test0',
1,
'test1',
2,
3,
array('test2',4),
5
);
でした。
$strを受け取ったときに、この$arrへ変換するにはどんな方法があるのかなぁ、と。
0102nobodyさん
2009/11/19(木) 08:38:29ID:BO5FZy2Hおぉ!やりたいことができました
ありがとうございましたm(_ _)m
0103nobodyさん
2009/11/19(木) 13:19:46ID:MI354vJbsmartyとかcakephpとかテンプレートエンジンやフレームワークを使うより
includeで呼び出すほうが処理が軽いと思うのですが違うのでしょうか?
0104nobodyさん
2009/11/19(木) 13:31:12ID:???あってるよ
そもそもテンプレートやフレームワークは軽くするためのモノじゃないし。
余計な処理が増えるんだから素の状態と比較したら重くなって当然
0105nobodyさん
2009/11/19(木) 15:20:18ID:???はまりにはまってどうしようもないから助けて
標準入力stdinを受け取りたいんだけど、
起動時点で標準入力が渡されていたら受取り、
そうでなければデフォルト値を使用ってしたいんです。
でも、標準入力を読み込みに行くと、空の場合、入力待ちになっちゃう
この入力待ちをさせない方法ってありますか?
0106nobodyさん
2009/11/19(木) 15:21:56ID:JXswh9pT0107nobodyさん
2009/11/19(木) 15:31:35ID:???0108nobodyさん
2009/11/19(木) 20:21:52ID:AL4i469VHello-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マルチじゃないんだが
ちなみにマルチと思われるレスを教えて下され
■ このスレッドは過去ログ倉庫に格納されています