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

【PHP】下らねぇ質問はここに書き込みやがれ 71

■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん2008/07/17(木) 19:42:52ID:DVaNTncw
まず読め→【PHP マニュアル】http://www.php.net/manual/ja/
PHPで最良の教本はこの公式マニュアル。市販の書籍は嘘が多いので鵜呑みにしない。
過去スレ、関連スレ、FAQなどは>>2-10辺り
次スレは>>980が立てる。10分以内に立たない場合、宣言してから立てたい人が立てること。

◆前スレ
【PHP】下らねぇ質問はここに書き込みやがれ 70
http://pc11.2ch.net/test/read.cgi/php/1214356448/

◆質問する時の注意
・ 自分のIDを表示させること。(メール欄に何も記述しないこと。空白も入力しちゃダメ)
・ サーバーのOS(Linux、Windows他)、WebサーバーとPHPの種類やバージョン等を明記すること。
・ 己の行った操作、変更などを詳しく明記すること。
・ エラーメッセージはそのまま表記すること。「エラーが出ます」だけでは回答不可。
・ 質問者として、態度をわきまえること。
・ 事前に公式マニュアル、リファレンス本くらいはちゃんと目を通しておくこと。

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

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

【その他諸注意】
・正規表現・PEAR・テンプレート(Smarty等)・フレームワークは各該当スレへ
・SQLについての質問はデータベース板(PCカテゴリ)の各スレで
0562nobodyさん2008/08/05(火) 01:03:59ID:???
>>560
xamppは開発環境ではありません。

あと時間を気にするなんて毎日作り直してんの?
参考までに使った場合と使わない場合にそれぞれかかる時間を教えて。
0563nobodyさん2008/08/05(火) 01:06:13ID:???
下らねぇ質問が来るまでこの流れのままなのか・・・
0564nobodyさん2008/08/05(火) 01:11:44ID:???
>>561
足りない頭で、レス乙。

高級言語の仕様が1から始まるかと0から始まるかということと、
アセンブル・機械語がどうかとは全く別の話だ。

それは高級言語の実装で吸収すればいいだけの話。
0565nobodyさん2008/08/05(火) 02:54:56ID:???
>>564
俺その辺詳しくないから聞きたいんだが、
要素数が255とか65535(2進法)
10、100(10進法)
2147483647(32bitでのintとfloatの境界)

の時は[0]スタートの方が有利に思えるんだけどどうなの?

例えば10個目の配列の参照する時
[0]からの場合【[9]】
[1]からの場合【[10]】
と書くよな。

9は1文字、10は2文字
ソースのサイズは若干変化あるよな。
後、intとfloatの型変化の時も影響がデカイ気がする。
こういうレベルの影響はないのか?
0566nobodyさん2008/08/05(火) 03:12:59ID:???
C言語で配列の要素番号が0から始まるのは、配列が存在するアドレスから何要素分進んだかを表しているから。
hogearray[16]は、*(hogearray + 16)の構文糖衣。
多次元配列darray[4][4]は*(darray + 4 * x + 4)。 # xはsizeof(darray[0])
もし要素番号が1から始まったら、多次元配列darray[4][4]は*(darray + 3 * x + 3)。
[]で書くと4なのに、ポインタを使うと3になる。こんなややこしい仕様はバグの元。
だから要素番号は0から。
で、PHPは元々Perlので実装され、そのPerlが配列に関してはC言語の構文を真似たから、PHPの要素番号も0からになったと予想。
悪法でも何でもなく、親しめられてきた言語に合わせて、CやPerlなどからPHPに移ってきた人が混乱しないようにしただけ。
>>561
それは比較するときの話なのでは。x86やx64で言えば、0との比較はcmpしなくてもmovでZero Flagフラグが立つかどうかで分かるから。
# Core 2以降はマクロヒュージョンのおかげでcmpしようがしまいが同じだがな。
>>565
ソースが1文字増えたところでロスする時間は1マイクロ秒以下。それを気にするならソースの余計な空白やタブを取っ払う方がいい。
0567nobodyさん2008/08/05(火) 03:28:28ID:???
>>566
お前が、相当技術力があるのは認めるが、
なんで、そんな奴がこのレスにいるの?

phpなんて、単価が安い仕事ばっかだろ。
レスで書いているような内容が分かるなら、
phpよりも、かなり良い仕事が出来そうだが。

おれ何をしているかというと、昔SEをやっていたが今はシステム営業をやっていて、
自分のサイトを作るためのに個人的にphpをやっていたりする。
0568nobodyさん2008/08/05(火) 03:36:45ID:???
ただ2chのスレを巡回して、どこかからの受け売りを垂れ流す、技術も糞もない学生ですがな
0569nobodyさん2008/08/05(火) 04:14:40ID:???
>>567
を笑うスレですか?
0570nobodyさん2008/08/05(火) 08:58:09ID:???
プログラミングに思想と性欲は邪魔
0571nobodyさん2008/08/05(火) 09:24:02ID:???
>>567
WEBアプリほどぼろい商売ないと思うんだけど、低脳のおまえは何で稼いでんの?w
0572nobodyさん2008/08/05(火) 09:26:44ID:???
>>562
おまえのとこは客があまりいなくて暇でいいんだな
客に合わせていろんな環境を嫌々作ってみたらよくわかるで
0573nobodyさん2008/08/05(火) 09:29:13ID:???
>>571
php程度の仕事で、ぼろい商売なんて思うなんて、お前は相当あれ何だなぁww
0574nobodyさん2008/08/05(火) 09:32:42ID:???
xamppを開発環境じゃないといってる馬鹿は放置しとけ
0575nobodyさん2008/08/05(火) 09:34:33ID:???
>>573
そのPHP程度のスレをいちいち覗きに来なきゃーいいのにねぇ
( ´д)ヒソ(´д`)ヒソ(д` )
0576nobodyさん2008/08/05(火) 09:37:08ID:???
>>573
こういう低脳な奴が相場下げていってるんだろーな
0577nobodyさん2008/08/05(火) 09:47:55ID:???
要素番号が1から始まる言語って存在するの?
0578nobodyさん2008/08/05(火) 09:55:54ID:???
>>577
VB6までのVisualBasicとか。
0579nobodyさん2008/08/05(火) 10:00:36ID:???
>>578
VB6までしか使ったことないけど、
今のVBって配列の要素番号変わっているの?
移植とか困るだろうなぁ。
0580nobodyさん2008/08/05(火) 10:07:34ID:???
>>578
VB.NETは0からになったはず。
どうせほとんど別言語の体裁を取ってるし、
元々Option Base 0使ってる奴が大多数。
大差ないと思われwww
0581nobodyさん2008/08/05(火) 10:14:01ID:???
0から始まる言語を初めて使ったとき、0からだとこんなにスッキリ書けるんだ!
と、思ったもんだがな。
0582nobodyさん2008/08/05(火) 12:59:08ID:???
>>574
http://ja.wikipedia.org/wiki/%E7%B5%B1%E5%90%88%E9%96%8B%E7%99%BA%E7%92%B0%E5%A2%83
もしかしてphpspot(笑)とか真に受けちゃってる?
0583nobodyさん2008/08/05(火) 13:06:04ID:???
>>582
典型的な馬鹿か?
開発するために必要な環境全般をさして開発環境というんだよ
IDEのことだけをさすわけじゃない
当然デバッグのための環境(xampp)も開発環境という
IDE全てにデバッガが含まれてると思ったら大間違い
0584nobodyさん2008/08/05(火) 13:07:16ID:???
>>582
しったか乙
0585nobodyさん2008/08/05(火) 13:13:01ID:???
まったく、さすがphpのスレだけあってレベルが低すぎる。
馬鹿でも出来るphpだが、それさえも出来ないって救いようがない。
0586nobodyさん2008/08/05(火) 13:13:48ID:???
>>583-584
初心者さんなのかな?^^ 頑張ってピー・エッチ・ピー習得してね^^
0587nobodyさん2008/08/05(火) 13:14:21ID:???
さてお前らPHP5.3リリースですが
http://www.rooftopsolutions.nl/article/199
0588nobodyさん2008/08/05(火) 13:15:37ID:???
xamppはテストには必要だがステップ実行するデバッガとはまた別
そのテスト環境も開発環境の1つなのは間違いないが
文字どおり開発するのに必要な環境なわけだからな
xamppとメモ帳だけだって立派な開発環境だ
IDEにだってxamppをパッケージとして含めることはできるわけだし
オールインワンにした場合そのxamppが含まれたIDEに対して
xamppの部分は開発環境でないなんて意味不明なことはいえないだろ
0589nobodyさん2008/08/05(火) 13:15:59ID:???
>>587
php5.3って、当然配列の添え字は1から始まっているんだろうな?
0590nobodyさん2008/08/05(火) 13:17:21ID:WvP0Kt9J
xxne.jpみたいなサブアドサイトを作りたいんだけど
PHPで出来るのかな?
0591nobodyさん2008/08/05(火) 13:17:35ID:???
配列の添え字で不都合するのは糞プログラマだけだろ
いっぱしのやつならそんなの気にしない
たとえ添え字が14とかわけわからん数字からはじまっててもな
0592nobodyさん2008/08/05(火) 13:21:00ID:???
俺はJAVAを中心に仕事をしているが、
配列の添え字なんて、そもそもプログラムで意識しない。
配列が必要なデータはクラス化(ListやMapなど)してしまう。

配列の添え字を意識しなければいけない時点で、
オブジェクト指向が出来ていない証拠だよ。
今まで、そういう指摘が出ないのが不思議。

まだ、php4とか使っているのかよ?それともオブジェクト指向すら知らない?
0593nobodyさん2008/08/05(火) 13:24:30ID:???
>>592
PHPにはコレクションはありません
0594nobodyさん2008/08/05(火) 13:30:54ID:???
何でもかんでもコレクションにブチ込むのがOOPなんですか
配列を返す関数とかも色々あるんですけど、全部コレクションに入れ直すんだろうか
でもその場合でも配列は扱うよね
0595nobodyさん2008/08/05(火) 13:35:40ID:???
> でもその場合でも配列は扱うよね
使わねーよw
Iteratorとか知らねーのかよw
配列を生で扱うことに何の躊躇もないなんて、可哀想な脳みそ。
0596nobodyさん2008/08/05(火) 13:37:01ID:???
>>586
これだから初心者は^^;;;
Web開発するんだからWebサーバなども含めて開発環境に決まってんだろ
必要とあらば各種SDKフレームワークなども含める
使用する統合開発環境(IDE)だけに含まれてるものだけで開発できるとは限らん
結局自分が何を作るかで必要なものが個々に必要になってくるわけ
IDEはその土台に過ぎん
0597nobodyさん2008/08/05(火) 13:38:52ID:???
ここはPHPのスレですよ?
だいたいOOPとかスレ違いもいいところ
PHPで無理にOOP使う必要はない
0598nobodyさん2008/08/05(火) 13:39:40ID:???
OOよく分かってない人はイテレータとか使うだけで感動する傾向がある気がする。
0599nobodyさん2008/08/05(火) 13:39:49ID:???
597 :nobodyさん:2008/08/05(火) 13:38:52 ID:???
ここはPHPのスレですよ?
だいたいOOPとかスレ違いもいいところ
PHPで無理にOOP使う必要はない
0600nobodyさん2008/08/05(火) 13:41:47ID:???
いちおうSPLとかあるけど、使ってる人は見たことがない
0601nobodyさん2008/08/05(火) 13:53:14ID:???
PHPの質問をどうぞ
0602nobodyさん2008/08/05(火) 13:59:33ID:???
JAVA厨がしょぼPHPユーザをいじめてると聞いて飛んできますた
0603nobodyさん2008/08/05(火) 14:04:23ID:???
>>595
javaには配列からコレクションに変換する関数があるんだな
iterator全く関係ない訳だが
0604nobodyさん2008/08/05(火) 14:35:30ID:???
ひとまずスレタイ読めるようになってから来てくれ
0605nobodyさん2008/08/05(火) 14:53:49ID:???
まだやってんのかお前らwwwwwwwww
0606nobodyさん2008/08/05(火) 15:16:09ID:???
本日のキチガイチェキ

>>567
>>573
>>582
>>585
>>586
>>592
>>595

ID出なくてもキチガイは目立つから以外にわかるもんだな
0607nobodyさん2008/08/05(火) 15:17:45ID:???
追加
>>606
0608nobodyさん2008/08/05(火) 15:37:03ID:???
  ワケ     ワカ     ラン♪
  ∧_∧   ∧_∧    ∧_∧
 ( ・∀・)  ( ・∀・)   ( ・∀・)
⊂ ⊂  )  ( U  つ  ⊂__へ つ
 < < <    ) ) )     (_)|
 (_(_)  (__)_)    彡(__)
0609nobodyさん2008/08/05(火) 15:47:11ID:???
>>607
おいおい、俺も入れてくれよ
0610nobodyさん2008/08/05(火) 18:39:34ID:???
>>587
・名前空間
・クロージャー
・SQLite3デフォ
きたああああ
0611nobodyさん2008/08/05(火) 19:24:35ID:???
もちけつ、まだalphaだ
0612nobodyさん2008/08/05(火) 21:13:40ID:???
おまえらせっかく10年遅れでパターン覚えたのに残念だったなw
0613nobodyさん2008/08/05(火) 21:22:15ID:???
あれ、青山は辞めさせられたの?それともオリンピック取材?
0614nobodyさん2008/08/05(火) 23:00:21ID:8enGip0r
プログラムが実行しているページのURLを取得したいと思います。

echo "http://".$_SERVER["SERVER_NAME"].$_SERVER["SCRIPT_NAME"];

で一応取得できるのですが、http://とすると、
SSLページの場合は適さないと思います。

何か良い方法、または関数って無いでしょうか?
0615nobodyさん2008/08/05(火) 23:04:38ID:???
>>614
var_dump($_SERVER);
0616nobodyさん2008/08/05(火) 23:14:18ID:???
PHPよりJavascriptで取得した方が正確だったのでそうします。
お騒がせしました。
0617nobodyさん2008/08/06(水) 01:34:58ID:1xe8Gdey
597 名前:nobodyさん[sage] 投稿日:2008/08/05(火) 13:38:52 ID:???
ここはPHPのスレですよ?
だいたいOOPとかスレ違いもいいところ
PHPで無理にOOP使う必要はない
0618nobodyさん2008/08/06(水) 01:38:34ID:nCuNNad/
20万件のデータを配列に格納して、
あるデータがその配列にないかを検査する
処理を書いています。

in_array()で一個ずつマッチングしているのですが、
これが一番早いやり方でしょうか?

アルゴニズムの勉強をすればもっといい方法があるのかもしれませんが、
なるべく簡単にできるやり方で良い方法があれば教えて頂きたいと思います。

ちなみに、DBは使えない環境です。その代わりメモリーは16GBあります。
0619nobodyさん2008/08/06(水) 01:40:05ID:???
自前でインデックス作って管理
0620nobodyさん2008/08/06(水) 01:45:20ID:nCuNNad/
>>619
回答ありがとうございます。
ただ、今日の夕方までが納品なので、それを今からやるのはちょっと辛いです。
現在、パフォーマンステストの段階まで来ていて、
この部分の処理をもう少し早くできればと思っています。
0621nobodyさん2008/08/06(水) 02:01:59ID:???
>>620
入れるときにソートしとけば?w
0622nobodyさん2008/08/06(水) 02:21:18ID:???
質問です

PHPだけの質問ではないのですが、
Google Picasa内の画像の直URL
例)
ttp://lh3.ggpht.com/Josythecook/RqUmb2H6U0I/AAAAAAAAAAw/A2d0MFM8N6Y/Adriana_Lima89.jpg

IEでもFFでもブラウザに直にURLを入れると表示されるが、
Javascriptで
image = new Image(); image.src = 'http://〜';
と入れても表示されない。※先にブラウザURL直打ちしたあとなら表示される。おそらくキャッシュを使うため

さらにPHPの
fopen('http://〜'); や file_get_contents('http://〜');
でも開けません。

PHPのCURL関数もだめでした。
※FFのLivehttpheadersでFFで画像を表示したときのヘッダー情報を真似てみました。(UA偽装など)

また、上記のいづれもPicasa以外の画像なら表示できるため、根本的にやり方が間違っているということはないと思われます。

上記のことから、Picasa側でどのような制限をかけているか判別できるかた居ますでしょうか?
また、もし可能ならPHP+CURLを使用した取得可能なサンプルを教えいただけますでしょうか?

よろしくお願いいたします。

0623nobodyさん2008/08/06(水) 02:25:02ID:???
自前でインデックス作るのってそんなに難しいことか?
1カラムに限定すれば楽だと思うけど。36進数で管理すればファイルサイズも節約できるよん。
0624nobodyさん2008/08/06(水) 03:10:22ID:???
>>622
FFってなんだ?
もしかしてFxのことか?

FireFoxって書いてると恥ずかしいから、
今のうちにFirefoxって書く練習しておいたほうがいいよ

fopenで普通に取得できたから、やり方が悪いんじゃないの?
0625nobodyさん2008/08/06(水) 03:27:37ID:???
Final Fantasyだろjk

火狐とかきもい略称もあるよな
支那人かお前はと・・・
と思って中文のFirefox説明を見てきた

Mozilla Firefox(正式縮寫為 Fx,非正式縮寫為FF),俗稱火狐(目前無官方中文名)
意味はなんとなくわかったwwwwww
しっかりFFも非正式ながら使われてるようだwwwww
0626nobodyさん2008/08/06(水) 03:29:38ID:nCuNNad/
>>621>>623
レス感謝します。
なんだか、自分が想像していたより、
どんどん話が大きくなってしまって、
怖くなったので、この辺で終わりにしたいと思います。

私としましては、ただ簡単に速く出来ればと思って書いた質問でした。
なので、正直なところとして、それ以上の事はよかったのです。
0627nobodyさん2008/08/06(水) 14:32:18ID:???
可愛らしいな、おいw
0628nobodyさん2008/08/06(水) 15:26:29ID:???
>>626
連想配列は?
0629nobodyさん2008/08/06(水) 15:51:10ID:???
1.テキストボックスに入力します(html、submit)
2.fwriteでtxtファイルに書き込みます(php)
3.@に戻ってテキストボックスに入力、txtファイルに書き込み
…と、したかったのですが、
上書きされてしまい、最後に入力したデータしかtxtファイルに保存されません

どう回避すればよろしいでしょうか?
0630nobodyさん2008/08/06(水) 15:52:09ID:???
いや、、、どうしたいのさ。
追記したいなら追記モードでオープンとか。
0631nobodyさん2008/08/06(水) 15:53:45ID:???
魔乳亜留嫁(fopen
0632nobodyさん2008/08/06(水) 16:17:28ID:???
>>629
fopen(書き込みたい文字, 'a')
0633nobodyさん2008/08/06(水) 16:19:24ID:???
訂正
fopen(書き込みたいファイル, 'a')
0634nobodyさん2008/08/06(水) 16:21:17ID:???
php5使ってるならfile_put_contentsがいい
int file_put_contents ( string $filename , mixed $data [, int $flags [, resource $context ]] )
flagにFILE_APPENDやれば追記する
0635nobodyさん2008/08/06(水) 19:38:50ID:???
>>622
それって迷惑行為だよな。
0636nobodyさん2008/08/06(水) 19:39:32ID:???
文字列 $str = "abcdefg.php" から、後ろ3文字を取り除くとき、どう書くのがいちばんスマートですか。
0637nobodyさん2008/08/06(水) 19:43:19ID:???
echo substr($str, 0, -3);
0638nobodyさん2008/08/06(水) 21:27:26ID:???
PHPのクロスプラットホーム開発について
質問させて下さい。

前提として以下の様なフルパス指定のソースが大量にあります。
requiere "/export/home/hoge.php"

このソースを変更せず、windowsのeclipse pdt
で動かしたいと思っています。
windowsにはルートディレクトリがないため、
requiereでエラーとなりますが、これを回避する
方法はないでしょうか?
考えているのは、
1、SFU、Cygwinでなんとかならないか
2、requiereのソースを探してきて改造するか
以上、よろしくお願いします。

そのほかPHPクロスプラットホーム開発の
ノウハウがあるサイトがあれば教えてくださいませ。
0639nobodyさん2008/08/06(水) 21:30:35ID:???
s/requiere/require/
0640nobodyさん2008/08/06(水) 21:34:16ID:???
誰もアルゴニズムには突っ込まない。さすがだなPHPユーザーどもw
0641nobodyさん2008/08/06(水) 21:35:00ID:???
>>640
「あー・・・だるいから突っ込まなくていい?」という心境
0642nobodyさん2008/08/06(水) 21:49:58ID:???
ルートディレクトリが無いんだって
ヒソヒソ( ゚o゚)ヤダァ(゚o゚ )ネェ、キイタ?( ゚o゚)オクサン(゚o゚ )アラヤダワァ
0643nobodyさん2008/08/06(水) 21:51:54ID:???
アルゴリズムって、日本語に訳すと数学的律動体操ってことか?
何のこっちゃ?
0644nobodyさん2008/08/06(水) 21:53:45ID:???
>>642
おっしゃるとおり、windowsにもルートディレクトリがありますね、
ごめんなさい。
「/」のルートディレクトリに訂正です。
0645nobodyさん2008/08/06(水) 22:03:01ID:???
apacheだかphpだかをインスコしたドライブに
フォルダツリーを作ってやったら出来るんじゃないの?
cドライブにインスコしてたら
c:\export\home
にファイル置くとか
0646nobodyさん2008/08/06(水) 22:13:06ID:???
>>645
ありがとうございます。

試しましたが、ダメでした。
が、ボケてただけかもしれないので
もう一度やり直してみます。
0647nobodyさん2008/08/06(水) 22:17:41ID:???
Cygwin版のpacheで動くphpなら/でいけそうな気がするけどどうなんでしょうね
06486382008/08/06(水) 22:26:36ID:???
家のPCで試してみました。
>>645さんのおっしゃる通り、正常に動作しました。
失礼致しました。

環境の違いは以下ぐらいです。
正常動作する:PDT v1
動作しなかったと思われる:PDT V1.0.3

スレ汚しごめんなさい。
0649nobodyさん2008/08/06(水) 23:00:47ID:???
PDTなんて使うなw
0650nobodyさん2008/08/06(水) 23:03:06ID:???
phpspotメソッドというものがあるようなのですが
どのように使うのでしょうか?
LINUX、PHP5.2.6、ROOT有レン鯖です。
宜しくお願いします。
0651nobodyさん2008/08/07(木) 03:17:10ID:???
>>649
なにがおすすめですか?
0652nobodyさん2008/08/07(木) 03:54:19ID:???
最初に…、長文になってしまってすいません。

SQLインジェクションを防ぐために、SQL文を生成する際、「escape_string」を使用しています。
しかし、人為的なミスで「escape_string」を使用せずにSQL文を生成していまうことがあります。
そこで、mysqliクラスを完全にくるんだクラス(OrgDBクラス)を1つ作成して、DBに対する操作を
OrgDBクラスを介して行うようにしました。
0653nobodyさん2008/08/07(木) 03:55:32ID:???
>>652
PDO使え
0654nobodyさん2008/08/07(木) 03:55:55ID:???
〜OrgDBクラス(抜粋)〜
class OrgDb {
 private $p_oConnect;
 private $p_sSql;
 public function OrgDb_connnect() {
   $this->p_oConnect = new mysqli(…);
   if ($this->p_oConnect->connect_errno !== 0) {
    return false;
   }
   return true;
 }
 public function OrgDb_makeSql($sSql) {
  for ($nCnt = 0; $nCnt < 10; $nCnt++) {
   $sSql = str_replace("<" . $nCnt . ">", pack("C", $nCnt), $sSql);//☆1ココ
  }
  $this->p_sSql = $sSql;
 }
 public function OrgDb_setSql($nIndex, $sData) {
  $this->p_sSql = str_replace(pack("C", $nIndex), $this->p_oConnect->escape_string($sData), $this->p_sSql);
 }
 public function OrgDb_execSql() {
  for ($nCnt = 0; $nCnt < 10; $nCnt++) {
   if (mb_strpos($this->p_sSql, pack("C", $nCnt)) !== false) {//☆2ココ
    return false;
   }
  }
  return $this->p_oConnect->query($this->p_sSql);
 }
}
0655nobodyさん2008/08/07(木) 03:57:31ID:???
〜OrgDBクラスを使用する〜
$oDb = new OrgDb();
$oDb->OrgDb_connnect();
$oDb->OrgDb_makeSql("select * from table where key = '<0>'");
$oDb->OrgDb_setSql(0, "クライアントから送信されたデータ(要サニタイジング文字列)");
$oRes = $oDb->OrgDb_execSql();
0656nobodyさん2008/08/07(木) 03:58:37ID:???
やっていることは、SQL文を生成する際、
 1.静的なSQL文を定義する。この際、動的に設定される部分を"<N>"と記述する。
 2.動的に設定される部分を実際のデータで置換する。
 3.生成されたSQL文を実行(発行)する。
と、いう流れです。

上記ソースの通り、発行されるSQL文はOrgDbクラス内に閉じ込めてあり、動的に設定される部分は、全て、
OrgDb_setSqlメソッドを介して設定されるので、必ず、サニタイジング(escape_string)されるようになっています。
※やり方はいろいろあると思うのですが、このやりかたしか思いつかなかったです...orz...


〜質問〜
「☆1」部分と「☆2」部分なのですが、クライアントから送信されないデータを
置換対象としたかったので、pack関数を使用して、バリナリデータ(制御コード)としましたが、
この方法で何か問題が発生することはあるでしょうか?
※ちなみに、置換対象の種類は10個と決めています。

長文、本当にすいません;;
0657nobodyさん2008/08/07(木) 04:00:13ID:???
>>653
早々のご意見ありがとうございます。
諸事情により、PDOは使えないです。
使えるのであれば、PDOでやりたかったです;;
0658nobodyさん2008/08/07(木) 04:00:35ID:???
諸事情って?
0659nobodyさん2008/08/07(木) 04:06:25ID:???
>>658
システム的な理由ではなく、もろもろの事情です;;
すいません、上手く説明できません;;
0660nobodyさん2008/08/07(木) 04:09:19ID:???
try catch汁
0661nobodyさん2008/08/07(木) 04:11:06ID:???
>>659
だからそれを聞いてる
■ このスレッドは過去ログ倉庫に格納されています