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

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

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

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

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

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

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

【その他諸注意】
・正規表現・PEAR・テンプレート(Smarty等)・フレームワークは各該当スレへ
・SQLについての質問はデータベース板(PCカテゴリ)の各スレで
0352nobodyさん2008/08/21(木) 23:22:15ID:???
>>351さん

ループですか?
foreachではなく、ということですか?
0353nobodyさん2008/08/21(木) 23:22:53ID:???
>>347
あのな、NOTICEレベルのエラーも表示させてみ
ループ内で使ってる変数が未定義とか、そんなオチだろうよ。
0354nobodyさん2008/08/21(木) 23:38:39ID:2yWxB/YG
Vimなんて平気で使えます><
0355nobodyさん2008/08/22(金) 00:03:05ID:???
>>348
foreach内で$addとかの変数をvar_dumpしてみ
普通foreachの外でmail出来てforeach内でループ出来ないってことはない
スコープが透過だからな

それと余談だが、一斉送信はsendmailよりSMTPがいい
sendmailは一通ずつコネクションを切るからオーバーヘッドがウザす
さくらでSMTP使えれば、だが
0356nobodyさん2008/08/22(金) 00:18:15ID:???
>> 353さん
>> 355さん

ありがとうございます!
ご指摘いただいて、一通りエラーが出ないようにしてみたらメールが送られてきました。
お騒がせして申し訳ありません…。

もう少しきちんと作って確認をしてみます。
メールもSMTPで送れそうだったらそちらで送ることにします。

ありがとうございました!
0357nobodyさん2008/08/22(金) 00:19:44ID:UcmQnfu1
>>355
詳しいのか詳しくないのかわけわからんコメントですねw
上と下とが別人みたいw
0358nobodyさん2008/08/22(金) 00:22:22ID:UcmQnfu1
sendmailよりpostfixやqmailが良い
sendmailは一通ずつコネクションを切るからオーバーヘッドがウザす
postfixやqmailなら・・・どうだかしらないけどw
03593552008/08/22(金) 02:44:01ID:???
言い方が悪かった
sendmailと言ったのはPHPのmail系関数にwrapされてる実装の方
つまりphp.iniのsendmail_pathで指定したコマンドを経由して送信する機能のことね

SMTPと言ったのは25や587ポートで内部や外部のSMTPにコネクションを開いて送信する方
こっちはコネクションを自分で閉じるから接続・切断のオーバーヘッドが少ない
自分で実装するのが面倒な時はPEAR::SMTPを使う手もある

>>355 「foreach内でループ出来ない」
ボケとる・・・
0360nobodyさん2008/08/22(金) 02:46:30ID:nRWBXbXV
どなたか教えて頂けないでしょうか?

文字の0〜9をパターンマッチングさせる時の正規表現はどのように書けば
よいのでしょうか?
↓だと数字の0〜9のパターンマッチングになるため、$search_numberに
文字列の0〜9(例:文字列で777)が入っていても0として扱われてしまいます。

preg_match("[0-9]",$search_number)
0361nobodyさん2008/08/22(金) 02:47:54ID:XmBnafOM
Net_SMTP使ってるんですが、
$smtp->connect()時に、タイムアウトをたとえば10秒に指定していても、
回線を切って実行してみると、エラーを返してくるのが1分後くらいです。
何が問題なのでしょうか?
0362nobodyさん2008/08/22(金) 02:55:40ID:???
>>360
デリミタ
03633612008/08/22(金) 03:08:54ID:???
Net_Socketの中見たら、中でgethostbynameとか使ってました
回線切ってたからここで引っかかってたのかも
っていうか、この関数タイムアウト自体がないんですね
PHPテラアホス
0364nobodyさん2008/08/22(金) 03:30:11ID:???
>>362
/ が抜けているだけだったのですね。
上手く動作しました。ありがとうございました。
0365nobodyさん2008/08/22(金) 09:06:51ID:???
>>363
まぁしかたないと思う
Cの同名関数を利用してるしな
ソケットで独自に実装すればstream_set_timeoutが使えるのにな

0366nobodyさん2008/08/22(金) 09:09:53ID:???
>>317
sharedの場合soファイルが出来るだけ
iniの設定変えてなかったらエラーとか出ない
ただ関数がネーヨというエラーは出るがな
0367nobodyさん2008/08/22(金) 09:19:01ID:5EVYna0b
すみません。教えてください。
phpで作ったサイトで運用してますが、
CPU Load Avarageというのを見ています。
これって、1を超えると、CPUの使用率は常に100%という関係になるのでしょうか?
私の場合、1を常に超えた状態なので、phpが暴走するのではないかと不安視しています。
サーバを増やすなどの措置が必要になりますか?
アドバイスを教えてください。
0368nobodyさん2008/08/22(金) 09:21:22ID:???
はぁ?お前は何を言ってるんだ
0369nobodyさん2008/08/22(金) 09:28:56ID:5EVYna0b
>>368
すみません。具体的なイメージなんですが、
私が不安視しているのはwindowsの場合とかって、
CPUの使用率が100%になると暴走状態になって、再起動することになりますよね。

そのような状態がサーバーで起こっているとしたら、
新しく起動されたphpが暴走して、どんな悪影響を及ぼすか不安視しています。

windowsみたいに、画面が二重に表示されたり、マウスの軌跡がずらずら並んだり、
そのようなことがphp上で発生する状態なのでしょうか?
0370nobodyさん2008/08/22(金) 09:40:05ID:???
もうちょっと知識と経験を積んでから始めたほうがいいと思う
0371nobodyさん2008/08/22(金) 09:50:22ID:5EVYna0b
>>370
たしかにそうですね。すみません。
会社命令で、その中でパソコンに詳しいのが私だけで、
といっても、ホームページを作った経験があるだけなんですが、
それで会社の全商品を表示したりするサイトなどを一人で立ち上げることになり、
会社から飼ってもらった本を片手にやっと、できったという感じです。
OSは本の付録についていたFreeeBSDを使っています。

ですが、その本でCPU AVERAGEを見ろとかいてあり、みたら1を常に超えている状態になっていて、
困っています。会社に他に空いているパソコンがないので、
別のパソコンを買うにも、稟議書みたいなものを通さないと行けないので、
面倒だったりします。やはり、もう一台必要でしょうか?
0372nobodyさん2008/08/22(金) 09:59:18ID:???
>>371
その状態は大変危険な状態です。しかも、業務につかっているなら尚更です。
とりあえず、ここから見積もりを取って、早急に上司と掛けあうのが先決です。
http://click.linksynergy.com/fs-bin/click?id=nEMDVbzUNEo&offerid=113065.10001436&type=3&subid=0
今現在も稼働しているなら、大急ぎで対応してください。
0373nobodyさん2008/08/22(金) 09:59:57ID:???
>>371
topコマンドの「CPU Load Avarage」か?
ほとんど負荷のない時に1が表示され、負荷の高い場合は最大で10だ
負荷の高さを10段階で評価する
ちなみにスレ違い

PHPがCPUの負荷で暴走することはまずない(せいぜいタイムアウト
メモリ不足でcoreを吐くことはある
0374nobodyさん2008/08/22(金) 10:11:34ID:5EVYna0b
>>372>>373
お返事、大変ありがとうございます。
phpが暴走することがないということで、それは安心しました。
ただ、危険な状態には変わりないんですね。
教えられたサイトで、さっそく見積もりを取ってみます。
ありがとうございございました。あと、スレ違いになってしまい申し訳ありませんでした。
0375nobodyさん2008/08/22(金) 10:47:30ID:???
>>374
>>372は釣りだと思うが・・・

CPU面ではまったく負荷が感じられないわけだし
どんなソースを書いてるか知らないからこれだけでは危険と判断出来ん
(スペック的に現状では問題ない)

素人が企業サイト、これは危険だがな
0376nobodyさん2008/08/22(金) 11:25:27ID:UcmQnfu1
何でHP作るぐらいのスキルの人が鯖管理まで手を出さなくちゃなんない理由が無い。
コストの話なら逆にそっちのほうがかかる。ユーの無駄な人件費が
0377nobodyさん2008/08/22(金) 11:30:55ID:???
>>373
何も負荷がない時のロードアベレージは、1じゃなくて0だろ。
誰も突っ込まないところを見ると、このスレの住民は相当レベルが低そう。
0378nobodyさん2008/08/22(金) 11:43:11ID:SUat73CA
>>377
>>373 もCPU Load Avarage
とか書いてる時点で釣りだと思うんだけど……。
Load Averageのことだとしても、説明変だし。
0379nobodyさん2008/08/22(金) 11:59:12ID:???
>>374
スリーサイズ教えてくれたら的確なアドバイスをレスしよう
0380nobodyさん2008/08/22(金) 12:00:50ID:???
明らかに釣りなのにいちいち突っ込む奴の方が頭悪いだろJK
0381nobodyさん2008/08/22(金) 12:05:39ID:???
>>380
とかいって、俺が突っ込んだのを見て、慌ててレスした癖に。
0382nobodyさん2008/08/22(金) 12:06:12ID:???
なんだこの基地外
0383nobodyさん2008/08/22(金) 12:17:30ID:???
は?
俺も実は知ってました、それ位赤ちゃんでも分かる、みたいな言いぶり。
こういう奴周りにもいるが、キモイわ。
0384nobodyさん2008/08/22(金) 12:20:07ID:???
アフィ貼ってる時点で・・・
0385nobodyさん2008/08/22(金) 12:45:45ID:q1zzzoBS
釣り人が釣られて怒ってらwwwwwwww
0386nobodyさん2008/08/22(金) 14:56:58ID:UcmQnfu1
釣り人が釣られるってあれだろ?
渓流でへたくそが投げた針が漫画みたいに口に引っかかってあたたたた〜ってなるあれだろ?
0387nobodyさん2008/08/22(金) 15:53:59ID:fin98YtZ
うわあ痛そう
0388nobodyさん2008/08/22(金) 16:02:05ID:???
俺は、投げたルアーで眼球をえぐられた人を知っているけど。
0389nobodyさん2008/08/22(金) 16:37:18ID:???
50近い男女が大学生を演じるって無理ありすぎ!!!

制作予算ねーのかよ。
0390nobodyさん2008/08/22(金) 17:06:39ID:???
>>389
ハァ?
0391nobodyさん2008/08/22(金) 17:07:23ID:???
誤爆だろw
0392nobodyさん2008/08/22(金) 17:07:55ID:???
気になるw
0393nobodyさん2008/08/22(金) 20:35:41ID:???
sessionをファイルで保存するのと、
memcashedで保存するのとどっちが速いですか?
ファイル操作とmemcahedの接続コストとどちらが掛かるかなんですが。
ちなみに今はファイルでやっています。
それより、良い方法がないかと模索中です。
0394nobodyさん2008/08/22(金) 21:40:52ID:???
どっちもそれほど変わらん
DBとして使うなら全然違うがセッションでは・・・

phpのセッションもコンストラクトとデストラクトでのみファイルアクセスを行うから
その時はメモリよりオーバーヘッドが豆粒程度に大きいけど
途中の読み書きはメモリ上に展開されたセッション変数に収まる
結局メモリだからほとんど同じ

0395nobodyさん2008/08/22(金) 22:27:08ID:???
>>394
> phpのセッションもコンストラクトとデストラクトでのみファイルアクセスを行うから
そうなんですね。それなら、大して変わりなさそうですね。
というより、ディスクよりメインメモリーの方が小さいことを考えると、
アクセス数が増えるこを考慮してファイルの方がリスクが少ないともいえますね。
であれば、冒険せずにファイルでやってみます。
ありがとうございます!!
0396nobodyさん2008/08/22(金) 22:50:09ID:???
おれはもともとアニオタのおっさんが質問してるってことを見抜いてたから一言も答えなかったぞ
0397nobodyさん2008/08/23(土) 00:45:53ID:???
一体誰と戦っているんだ
0398nobodyさん2008/08/23(土) 14:07:17ID:5Laah46M
症状:不要なディレクトリが削除できない

 FTP経由で不要なディレクトリが削除できなかったので、rmdir関数を利用してみたところ、以下のエラーメッセージが表示されました。

エラーメッセージ:
Warning: rmdir($dir) [function.rmdir]: Directory not empty in /***.com/***.html on line 2


経過:rmdir関数は、ディレクトリの中にファイルが存在した場合削除に失敗する仕様なので上記のエラーメッセージを吐き出したものと考えられますが、ディレクトリの中身は空(0 Bytes)です。

 試しに、ディレクトリの中身ごと削除を行うという「system("rm -rf $dir");」を実行させてみましたが、こちらはエラーメッセージは吐き出しませんが、ディレクトリの削除もされませんでした。

 こういう場合の原因は何が考えられますか?
 また、どう対処すれば良いでしょう。

サーバのOS:不明(無料レンタルサーバ)
PHP 5.1.6
参考:ディレクトリまたはファイルの所有者は自分のIDになっています。
0399nobodyさん2008/08/23(土) 14:39:43ID:???
>>398
.で始まるファイルがあるとか
そうでなければサーバのPHP設定とか
0400nobodyさん2008/08/23(土) 15:12:43ID:???
パーミッションエラーじゃないから違うとは思うが、
そのディレクトリの親ディレクトリの書き込み属性とか
0401nobodyさん2008/08/23(土) 15:18:06ID:???
400 :nobodyさん:2008/08/23(土) 15:12:43 ID:???
パーミッションエラーじゃないから違うとは思うが、
そのディレクトリの親ディレクトリの書き込み属性とか


書き込み属性がパーミッションだっつうのw
0402nobodyさん2008/08/23(土) 15:35:07ID:???
所有権は?
0403nobodyさん2008/08/23(土) 15:48:03ID:???
所有権は、時効によって消滅しました。
04043982008/08/23(土) 15:50:48ID:5Laah46M
>>399
変わった名前のファイルは作成しませんでしたし、ファイルは全て削除されたようで空です。
サーバのPHP設定というのはどういう事になりますか?
察しが悪くすみません


>>400
パーミッションは変更出来るので色々試してみましたが、結果は変わりませんでした。


>>402
所有権は自分のIDになっています。
ので、属性変更は可能です。
ディレクトリが削除できません。
0405nobodyさん2008/08/23(土) 16:48:46ID:???
>>404
いろいろって、ディレクトリを消す=親ディレクトリの内容が変わる
つまり、wが必要
0406nobodyさん2008/08/23(土) 17:10:43ID:???
not emptyなら空じゃないからでしょ
パーミッションどうこうでもnot emptyが出力されるはずは・・・

scandir等でディレクトリの中を出力してみたら?
.で始まるファイルを隠しファイルとしている場合がある
「.」「..」は無視な
0407nobodyさん2008/08/23(土) 17:33:06ID:MJFU9Zb0
すいません、すごく基本的な質問です。

掲示板にパスワードを入力してチェックする際に
半角英数字4〜8文字かどうか調べたいのですが。

if(preg_match("/[0-9a-zA-Z]{4,8}/", $pass)

これでいけるかと思っていたらこれだと
半角英数字4〜8文字があるとok になってしまうらしく
(半角英数字10文字)例)1234567890
(記号有り)例)****1234++
もokになってしまいます。

正しい記述はどうするんでしょう?
04083982008/08/23(土) 17:36:35ID:5Laah46M
>>406
そういう手がありましたか・・・!(頭弱くてすみません
scandir活用させてもらったところ
しっかり隠しファイルがいつの間にか存在していました。
「0 Bytes」という表示から本当に中身は空なのだと思い込んでいたせいで混乱しておりました。

地道にリストアップして削除していきます
助かりました、ありがとうございます!
04094072008/08/23(土) 17:55:07ID:MJFU9Zb0
あ〜、すいません解決しました。

^[0-9a-zA-Z]{4,8}$

先頭と終端を指定していなかった。
お手数をおかけしました。
0410nobodyさん2008/08/23(土) 20:19:17ID:tD80K7qS
phpでメールを送信した後に、本当に送信したメールが届いてるかどうかを
チェックする関数を教えて下さいませ。お願いします。

【OS】CentOS4
【PHP】PHP5
【DBサーバー】MYSQL5.0
です。
0411nobodyさん2008/08/23(土) 20:32:21ID:???
>>410
無い。

さあ次どうぞ。
0412nobodyさん2008/08/23(土) 20:57:45ID:tD80K7qS
>>411
まじですか?

PHPって、GG佐藤以下ですねw
0413nobodyさん2008/08/23(土) 21:27:58ID:pIRCIy4o
すみません、質問させてください。

例えばURLから example.php?param1=aaa&param2=bbb のように2つのパラメータを読み込む場合、
XML形式のサイトマップなどからのアクセスだと、
example.php?param1=aaa&param2=bbb というURL表示からの読み込みとなるため
"amp;"がパラメータ名の一部として解釈されてしまい、正しいデータのやりとりがなされません。

この問題をphpプログラム内にて解決するにはどうしたらよろしいでしょうか?
ちなみに.htaccessでのRewriteRule機能を利用しての解決はできませんでした。

初歩的な質問かもしれませんが、どなたか教えていただけないでしょうか?
よろしくお願い致します。
(php5.2 サーバーはKagoyaの専用サーバープランを使用しています。)
0414nobodyさん2008/08/23(土) 21:32:39ID:???
>>412
お前が勉強不足なのだよ
そもそも到着したかどうかなんて分かるわけないじゃん
宛先のMXからリレーしてるかもしれんのに
どうしても必要ならエンベロープに届くエラーメールでもチェックするんだな
0415nobodyさん2008/08/23(土) 21:35:36ID:???
>>413
html_entity_decode関数で「&」を「&」に戻せば良かんべ
0416nobodyさん2008/08/23(土) 21:36:41ID:???
>>415
1個目の「&」−>「&」

0417nobodyさん2008/08/23(土) 21:41:06ID:bsrwSGnB
PHP+MySQLでのサイト作成で、いい方法を思いつかないので、アイデアを貸してくださいw

year month day text
2008 8 22 aaaa
2008 8 22 bbbb
2008 8 23 cccc
 ・
 ・
 ・

という感じでデータがあって

ページ上には

2008/8/22
aaaa
bbbb

2008/8/23
cccc

という風に出したいです。
0418nobodyさん2008/08/23(土) 21:43:04ID:???
>>415

>>413です。ありがとうございます!
早速試してみようと思います。
0419nobodyさん2008/08/23(土) 22:05:47ID:???
>>417
配列を使えばいいんじゃね?

$recodes // mysqlからfetchallしたようなやつ(fetchallはPDOだが)
$list = array();
foreach($recode AS $row){
 $date = *****(2008/8/22になるように)
 $data = *****(aaaaになるように)
 if(!isset($list[$date])){ $list[$date][] = $date."<br />"; }
 $list[$date][] = $data."<br />";
}
implode("<br />", $list);

まぁ考え方の1つってことで
0420nobodyさん2008/08/23(土) 22:07:07ID:???
ぎゃ!まちがった

$recodes // mysqlからfetchallしたようなやつ(fetchallはPDOだが)
$list = array();
foreach($recode AS $row){
$date = *****(2008/8/22になるように)
$data = *****(aaaaになるように)
if(!isset($list[$date])){ $list[$date] .= $date."<br />"; }
$list[$date] .= $data."<br />";
}
implode("<br />", $list);
0421nobodyさん2008/08/23(土) 22:14:23ID:???
度々すみません。
>>413,>>418です。

URL文字列を$HTTP_GET_VARSとして、

$HTTP_GET_VARS = html_entity_decode($HTTP_GET_VARS);

と該当ページに挿入したのですが
Warning: html_entity_decode() expects parameter 1 to be string というメッセージが出て
上手くいきませんでした。この関数の正しい使用法を教えていただけないでしょうか?
0422nobodyさん2008/08/23(土) 22:22:42ID:???
>> 421
parse_str(html_entity_decode($_SERVER['QUERY_STRING']), $argv);
print_r($argv);
ってやってみ
0423nobodyさん2008/08/23(土) 22:56:55ID:???
>>421です。

>>422さん、上手くいきました。
どうもありがとうございました!
04244172008/08/23(土) 23:11:04ID:bsrwSGnB
ありがとうございます!
なんとなく見えました!
0425nobodyさん2008/08/24(日) 02:12:36ID:tkAECmwh
掲示板を製作しています。
テキストエリアから入力された改行コードを<br>に変換するのは以下のコードでできるのですが、

$ensql = preg_replace("/(\r\n|\r|\n)/","<br>",$ensql);

逆に<br>を改行コードに変換するのはどうすればよろしいのでしょうか?
編集機能を持たせようと思い改良を加えているのですが・・・

\r\nでしたらWindows系ですし、\nでしたらUnix系ですし・・・・
0426nobodyさん2008/08/24(日) 02:32:34ID:???
>>425
べつに\nで出力したっていいじゃん
どうせ正規表現で<br>に直すんだから
0427nobodyさん2008/08/24(日) 02:33:21ID:???
winで\nで出力したらなんか問題でもあるか?
ためして不具合でてからいってくれ
0428nobodyさん2008/08/24(日) 02:34:37ID:tkAECmwh
すいません・・・\nでも問題無いのですね。
ありがとうございます(;´Д`)
0429nobodyさん2008/08/24(日) 09:50:04ID:???
どっちでも問題ないが、それとは別にWindowsの環境で
テキストモードでオープンしたファイルに\nで書き込むと
勝手に\r\nに変換される。
テキストモードというのがあるのは、そういうこと。
0430nobodyさん2008/08/24(日) 09:53:19ID:wBtpqVh7
質問です
ttp://fs-server.net/reference.htmlにある
他サイトの表示内容を取得 ⇒ ##GET_SITE##
はどの様になってるのでしょうか?
readfile()で全体を取り込むのはできたのですが開始テキストと終了テキストを指定するところが分かりません。

よろしくお願いします。
0431nobodyさん2008/08/24(日) 11:17:31ID:???
いえいえこちらこそ
0432nobodyさん2008/08/24(日) 14:19:31ID:???
>>430
strstrだけで何とかなる
終了テキストは補完する必要ありだが
0433nobodyさん2008/08/24(日) 18:12:19ID:???
PDOとmysqlの文字化け対策に「set names utf8」を使ってるんですけど
これはあまりよろしくないらしいんですが
他に何か解決方法はあるんですか?
レンタルサーバなのであまり細かい設定はできないのですが
0434nobodyさん2008/08/24(日) 18:26:23ID:???
>>432
ありがとうございます。調べてみます!
0435nobodyさん2008/08/24(日) 19:02:06ID:???
>>433
文字化けは主にサーバ側で自動変換させるから生じる
この際nemeでbinaryを指定することをオススメ
無変換で通信するから化けることはまずない

0436nobodyさん2008/08/24(日) 19:38:55ID:???
>>433
あ、それ俺も聞きたい。スレチだけど。
何かのSQL投げる度に、そのSQL実行するから、SQLの実行数が倍になってしまう。
0437nobodyさん2008/08/24(日) 19:47:07ID:???
接続したときに1回実行すればいいだろ
0438nobodyさん2008/08/24(日) 19:54:08ID:???
接続直後に、接続に使ったライブラリの機能で漢字コードの設定をすればいい
SET NAMES だとライブラリ側は文字コードを認識しないので、文字コードの違いを利用した
悪意のあるコードを入れられる可能性がある。
0439nobodyさん2008/08/24(日) 20:08:35ID:???
>接続直後に、接続に使ったライブラリの機能で漢字コードの設定をすればいい
mysql関数だとmysql_set_charsetってのがあるみたいですけど
PDOだとどうしたらいいんですか?
0440nobodyさん2008/08/24(日) 21:12:28ID:???
set namesでいいべ
インジェクションを心配するってことはリクエストの文字コード変換やクォートを怠ってるってことでしょ
pdoならprepareとドライバで十分とは言えなくてもやらないより全然違う
0441nobodyさん2008/08/24(日) 21:19:00ID:???
俺もset namesしかやり様が無いからやってるけど
無駄なクエリが1発っていうだけでなんか気持ち悪いよね
0442nobodyさん2008/08/25(月) 00:06:29ID:???
確かに無駄にSQLを流すことになるが
APIと言ってもmysql_set_charsetも同じことだぜ
サーバとクライアントで文字コードを統一することが第一だな
0443436 2008/08/25(月) 00:26:46ID:???
ググったら、直った。
ver4.1以降なら、mysqlの設定ファイルの問題。
0444436 2008/08/25(月) 00:28:45ID:???
おっと書き忘れた。

skip-character-set-client-handshake

これをsqldセクションに入れればOK!
0445nobodyさん2008/08/25(月) 01:01:07ID:???
<form name="frm" method="post" action="test.php">
<input type="hidden" name="test" value="a">
<a href="#" onclick="document.frm.submit()">フォームをサブミットする</a>
</form>
でtest.phpにhtmlページにおける値をPHP変数に渡して、
<head>
<?php
$txt = $_POST['txt'];
?>
<script type="text/javascript">
<!--
function hoge(){
var txt = "<?= $txt ?>";
alert(txt);
}
//-->
</script>
</head>
<input type="button" value="click" onclick="hoge();"></input>
このようにPHP変数からJavaScript変数に渡したいのですがどのようにすればよいのでしょうか。
上記のプログラムだとできません。どなたかご教授お願いします。
0446nobodyさん2008/08/25(月) 01:29:05ID:???
>>444
my.cnfを書き換えられるならサーバとクライアントの文字コードを統一した方が安全だぜ
そもそもskip-character-set-client-handshakeって
クライアント側の文字コードを省略してサーバの文字コードを強制的に使用するって設定じゃん?
かなり背水な対応方法だな
0447nobodyさん2008/08/25(月) 01:33:18ID:???
>>445
誤 $txt = $_POST['txt'];
正 $txt = $_POST['test'];
0448nobodyさん2008/08/25(月) 01:41:33ID:???
>>447
こんなところでミスしてたとは…orz
きちんと動きましたありがとうございます
0449nobodyさん2008/08/25(月) 01:47:47ID:???
SET NAMES するのを忘れた状態で保存してしまったデータは
どうやって取り出したら良いでしょうか??

テーブルの文字コードは UTF-8
データはPHPからSET NAMESを忘れて突っ込んだUTF-8

mysqldump .(省略) --default-character-set=utf8 > hoge.dump
して取り出してみたけど、見事にデータがぶっ壊れてます。困った。
0450nobodyさん2008/08/25(月) 01:48:32ID:???
そういえば、
var txt = "<?= $txt ?>";
の箇所の<?= 〜 ?>は一体なんなのでしょうか?
0451nobodyさん2008/08/25(月) 02:11:33ID:???
>>446
俺は、サーバーもクライアントも文字コード一緒だよ。
っていうか、俺がやっている奴は趣味でやっている奴だが、
そもそもシステム構築する際は、文字コードは統一しておくのが普通でしょ。
文字コードが混在しているシステムは、テスト工数が増大するし、リスクを増える。
■ このスレッドは過去ログ倉庫に格納されています