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

このエントリーをはてなブックマークに追加
1nobodyさん
まず読め→【PHP マニュアル】http://www.php.net/manual/ja/
PHPで最良の教本はこの公式マニュアル。市販の書籍は嘘が多いので鵜呑みにしない。
過去スレ、関連スレ、FAQなどは>>2-10辺り
次スレは970が立ててください立たなかった場合は980よろ

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

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

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

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

【その他諸注意】
・正規表現・PEAR・テンプレート(Smarty等)・フレームワークは各該当スレへ
・SQLについての質問はデータベース板(PCカテゴリ)の各スレで
2nobodyさん:2008/04/11(金) 06:39:15 ID:???
【簡易FAQ】 (1/3)
1.文字コードは何を使えばいいの?
 →1.UTF-8 2.EUC-JP のどちらか。迷うようなやつはShift_JISは使っちゃダメ。
2. このスレに書き込むときに自分のサイト名を晒したくない
 → http://example.com/が例文などのために予約されている。hogehoge.comは使っちゃダメ。
3. ブラウザに何も表示されないんだけど・・・
 → Apacheの設定を見直せ。ファイルの拡張子は何にしてて、その拡張子でPHPを呼ぶようになっているか?
4. 記号の意味がわからないけどググりようがない
 → 「@」 エラー表示を抑制、「->」 オブジェクトのメンバにアクセス、「::」 静的なメソッド呼び出し、
  「==」は暗黙の型変換をしてゆるい比較、「===」は型情報も含めた厳密な比較
5. echo "$arr['hoge']['fuga']"; と書いたらエラーになった
 → {おっぱい括弧}でくくって"{$arr['hoge']['fuga']}"にする
6. 一定時間ごとに自動的に何かしたいんだけど
 → cronかタスクスケジューラを使え。
7.extractって危険なの?
 →変数上書き&初期化忘れなどで危険。楽だからという理由だけで安易に使わない。
8. include/requireに「〜.php?a=b&c=d」のようなパラメータをつけたい
 → URL呼び出しなら可能だけど、普通のファイル呼び出しではできません
9.include/requireでURLを指定しても何も起きない
 → .phpの拡張子のファイルをURLで呼び出すと、1度PHPプログラムとして実行された結果になる。
10. そもそもインストールの時点でうまくいかない
 → 確認すべきはPHPのconfigureの引数、php.iniの内容と置き場所、
  Webサーバの設定(Apacheならhttpd.conf)、起動&再起動あたり
3nobodyさん:2008/04/11(金) 06:39:27 ID:???
【簡易FAQ】 (2/3)
11. SQLの質問はどこで?
 → データベース板に誘導されるのが嫌ならPHPにうまく関連させて質問する
12. 文字列のなかに、英字のみとか数字のみとか記号が入っちゃいやんとかはどうしたらいいの?
 → ctype_〜()が手軽。複雑なパターンはpreg_〜()あたりで正規表現を使う。
13. $a1, $a2, $a3 ... のような変数名をうまく扱いたい
 → 可変変数で実現できるけど、むしろ配列を使って$a[1], $a[2], $a[3]等とするのがベター
14. echoとprintってどう違うの?
 → よく議論される話題であるが基本的に両者とも同じ。 以下ちょっとした議論。
  http://www.faqts.com/knowledge_base/view.phtml/aid/1/fid/40
15. クッキーの情報をユーザから隠したい
 → セッション使え。ただしクッキーとセッションは仕組みが違うから同じように扱うな
16. strip_tags()で削除しないタグを複数指定したい
 → strip_tags($html, '<a><p><font>'); // htmlspecialchars()も検討すべし
17. CSVやTSVのファイルをスマートに扱いたい
 → まずはfgetcsv()。ただし日本語を含むと正常に動作しない場合があるので注意だ。
18. 値渡しと参照渡し(「&」を使う)のパフォーマンスの違い
 → C言語じゃないので、パフォーマンス目的で使いわけたらダメ。参照渡しにすると逆に遅くなったりする
  参照渡しは引数に戻り値を設定したり引数を関数内で変更するなど、正しい目的に使うこと
19. ファイル入出力関数(fopen等)でリモートファイル(http://〜とか)を扱う際の限界
 → fsockopen()でソケット通信 or PEARのHTTP系 or CURLで解決
  必要ならHTTPをはじめとする各種プロトコル(どんなデータを送受信するか)はRFCなどで調べる
20. PHPからPOSTリクエストしたい
 →19.を参照
4nobodyさん:2008/04/11(金) 06:39:39 ID:???
【簡易FAQ】 (3/3)
21. 画像処理一般 or GDの限界
 → ImageMagick(PECLのやつ or シェルから実行)
22. 画像・音・動画はファイルで保存?DBに保存?
 → 好きにしてください
5nobodyさん:2008/04/11(金) 06:39:56 ID:???
関連リンク
■本家マニュアル   http://www.php.net/manual/ja/
■日本PHPユーザ会 http://www.php.gr.jp/
■PEARマニュアル  http://pear.php.net/manual/ja/
■メーリングリスト   http://ns1.php.gr.jp/mailman/listinfo/
■ZFマニュアル    http://framework.zend.com/manual/ja/

(以下英語)
■Smarty       http://smarty.php.net/
■Zend本家      http://www.zend.com/
■Zend Framework  http://framework.zend.com/
■php | architect   http://www.phparch.com/
■Smartyマニュアル http://smarty.php.net/manual/en/
■PECL本家(英語) http://pecl.php.net/
6nobodyさん:2008/04/11(金) 06:40:31 ID:???
■過去ログ
【PHP】下らねぇ質問はここに書き込みやがれ 66
http://pc11.2ch.net/test/read.cgi/php/1205655807/
【PHP】下らねぇ質問はここに書き込みやがれ 65
http://pc11.2ch.net/test/read.cgi/php/1203854597/
【PHP】下らねぇ質問はここに書き込みやがれ 64
http://pc11.2ch.net/test/read.cgi/php/1202536271/
【PHP】下らねぇ質問はここに書き込みやがれ 61
http://pc11.2ch.net/test/read.cgi/php/1201425479/
【PHP】下らねぇ質問はここに書き込みやがれ 62
http://pc11.2ch.net/test/read.cgi/php/1199956159/
【PHP】下らねぇ質問はここに書き込みやがれ 61
http://pc11.2ch.net/test/read.cgi/php/1198002831/
【PHP】下らねぇ質問はここに書き込みやがれ 60
http://pc11.2ch.net/test/read.cgi/php/1196511516/
【PHP】下らねぇ質問はここに書き込みやがれ 59
http://pc11.2ch.net/test/read.cgi/php/1195204145/
【PHP】下らねぇ質問はここに書き込みやがれ 58
http://pc11.2ch.net/test/read.cgi/php/1194084457/
【PHP】下らねぇ質問はここに書き込みやがれ 57
http://pc11.2ch.net/test/read.cgi/php/1193062236/
【PHP】下らねぇ質問はここに書き込みやがれ 56
http://pc11.2ch.net/test/read.cgi/php/1192092941/
【PHP】下らねぇ質問はここに書き込みやがれ 55
http://pc11.2ch.net/test/read.cgi/php/1191058556/
7nobodyさん:2008/04/11(金) 06:40:45 ID:???
■関連スレ
くだすれPHP(超初心者用)3
http://pc11.2ch.net/test/read.cgi/php/1193295871/
PHP関連の書籍 第5版
http://pc11.2ch.net/test/read.cgi/php/1203696253/
【PHP】フレームワーク CakePHP 3ホール目【本命】
http://pc11.2ch.net/test/read.cgi/php/1205475360/
【PHP】 Smarty 隔離スレ 【テンプレート】
http://pc11.2ch.net/test/read.cgi/php/1201879269/
PHP総合雑談スレ
http://pc11.2ch.net/test/read.cgi/php/1200314111/
【PHP】フレームワークについて語るスレ10【総合】
http://pc11.2ch.net/test/read.cgi/php/1202521438/
【PHP】Ethna part.2【国産フレームワーク】
http://pc11.2ch.net/test/read.cgi/php/1186096518/
ZendFramework Part2
http://pc11.2ch.net/test/read.cgi/php/1204726884/
フランチョスとsymfony
http://pc11.2ch.net/test/read.cgi/php/1201177567/
最強のPHPエディタはなに?
http://pc11.2ch.net/test/read.cgi/php/1133785416/
8nobodyさん:2008/04/11(金) 06:41:24 ID:???
9nobodyさん:2008/04/11(金) 09:39:32 ID:???
10nobodyさん:2008/04/11(金) 09:42:15 ID:???
はやいけどphp7開発版試してる人居る?
11nobodyさん:2008/04/11(金) 10:28:19 ID:???
これが正しいテンプレ

まず読め→【PHP マニュアル】http://www.php.net/manual/ja/
PHPで最良の教本はこの公式マニュアル。市販の書籍は嘘が多いので鵜呑みにしない。
過去スレ、関連スレ、FAQなどは>>2-10辺り

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

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

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

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

【その他諸注意】
・正規表現・PEAR・テンプレート(Smarty等)・フレームワークは各該当スレへ
・SQLについての質問はデータベース板(PCカテゴリ)の各スレで
12nobodyさん:2008/04/11(金) 12:09:37 ID:75QSkZRP
以下のフォームのMAX_FILE_SIZEでの制限サイズについて質問です。

<form enctype="multipart/form-data" action="up.php" method="POST">
<input type="hidden" name="MAX_FILE_SIZE" value="168000" />
<input name="userfile" type="file" />
<input type="submit" value="ファイルを送信" />
</form>

このフォームから画像を送ったのですが、print_rで結果をみると
Array ( [file] => Array ( [name] => osusume.jpg [type] => image/jpeg [tmp_name] => C:\tmp\phpABC.tmp [error] => 0 [size] => 168001 ) )
というふうにerrorは0がついてます。
htmlで設定するMAX_FILE_SIZEのバイトと、print_rで取得できるsizeは、バイトの計算式が違うのでしょうか?
1KB=1024でMAX_FILE_SIZEを設定したのですが、1024でないのでしょうか?

サーバ側でsize規制はしてるのですが、MAX_FILE_SIZEを指定した場合の挙動を理解したいと思ってます。
どなたかご教授お願いいたします。
13nobodyさん:2008/04/11(金) 13:33:40 ID:34hEX+xz
formに入力された値を
^[0-9]+$
にでチェックしてるのですが、これに「+」も加えるのがどうすればいいのでしょうか?
/*form*/
1) 50
2) 25+25

いずれも通したいのですが。
14nobodyさん:2008/04/11(金) 13:53:58 ID:???
>>13
^[0-9\+]+$
15nobodyさん:2008/04/11(金) 14:59:11 ID:34hEX+xz
>>14
早速のレスありがとうございます!
今からやってみます〜!
16nobodyさん:2008/04/11(金) 15:51:14 ID:icnUZbgw
PDOで、特定のカラムだけ取得して1次元配列で返してほしいときは
fetchColumn()をfetchで回すのと、fetchAll(PDO::fetchColumn)を使うのとどっちが効率良いんだろう?
17nobodyさん:2008/04/11(金) 16:18:38 ID:???
>>16
質問するときは言葉を選べクズ。
18nobodyさん:2008/04/11(金) 16:19:15 ID:???
>>16

誘導
くだらない質問でもど偉そうに聞いていいスレ
http://pc11.2ch.net/test/read.cgi/php/1158647441/
19nobodyさん:2008/04/11(金) 17:30:27 ID:???
>>16
配列を作る必要があるなら fetchAll(PDO::FETCH_COLUMN) でいい。
一度参照したら捨てていい場合や、
メモリ使用量を気にしないといけない場合は逐次 fetchColumn()。
20nobodyさん:2008/04/11(金) 19:58:21 ID:kamEmAKJ
質問があります。
phpでバイナリ形式のファイル(音声ファイル)を処理したいと考えています。

具体的には、バイナリデータを10進数に変換し
特定の箇所を
「10(10進)」→「20(10進)」
などに置き換えた後、再びバイナリ形式に戻して新ファイルとして出力したいです。

現在は、
@bindec()で読み込んだバイナリデータを変換
A処理
Bdecbin()でバイナリ変換してファイルに出力
としているのですが、
プログラム実行後に出来た音声ファイルを開こうとすると
「予期しないデータを含んでいるか破損している可能性があります」
と表示され開くことができません。

ちなみにテキストエディタで開くと、
元ファイルは文字化けしたような文字がたくさん並んでいるのですが、
実行後のファイルは、0と1のみが無数に表示されてしまいます。
実行後のファイルも化けたような文字がたくさん出てこれば成功するような気もします。

深い知識がないので的外れなところもあるかもしれませんが、
よろしければどなたか教えてください。
よろしくお願いします。

プログラム実行OS:Linux
言語:PHP 4.4.8
音声ファイル再生OS:Windows
です。
21nobodyさん:2008/04/11(金) 20:14:38 ID:???
>>20
何がやりたいが意味不明だが、そんなことできるわけもなく。
ファイルがおかしくなるのは当たり前。
バイナリエディタに音声ファイルと同じデータを入力して書き出したところで音声ファイルにはならない。
22nobodyさん:2008/04/11(金) 20:15:27 ID:???
データを、どう読み込んで、どう保持してるか、さらしてみ
23nobodyさん:2008/04/11(金) 20:24:14 ID:???
>>21
ちゃんとフォーマットさえ守ればできるし。
24nobodyさん:2008/04/11(金) 21:39:38 ID:???
テキストファイルでひらいてんだろfopenの引数にbいれろ
25nobodyさん:2008/04/11(金) 22:24:57 ID:???
>>20
bindec() decbin() は基数変換用の関数だ。
バイナリ弄りたかったら ord() chr() や pack() unpack() を使っとけ。
あと確認用にバイナリエディタも用意しとけよ。
26nobodyさん:2008/04/12(土) 02:42:06 ID:???
fscanfはタブ区切りならちゃんと動くのに
カンマ区切りだと妙な挙動になるのはバグですね
27nobodyさん:2008/04/12(土) 03:16:30 ID:???
fscanfがおかしいです
28 ◆IiyUHoZM0E :2008/04/12(土) 05:53:41 ID:7Xlwa8pI
質問です。
LAMP環境で勉強しながらBBSを作っています。
$hoge = mysql_query("SELECT * FROM tbl");
みたいな文を書いたとき、$hogeの中に入るのはresourceという
ものらしいのですが、このresourceというものがどんなものなのか、
いまいちイメージがつかめません。
どなたか解説していただけないでしょうか?

もしこの質問がデータベース行きの質問だったら、スレ違いすみません。
29nobodyさん:2008/04/12(土) 06:22:25 ID:???
ざっくり言うと、まだphpで読めないデータの固まりみたいな感じかな
30nobodyさん:2008/04/12(土) 09:17:11 ID:???
ただのIDじゃねえの?
31nobodyさん:2008/04/12(土) 13:21:32 ID:???
arr
32nobodyさん:2008/04/12(土) 14:40:23 ID:???
>>28
実際にはリソースIDがはいってるが、概念的にはDBからの結果が入ってるって事じゃないの
33nobodyさん:2008/04/12(土) 14:44:24 ID:???
mysql_queryの返り値に結果なんて入ってねぇよw
34nobodyさん:2008/04/12(土) 14:50:46 ID:???
fopenの$fpのようなもの
35nobodyさん:2008/04/12(土) 15:17:48 ID:???
返り値じゃなく戻り値に統一してください。マニュアルも書き直してください。
36nobodyさん:2008/04/12(土) 15:26:42 ID:???
返り血はいかんよ
37nobodyさん:2008/04/12(土) 15:52:39 ID:???
モド・リッチ
38nobodyさん:2008/04/12(土) 16:04:06 ID:???
>>33
だから概念だと言っているんだけど。
違うなら違うでいいけど、俺の理解を書いただけ。
39nobodyさん:2008/04/12(土) 16:08:49 ID:???
概念でも違うわボケw
40nobodyさん:2008/04/12(土) 16:19:05 ID:???
そうか、ありがとう勉強になった
41nobodyさん:2008/04/12(土) 16:22:01 ID:???
リソースを参照するためのIDが返ってくる、が正解。
42nobodyさん:2008/04/12(土) 16:23:20 ID:???
俺の概念ではPHPはプチエッチなピクチャーです。
違うなら違うで良いけど、俺の理解はそうなんです。
43nobodyさん:2008/04/12(土) 16:28:06 ID:???
>>32>>41の違いは用語だけのような気がするけど。
根本的にどこが間違っているの?
44nobodyさん:2008/04/12(土) 16:38:27 ID:???
     _n_n
    _/ィV"Vj
   /Oィ(゚Д)
  〈 <`ー"^"^i  だからカイマンだと言っているんだけど。
  rシ つ三づ
i\rシ ノ三ノ
ヾ__イ_)シ_)

4528 ◆IiyUHoZM0E :2008/04/12(土) 16:54:45 ID:???
28で質問したものです。
$hogeの中には実際のデータの塊とかが入るのではなくて、
mysql内のデータを参照するためのポインタのようなものが
入っている、という解釈でよろしいでしょうか?
46nobodyさん:2008/04/12(土) 16:55:26 ID:???
レンタルビデオ屋でカード式のとこがあるだろ、
カードを持ってレジのお姉さんに渡すとビデオ本体を奥からもってくるとこ、
つまり

ID    :カード 
リソース:ビデオ本体

に例えろ、IDそのものには何の価値もないのだ、
くれぐれもパッケージと中身の違いに騙されるな。
47nobodyさん:2008/04/12(土) 17:10:55 ID:???
キャバクラの店頭に飾ってる写真と同じか
48名無しさん@アイコンいっぱい。:2008/04/12(土) 19:26:42 ID:QH24pWr1
アフィリエイターはなぜ3ヶ月でやめるのか?
http://kakitarou.com/url/files/accel.html
49nobodyさん:2008/04/12(土) 19:31:23 ID:???
>>45
そう
50nobodyさん:2008/04/12(土) 19:46:20 ID:???
>>48
書き方がいつも同じでワロタ

一ページで構成、文章長い。
途中に体験談が出てきて、
最後に、金額。
51nobodyさん:2008/04/12(土) 20:00:26 ID:???
でいつまでも値下げ
52nobodyさん:2008/04/12(土) 20:57:30 ID:???
SQL書くのマンドクセからフレームワークの使い方覚えたけど
結局複雑なリレーションはSQL書かないといけないのね、イヤン!
53nobodyさん:2008/04/12(土) 20:59:17 ID:???
SQLのほうが楽でいいじゃん
54nobodyさん:2008/04/12(土) 21:10:36 ID:pm7T1kPT
PHPでSQL文意識せずにクエリ作れるライブラリってどんなのがあるの?
55nobodyさん:2008/04/12(土) 21:17:35 ID:???
意識しろ
56nobodyさん:2008/04/12(土) 21:49:43 ID:???
感じろよ
57nobodyさん:2008/04/12(土) 22:07:14 ID:???
getdate()['year']って書けないのは何の嫌がらせなの?
58nobodyさん:2008/04/12(土) 22:10:44 ID:???
まぁ確かにPHPらしくないわな
59nobodyさん:2008/04/12(土) 22:12:18 ID:???
'functionHoge'()
これもだよな
6054:2008/04/12(土) 22:22:06 ID:pm7T1kPT
悪かった、SQL文をただ意識するだけなら構わない。
だが生のSQL文を弄れてしまうとSQLインジェクションの知識が必須になってしまうから
そこをライブラリ側で隠蔽化してやってくれるもので、なるべく独立したライブラリってないの?
61nobodyさん:2008/04/12(土) 22:29:36 ID:???
>>60
つプレースホルダ
62nobodyさん:2008/04/12(土) 23:11:19 ID:???
>>61
lol
6354:2008/04/12(土) 23:31:51 ID:pm7T1kPT
>>61
あ、なるほと、プレースホルダって何なのか今理解した。
PDOってのを使ってprepareではユーザ入力値を入れないようにすれば良いわけか。
何かこれ常識なことを質問してしまったみたいだな。皆ごめん、どうもありがとう。
64nobodyさん:2008/04/12(土) 23:36:36 ID:???
てかSQLインジェクションの知識もなしでよくシステム作る気になれるね。
損害賠償くらわないようにね。
65nobodyさん:2008/04/12(土) 23:55:06 ID:???
損害賠償については皆が皆仕事のWebプログラム書いてるわけじゃないし。
末端プログラマが皆セキュリティ技術者では居られないし。
公表されたセキュリティ問題に低リスク/コストで対応するためにライブラリを使うんだし。
66nobodyさん:2008/04/13(日) 00:12:05 ID:???
末端でもSQLインジェクションは解ってないといけないと思います。webプログラム書くなら。
個人的にはむしろ、入門書でも最初に教えるぐらいしないと。と、思う。
67nobodyさん:2008/04/13(日) 00:22:36 ID:???
SQLインジェクション知らない

ライブラリ使って楽しよう

とかいろんな意味で終わってる(笑)
68nobodyさん:2008/04/13(日) 01:26:09 ID:???
なんか意図せず極論になってしまってる気がするので物申したいんだけど、
SQLインジェクションにおいて新しい攻撃法が今後発見されることは100%ないの?
セキュリティ技術者ってのは最新の攻撃を常に把握してるよね、それが仕事だもん。
でもプログラムを書いたらその後運営には携わらない末端プログラマは居るでしょ。
そしてそのプログラマは当時のSQLインジェクションの知識で自前でサニタイズしていたら。
つまり「解っている」というのが、その時点についてのみではダメってことでしょ。

これを名の知れたライブラリと一般化したサニタイズ手法を使って文書として残しておけば、
保守として全てを理解していなければならないプログラマは不要であり、
かつ必要な最低限のセキュリティのチェックは可能になるでしょ。

俺はWebの仕事はやったことないからズレてること言ってるのかも知れないけど、
殆どの仕事はASP的な形態で同じプログラマがずっと関われるようなものなの?
69nobodyさん:2008/04/13(日) 03:26:06 ID:???
実用上はライブラリ通せば無問題だが、
概念上それくらい常識として知っておけ、
ってことじゃねーの?
70nobodyさん:2008/04/13(日) 03:34:36 ID:???
>>68
現実にそれが可能ならセキュリティ技術者なんて要らんわな

夢から覚めなさい
71nobodyさん:2008/04/13(日) 03:54:16 ID:bEpE13Rl
アップロードして保存されたファイルのその保存日を判別する方法ありますか?
ただし、画像ファイル名に保存日を書き込めないとします(20080413.jpgなどはダメ)
phpの関数でそんなのあるんでしょうか?
一定期間が過ぎたら削除する処理に利用したいと思っています
72nobodyさん:2008/04/13(日) 04:24:29 ID:hN58mjIP
毎朝6時以降、最初のアクセスでデータを更新するプログラムを作っています。
(クーロンを使えというのはなしで)
前回のデータ取得はキャッシュされていて更新時間は変数として使えます。

現在の日付時間、デーの更新時間、毎朝6時

これらをどう組み合わせて計算すればいいでしょうか?頭がこんがらがってしまいました(?_?)
よろしくお願いします。
73nobodyさん:2008/04/13(日) 05:23:53 ID:???
filemtime


if(date(更新時間-6時間)<date(今-6時間)){
74nobodyさん:2008/04/13(日) 05:27:15 ID:???
×date
○mktime
orz
75nobodyさん:2008/04/13(日) 05:37:33 ID:???
"6時間"じゃなくね?

>>72
宿題か?
デーの更新時間に日付が入ってないなら無理だ
頑張れ
76nobodyさん:2008/04/13(日) 05:51:50 ID:hN58mjIP
デーの更新時間はタイムスタンプなので日付に変換できます^^;

6時間じゃなくて朝6時です

6時以降の最初のアクセスをトリガーとして作動させたいのです

77nobodyさん:2008/04/13(日) 06:49:43 ID:???
if(更新日時 < 前日朝6時 or 更新時 < 朝6時 and 現在時 >= 朝6時) 更新;
78nobodyさん:2008/04/13(日) 07:50:58 ID:???
意外と難しいなw

>>77
これだと前々日の場合が駄目じゃね
毎日アクセスがあるとは限らない場合を想定すれば
79nobodyさん:2008/04/13(日) 08:06:52 ID:???
更新日時 < 前日朝6時 の所が2日前や1週間前もカバーしてるような?
入ってるデータが全部タイムスタンプなら>>77でよさそうだけど、寝起きだから自信ないな
80nobodyさん:2008/04/13(日) 08:54:53 ID:y9NKt7wS
PHPでサーバ上のセッションを全て廃棄する方法はありませんか?
(現在のセッションの、全てのセッションデータの廃棄ではありません)

マニュアルを見た感じではみつかりません。
http://jp2.php.net/manual/ja/ref.session.php

具体的には、PHPのプログラムを更新する場合に、その前からのセッションが生きてるのは、嫌だなぁって事なんですが。

PHPは5.2 使ってます。
81nobodyさん:2008/04/13(日) 09:16:12 ID:???
>>80
session.nameを変えるとか。
session.save_pathを変えるとか。

82nobodyさん:2008/04/13(日) 09:25:53 ID:y9NKt7wS
>>81
なるほど。
session.nameはPHP_INI_ALLだから session_startより前で設定すればできそうですね。

ありがとうございました。
83nobodyさん:2008/04/13(日) 09:52:09 ID:/FusEZA8
毎時間処理させるにはどうすればいいですか?
84nobodyさん:2008/04/13(日) 09:53:02 ID:???
>>83
cron
85nobodyさん:2008/04/13(日) 10:05:23 ID:???
>>83
手動
8683:2008/04/13(日) 10:09:53 ID:/FusEZA8
>>84-85
ありがとうございます。

cronについて調べてみましたが、いまいち使用方法がわかりません。
簡単なサンプルを示していただけませんか?
(1時間ごとにtest.PHPを呼び出す例など)

使用しているサーバはoroti.comのw8サーバです。
http://www.abcoroti.com/~rent/rspace/server.html
87nobodyさん:2008/04/13(日) 10:41:22 ID:???
>>83
右手
88nobodyさん:2008/04/13(日) 10:43:16 ID:???
>>86
読んでないけど、クーロソが使えると言うならば、鯖屋の指示通りに
設定すればいいだけ

(本来は鯖の設定ファイルを書き換えるようなのだから、それなりの権限がなければできない)

使えなければ、前に出てたアクセスをトリガー
(アクセスがあったら、それを契機に)スクリプトで処理するという方法で解決
89nobodyさん:2008/04/13(日) 10:43:55 ID:???
>_
90nobodyさん:2008/04/13(日) 10:46:12 ID:???
>>86
どの程度まで調べたの?
91nobodyさん:2008/04/13(日) 12:13:21 ID:???
サウンドハウス事件は何故おきたのか検証してみないか?
92nobodyさん:2008/04/13(日) 12:57:13 ID:???
今日からPHP始める。






でっていうwww
9383:2008/04/13(日) 13:02:10 ID:/FusEZA8
>>87-91
ありがとうございます。

質問板にてcronに関するスレを発見しました。
質問者:cronは使えまか?
管理人:cronつかえますよ。

cronに関するスレはこれだけで、鮎の方にも設定方法が紹介されていませんでした。
この場合どうすればいいでしょうか?
htaccessみたいなかんじで毎時間処理するよう記述したファイルをUP
するんですか?
94nobodyさん:2008/04/13(日) 13:14:28 ID:???
simplexmlって名前空間つきの要素へのアクセスはどうすればいいの?
xpath使えって話?
95nobodyさん:2008/04/13(日) 13:22:57 ID:/XYVoWCv
PHPにて、
PEAR::Image_Graph(オープンソース)を使用して
円グラフを作成しています。
マーカー部分に、"項目名 XX%"の用に表示させたいと思っています。
項目名を表示する方法をわかる方がいれば教えてもらえないでしょうか?

PHPとは少し違いますがお願いします。
96nobodyさん:2008/04/13(日) 13:28:26 ID:???
最近Image_Graphの質問が立て続けに出てるが同一人物か?
いい加減PEARはスレ違いだっつうの
97nobodyさん:2008/04/13(日) 13:37:47 ID:???
時間処理の質問見てて思いついたのだが、
任意の引数でタイムスタンプ作成する、dateの逆関数みたいなものって無いものかね
mktimeより楽に使えると思うのだがどうか。

$timestamp=inv_date('08年04月13日13時40分','y年m月d日H時i分');
みたいな
98nobodyさん:2008/04/13(日) 13:41:24 ID:???
当然あるわボケ
99nobodyさん:2008/04/13(日) 13:48:35 ID:???
>>91
HACKER SAFE使ってたって書いてあるけど、
ああいう外部からのチェックサービスって
結局CGIプログラムのソースコードは見ないんだろうから、
その中にある脆弱性には甘いんだと思うよ。
色んなサービスを動かすサーバ建てて、
その中に脆弱性のあるバージョンや機能が無いか調べるには良いと思うけど。
100nobodyさん:2008/04/13(日) 14:55:35 ID:/XYVoWCv
>>96
すみませんでした。
101nobodyさん:2008/04/13(日) 16:58:04 ID:mSGmcBg3
質問です。
たとえば、数十個のディレクトリ名を定数として利用する場合、配列でなくdefineでも問題ないと思いますが、
状態遷移に必要な情報を管理する多次元の配列の定数が必要な場合、どのようにするのがベターなのでしょうか?
・グローバルなところに変数として置く(現在はこの考えを利用)
・オブジェクト定数で管理
・XML/YAMLなどでデータ分離
あたりが思いつくのですが、常套手段などがあったらご教授お願いします。
10272:2008/04/13(日) 17:59:49 ID:???
>>73-79
ありがとうございます
明日の6時になったら動作するか確認してみます
103nobodyさん:2008/04/13(日) 18:29:39 ID:cn35Eo4d
20で質問した者です。

ord()とchr()を使用することでバイナリの扱いを解決することができました。
答えてくださった方々、ありがとうございます。

もうひとつ質問なのですが、phpの配列の要素数に上限はあるのでしょうか?

要素数が100000くらいのときはプログラムが正常に動くのですが、
要素数が1000000くらいになると途中でプログラムが止まってしまいます。

どなたかご存知であれば教えてください。
お願いします。
104nobodyさん:2008/04/13(日) 18:56:04 ID:cn35Eo4d
103です。
追記します。
このようなプログラムを組んでおり、
容量が1MBを超えるようなファイルだとプログラムが途中で止まります。

$fno = fopen("sample.mp3", 'rb');
while (!feof($fno)) {
$data[] = fread($fno, 1);
}
fclose($fno);
105nobodyさん:2008/04/13(日) 19:33:29 ID:???
>>104
[PHP] 配列に値を入れていくとエラーになりプログラムが落ちます。
http://q.hatena.ne.jp/1145420732
と同じ現象じゃないかな。
つまりPHPスクリプト一つに許可されている使用メモリ量をオーバーしているんだと思うよ。

デフォルトでは8MBか16MBに設定されているらしいのに、
たった1Mのファイルでオーバーしちゃうなんておかしいと思われるかも知れないけど、
PHPは配列の要素毎にも変数の型を持っているだろうから、余計にメモリを食っちゃうんだろうね。

単純に読み込んだデータにバイト単位でアクセスしたいのなら、
$data = fread($fno, filesize("sample.mp3"));
として一つの変数へ一気に読んじゃえば、配列と同じに$data[0]って感じで読めるんじゃない?
上のは試してないから嘘かもしれないけど。
106nobodyさん:2008/04/13(日) 21:43:31 ID:RGnLfYK/
phpgroupwareを入れたら下記のエラーが出てしまいました

NOTE: You must have cookies enabled to use setup and header admin!*

ブラウザ側ではクッキーは有効にしてるんですが・・・・どうすればいいでしょう?
107nobodyさん:2008/04/14(月) 00:14:07 ID:???
このindex.cgiがエラーがでるんですが修正できますか?(属性755)
http://www.borujoa.org/upload/source/upload18138.zip
108nobodyさん:2008/04/14(月) 00:42:56 ID:???
そんな餌で(ry
109nobodyさん:2008/04/14(月) 00:46:10 ID:???
fscanfがおかしいですだって?
110nobodyさん:2008/04/14(月) 04:32:32 ID:???
>>98
教えてくれ
111nobodyさん:2008/04/14(月) 07:07:30 ID:???
112nobodyさん:2008/04/14(月) 11:41:38 ID:6hAyd3lA
浮動小数点を表示すると、元の数値によって指数形式になったり
ならなかったりします。どういうルールで変換されているんでしょうか。

php -n -r "print(floatval(1100000));" → 1100000 が表示される。
php -n -r "print(floatval(1200000));" → 1.2E+6 が表示される。
php -n -r "print(floatval(1300000));" → 1300000 が表示される。
php -n -r "print(floatval(1300000));" → 1.4E+6 が表示される。
php -n -r "print(floatval(1500000));" → 1500000 が表示される。

環境は以下の通りです。

$ php --version
PHP 5.2.5 (cli) (built: Mar 3 2008 14:30:26)
Copyright (c) 1997-2007 The PHP Group
Zend Engine v2.2.0, Copyright (c) 1998-2007 Zend Technologies
with eAccelerator v0.9.5.2, Copyright (c) 2004-2006 eAccelerator, by eAccelerator
with Xdebug v2.0.2, Copyright (c) 2002-2007, by Derick Rethans

OS:Windows XP SP2
113nobodyさん:2008/04/14(月) 14:26:42 ID:???
すごくくだらない質問ですが、教えて下さい。
PHP5に元から入っているSQLiteのバージョンは2ですよね?
これを、バージョン3にしたいのですがインストールがいまいち分かりません。
環境は、WinXP Apache2 PHP5 です。

DB板に書くべきか悩みましたが、
PHP関係なのでこちらに書きました。
114nobodyさん:2008/04/14(月) 14:39:54 ID:???
SQLite3はPDOでされます。
115nobodyさん:2008/04/14(月) 15:31:07 ID:???
>>114
日本語でおk
116nobodyさん:2008/04/14(月) 17:23:23 ID:???
えすきゅうらいとさんはぴーでぃーおでされます。
117nobodyさん:2008/04/14(月) 18:17:04 ID:???
質問です。

PHPを記述しているページのアドレスをhttp://○○.phpではなく
http://○○.htmlまたは.php以外のモノにしたいのですが
やりかたが分かりません。

PHPを使っていると思われるサイトでも
アドレスが、http://○○.htmlとなっているのを見かけるのですが
どうやっているのでしょうか?

知っている方がいましたら教えてください。

118nobodyさん:2008/04/14(月) 18:24:35 ID:???
>>117
htaccessのAdd-Type
119nobodyさん:2008/04/14(月) 18:47:51 ID:???
htaccessでリネーム?するんですね。
検索してやり方を調べてみます。ありがとうございました。
120nobodyさん:2008/04/14(月) 19:11:38 ID:???
リネームじゃない
Apacheに拡張子htmlをPHPとして動かすように指示するだけ
Add-Type application/x-httpd-php .html
とかにすれば拡張子htmlのものがApacheでPHPとして扱われる
まぁこれ以上は板違いなんで
.htaccessについて深く知りたければWeb制作板へどうぞ
121nobodyさん:2008/04/14(月) 19:42:46 ID:???
その昔、
拡張子phpを使いたいという理由だけでPHPを始めた俺が来ましたよ
(突っ込みは無用)

アドレスが*.phpなのがオサレなんだと思ってた時期もありました
122nobodyさん:2008/04/15(火) 00:26:29 ID:???
>>112
それってPHPじゃなくてもなるんじゃなかったっけ。
CPUに詳しい人に聞いた方が良いと思う。
123すのっぶ:2008/04/15(火) 02:01:01 ID:LJ3oHWbN
php限定という訳じゃなくてすいません。
md5だと32桁の16進数値になりますが、大文字小文字を区別した表示でもっと短いhashはどのようなものがありますか?
ある携帯サイトで送られてくるメールのURLにそれらしきものがあり、「RJgYbxmTqnN5」という表記でした。
124nobodyさん:2008/04/15(火) 02:04:11 ID:???
125nobodyさん:2008/04/15(火) 02:12:30 ID:???
それはbase64では
126nobodyさん:2008/04/15(火) 02:38:46 ID:???
crypt
127nobodyさん:2008/04/15(火) 07:42:07 ID:LJ3oHWbN
http://jp.php.net/crypt
crypt だった。サンクス > 126

ちょっと古いサーバで試したんだけど、salt を指定しない場合、「$1$Qgv55ZYN$likCiswhSgaLSaWdJeObY.
」とかで、しかも毎回内容が変わってた。これはこれで役にたつものなの?どうやってパスワードチェックするんだろう。

ちなみにそのサーバの定数値は以下
CRYPT_SALT_LENGTH 12
CRYPT_STD_DES 1
CRYPT_EXT_DES 0
CRYPT_MD5 1
CRYPT_BLOWFISH 0

OS REDHAT 9
128nobodyさん:2008/04/15(火) 09:26:21 ID:???
指定されないソルトは乱数で生成されるから、それは正しい。

パスワードのチェックの時は、ソルトを読み取ってから
入力されたパスワードのハッシュを計算する

つ man 3 crypt
129nobodyさん:2008/04/15(火) 14:10:49 ID:???
ログ解析ソフトってあるじゃないですか。
あれの滞在時間とか、直帰率とか、再訪とか、
ああいうのの開発手法について、概要でも良いので
説明しているサイトをご存じないですか?
ググっても、ASPとかWeb屋とかが出てくるばかりで・・・・
130nobodyさん:2008/04/15(火) 14:31:23 ID:???
>>129
だいたいどういうことすればできるかイメージつくだろ。
クッキー、セッション、リファラーetc
それすらイメージできないうちは作れるレベルにないということ。
131nobodyさん:2008/04/15(火) 14:43:24 ID:tEWEzoyO
http://jp.php.net/manual/ja/book.imap.php
imapでpop3サーバーにつないで、読んだメッセージをDBにしまい
ごにょごにょしようかと思ってるのですが、
メッセージを既読にするにはどうしたらよいのでしょうか?

imap_setflag_full()
はimapでつないだ時だけ見たいだし、
imap_body()
に「既読フラグをたてないオプション」みたいのがあるので、読めば自動的に立つのかと思ったけど
だめっぽいです。

立てられないと、毎回すごい数のメールを見に行かなきゃならないのでちょっと現実的じゃないかなと。

わかりましたらお願いします。
132nobodyさん:2008/04/15(火) 14:47:25 ID:???
>>130
ログは取ってるんですよ。
IPアドレスとかUAとか、アクセス時刻とか。
それらをどういうふうにデータとして加工・保存していけばいいかのヒントになるようなものがあればということです

書き方が悪かったですね。スマソ
133nobodyさん:2008/04/15(火) 15:31:02 ID:???
藻前の望みをリストアップして1時間眺めれば判る。
134nobodyさん:2008/04/15(火) 15:43:29 ID:6h+mXfU6
うんかー02(urlつきだと書き込めないので省略)っていう2ちゃんねるビューワー機能のサイトがあるんだけど、
人大杉の板を.dat直読みさせることで、表示を可能にしてるらしい
.datがどこにあるか教えてください

例えば、ここのスレ http://pc11.2ch.net/test/read.cgi/php/1207863515/ の.datってどこでしょうか
135nobodyさん:2008/04/15(火) 15:49:37 ID:???
アクセス毎に10MBぐらいのファイルの読み書きするのって負荷かかりますか?

あまり詳しくないのですがDB使う場合とファイルをそのまま読み書きするのでは
やっぱ違いますか
136nobodyさん:2008/04/15(火) 16:02:39 ID:???
>アクセス毎に10MBぐらいのファイルの読み書きするのって負荷かかりますか?
なんでこんな糞システムになるのか理解できないが改善できるなら改善してくれ
じゃないと色んなところに迷惑がかかる
アクセス数が1日数件なら問題ないけど

>DB使う場合とファイルをそのまま読み書きするのではやっぱ違いますか
違う
扱うデータ件数が多ければ多いほどDBのほうが有利
137nobodyさん:2008/04/15(火) 16:19:15 ID:???
10MBぐらいのファイルじゃわからんな。
10MBのログに吐き出すだけならデータベースよりも軽石。
138135:2008/04/15(火) 16:28:06 ID:???
レスどうもです
ちょっと説明不足でした
プログラムファイルが10MBというわけではなく読み書きするデータファイルが10MBあるということです
最初は0でだんだんたまっていくという仕組みです

cgiで動かしていたのですが10MBぐらいで鯖の限界がきました
なのでPHPで作り直そうと思い、どのやり方が負荷が少ないかということで聞いてみました

やはりDBの方がいいのでしょうか



139nobodyさん:2008/04/15(火) 16:51:25 ID:???
鯖の限界っていうのがどういうことかわからないけど
おそらく使用可能なメモリが足りてないんでしょ?
だとするとcgiがだめでphpなら平気そうとかそういうレベルじゃないような気がする
特にPHPやPerlでWebプログラム組んでる人は特段意識しないだろうけど
扱うファイルが膨大となるとメモリ管理を効率よくおこなうプログラムを意識しないとだめだと思う
全てを配列に読み込むとかしただけでも相当メモリ使用量が増えるから

というわけでどういうものなのか想像できないのでなんともいえないけど
プログラム側の設計とファイルの扱い方についてを根本的に変えないといけないと思う
140nobodyさん:2008/04/15(火) 17:09:48 ID:???
このindex.cgiがエラーがでるんですが修正できますか?(属性755)
http://www.filebank.co.jp/wblink/b326ee425cd825e972e0e8c931e33383
141nobodyさん:2008/04/15(火) 17:24:26 ID:???
>>138
別にログにレコード追記するだけなら別に10Mが100Mでも遅くならんだろう。

ただまぁ、段々増えると言っている割りに、読み書きと言っているし、
なんとなく、file()とかで読み込んで...とか考えてそうだから素直にDBを使った方がいいね。
違ったらごめんよ
142nobodyさん:2008/04/15(火) 17:41:39 ID:???
アクセスログか何か?
配列に読み込んで追加して・・・とかやってるんなら追記モードでオープンすれば問題ないでしょ。
とりあえずもっと詳細な情報がないと何とも言えない。
>>136
データ件数が少なくてもリレーションや制約,データ構造のためにDB使う意味はあるよ。
143nobodyさん:2008/04/15(火) 19:53:03 ID:???
$binstr = "0x71,0x8E,0x01,0x00,0x00,0x00,0x00,・・・";
こんなデータの並びをバイナリにして、ブラウザからダウンロードさせたいと考えて
いるのですが上手くいきません。どなたアドバイスして頂けないでしょうか?

以下失敗例です・・・
$binarr = split(",", $binstr);
$bin = "";
for ($i=0; $i<count($binarr); $i++) {
$bin.= pack("c", $binarr[$i]);
}
header("Content-Type:application/octet-stream");
echo $bin;
exit();
144nobodyさん:2008/04/15(火) 20:12:25 ID:???
自己解決しました・・・
$bin.= pack("c", $binarr[$i]);

$bin.= pack("c", hexdec($binarr[$i]));

ん〜しかしpackの説明のとこで0xXXって感じで渡してるのに
なぜこれで上手くいったのかいまいち納得できず・・・
145nobodyさん:2008/04/15(火) 20:38:20 ID:???
HTTP_RequestでsetBasicAuth使わない場合は、
getResponseBodyでちゃんと返ってくるんだけど、
setBasicAuth使う&setMethod(HTTP_REQUEST_METHOD_POST)
すると
getResponseBodyしても何も文字列が返らない。

バグか何か?
どなたかご存じないですか?
146145:2008/04/15(火) 20:39:06 ID:???
ちなみに
setMethod(HTTP_REQUEST_METHOD_GET)
なら問題ありませんでした。
147nobodyさん:2008/04/15(火) 21:11:59 ID:???
変数に入ってる文字列を数式として評価できるのってevalだけですか?
$a="1+2";
とかがあったら3にしたいだけなんですが
148nobodyさん:2008/04/15(火) 22:05:32 ID:???
ども。
GDのimagecreatefromjpegを使っているのですが、
画像がでかいと死にます。
普通に死んでくれると問題ないんですが、
エラーメッセージも、返り血もなく、いきなり実行が中断されるので、エラートラップもしけません。
問題を回避する方法知ってる人いませんか?
149nobodyさん:2008/04/15(火) 23:57:17 ID:???
エログ見てみ。
150nobodyさん:2008/04/16(水) 00:16:21 ID:???
いつも見てますよエロゲ
151nobodyさん:2008/04/16(水) 08:11:13 ID:1M88tLAK
JpGraphで画像を出力したのですがどういうわけか携帯では見れません
もちろん画像形式はgifにしました
PCでは当然見れますし保存すると拡張子もgifです

考えられるのはキャッシュ化したファイルにはpngとなっているのですが
ダウンロードしてみると中身はちゃんとgifです。

どうすればいいでしょうか

152nobodyさん:2008/04/16(水) 09:39:16 ID:???
>>148
メモリーが足りてないんだろう。
memory_limitの値とかチェック。
あと、imagecreatefromjpegの前にファイルサイズとかチェックしろ。
153151:2008/04/16(水) 10:28:41 ID:???
自己解決しますた
154nobodyさん:2008/04/16(水) 11:27:50 ID:DHAOt7zZ
Dynamic EXtensionってなんですか?
これの設定がよくわかりません。
postgresqlやいろいろ入れていった場合
追加していけばいいのでしょうか?
155nobodyさん:2008/04/16(水) 12:19:19 ID:xAJOe1B+
関数の中でcookieを使うにはどうしたらいいのでしょうか?
下記のようにしているのですが、クッキーが有効となりません。

function cookieTest(){
if($_COOKIE["test"]<>"on"){
クッキーがない場合の処理
}
setcookie("test","on",time()+30);
}
156nobodyさん:2008/04/16(水) 13:05:55 ID:???
引数で渡す
157nobodyさん:2008/04/16(水) 13:12:39 ID:KGnhrG4i
.htmlの拡張子をphpファイルとして実行したいのですが、

.htaccessの

AddType application/x-httpd-php .htm .html

以外のやり方で、デフォルトで.htmlをphpファイルとして実行する方法はないでしょうか?
よろしくお願いします。
158nobodyさん:2008/04/16(水) 13:16:48 ID:???
httpd.conf(笑
159nobodyさん:2008/04/16(水) 13:17:54 ID:???
.htaccessも弄れないようなところで拡張子を誤魔化したいってのに不正のにほいがぷんぷんする。
160nobodyさん:2008/04/16(水) 13:46:10 ID:???
>>157
そんなにいやならフレームでも使ってろ
見た目はhtmlだろ
161157:2008/04/16(水) 13:56:24 ID:KGnhrG4i
>>160
いえ、ローカルのテストサーバ―として利用しているので、嫌とかではないんですが
毎回ディレクトリごとに.htaccessを設置するよりも、デフォルトで設定しておきたいのです。

AddType application/x-httpd-php .htm .html

これをhttpd.confに記述すればいいんでしょうか?
162nobodyさん:2008/04/16(水) 14:05:29 ID:???
>>161
>ディレクトリごとに
ルートに1つ置いとけばいいだろ

>これをhttpd.confに記述すればいいんでしょうか?
YES

まぁスレ違いもいいところだぜ・・・
163nobodyさん:2008/04/16(水) 14:06:46 ID:???
テストとして使ってるだけなら拡張子にこだわってるのはおかしいだろ。
164131:2008/04/16(水) 14:11:58 ID:QC7Y4msP
imap_setflag_full()
でフラグは立っていたみたいです。

imap_headerinfo()
で見ると、実際変わっていました。

しかし、imap_checkで変えるrecentの数や、
imap_searchでの検索でも、フラグが立っているとみなされません。

\\Flaggedをたてて、 UNFLAGGEDなんかでimap_searchしてみても
全権引っかかってしまいます。

From "hoge@hogehoge"
なんかで検索すると、うまく見つられてるようです。

常に1000件くらいメールがあるので、全部に対して処理をすると、読みこんで
メール解析したオブジェクト組み立てるだけで15秒〜30秒かかります。
DBに登録して・・・と考えると、ぜひ、新しいメールだけに処理をしたいのですが
なにか方法ありますでしょうか?

お願いいたします。
165nobodyさん:2008/04/16(水) 14:32:44 ID:KGnhrG4i
>>162
ありがとうございました
166nobodyさん:2008/04/16(水) 14:36:42 ID:pyqKRshm
>>155
$_COOKIEはグローバル変数だよ?
167nobodyさん:2008/04/16(水) 14:41:52 ID:pyqKRshm
>>155
あーわかった。それはクッキーに値が入ってない。
CやperlとかでCGI経験がないと、httpプロトコルが分らないから
クッキーはヘッダーで渡されているというのが分らないんだよね。

つまり、本文(html)を出力した後にクッキーは送出できないんだけど、
ここを理解しないと、今後同じデバッグに苦しむことになるよ。

解決策は、本文の前にsetcookieを呼ぶこと。
実装上のコツはノウハウだから、ケースバイケースでアドバイスが変わるよ。
168nobodyさん:2008/04/16(水) 14:51:35 ID:???
配列の最後の値をとりたいのですがそんな関数ありますでしょうか?
配列にいくつ値があるかはそのつど変わります。

以下のようにはできるのですが、もっと簡単な方法がありましたらよろしくお願いいたします。
$data = array('hoge','foo','fuga'...'bumobumo');
$str = $data[count($data)-1];
169nobodyさん:2008/04/16(水) 15:02:38 ID:???
>>168
ぱっと思い出せないけど、あるよ。
170nobodyさん:2008/04/16(水) 15:06:13 ID:???
>>168
$data[-1] を思い出してしまったたけど、end() があるよ。
171nobodyさん:2008/04/16(水) 17:08:09 ID:???
どなたかコレの使い方を教えていただけませんか?

AutoIndex PHP Script
ttp://www.moongift.jp/2007/05/autoindex_php_script/

どこで聞けばよいのか迷ったのですが、phpですのでこちらに書き込ませていただきました。
疑問点はこれを使う場合のディリクトリ構成です。
(AutoIndexフォルダ内に一覧表示したいものを入れるのか、その逆か)
また、必要があれば設定ファイルの変更箇所や、パーミッションの設定、アクセス制限の方法等も教えてください。

宜しくお願いします。
172171:2008/04/16(水) 17:24:04 ID:???
自己解決しました
173nobodyさん:2008/04/16(水) 17:30:39 ID:???
XML関係の関数について詳しく書かれた本/サイトを教えてください。
174nobodyさん:2008/04/16(水) 17:36:18 ID:???
>>171
ここで訊けばよいです。
ttp://autoindex.sourceforge.net/forum/
175nobodyさん:2008/04/16(水) 17:45:21 ID:???
176nobodyさん:2008/04/16(水) 19:01:43 ID:???
177173:2008/04/16(水) 19:16:54 ID:???
>>175
マニュアル見ても訳が分からない・・・
178nobodyさん:2008/04/16(水) 19:30:51 ID:???
>>177
関数についてそこ以上に詳しく書かれたサイトは無いぞ.
メニューを上げれば他の関連モジュールもあるが。
http://jp.php.net/manual/ja/refs.xml.php
179nobodyさん:2008/04/16(水) 19:35:05 ID:???
>>172で171を名乗っているのは別人です。
なので、完全には自己解決していませんが、>>174さんに教えていただいたフォーラムなどを参考に
ある程度進むことが出来ました。
一覧表示したいものがあるフォルダに、AutoIndexの内容物(index.phpなど)を入れたところ一覧表示されたのですが、
ユーザー名とパスワードによるアクセス規制がいまいちよく分りません。

初回動作で表示される設定画面で、「use_login_system」を「TRUE」にしたところまでは良いのですが、
どうやらそれに関係なく、誰でもファイルにアクセス出来る状態になってしまいます。
ユーザー名とパスワードを設定する.htpasswd.autoindexへの記述も、デフォルトで暗号化されているため
どうやってIDとパスを生成するのかもわかりません。
どなたかご教授願います。
180154です。:2008/04/16(水) 19:35:21 ID:DHAOt7zZ
だれか154の質問に答えてください。
よろしくお願いします
181171:2008/04/16(水) 19:51:41 ID:???
>>179
なんで私を名乗るんですか?
自己解決済みです。お騒がせしました。
182nobodyさん:2008/04/16(水) 20:04:44 ID:???
>>154
本当にDynamicに(実行時に)エクステンションをロードする必要があれば(って言うかその必要がある場面がわからんぞ)
dl関数使ってロードできる(けど使ったことない)。
実行時にロードする必要が無ければ
使いたいエクステンションを所定のフォルダに置いて
php.iniをいぢればOK(これは普通のやり方)
183nobodyさん:2008/04/16(水) 21:09:13 ID:???
>>147
substrを駆使すれば可能です
184nobodyさん:2008/04/16(水) 22:33:34 ID:???
>>168
array_pop

>>154
dllの事だろ
extension=php_pgsql.dll
こんな感じでiniに追記
詳しい事は環境がわからないと何とも言えない
185nobodyさん:2008/04/16(水) 22:38:20 ID:JLMZOI/r
PHPがオブジェクト指向になってから全然わかんないです。

関数メインで作っていたのを、今後の為に抽象化レイヤーに
書き換えようと思ってググリました。

$pdo = new PDO('hoge','huga','honya');な場合において
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$pdo->setAttribute(ATTR_ERRMODE,ERRMODE_EXCEPTION);
という表記を見たのですが、これは同じと考えて良いんでしょうか。

::hogeは静的メソッドなので、PDOのオブジェクトのインスタンスである$pdoの中では
多分PDO::を省いても良いって事なんだろうなぁと思うんですが
書き方の習慣として、どちらの書き方が推奨されますでしょうか。
186nobodyさん:2008/04/16(水) 22:46:10 ID:???
>>185
違う
PDO::ATTR_ERRMODE
これはクラス定数
ATTR_ERRMODE
これだと定数を参照する事になる
187nobodyさん:2008/04/16(水) 22:48:55 ID:???
>>185
あ、因みにクラスメソッド内での参照の仕方は
self::ATTR_ERRMODE
って感じになる
詳しくはここらあたりかな・・・
http://jp.php.net/manual/ja/language.oop5.constants.php
188nobodyさん:2008/04/16(水) 23:05:09 ID:???
>>185
おいおいおい・・・なぜ憶測でコードを書こうとする。他言語でOOPの経験があるわけでもないようだし。
ちゃんとマニュアルに書いてあることだから言語仕様で疑問に思うことがあったらこんなとこで聞く前に即参照しなされ。
189nobodyさん:2008/04/16(水) 23:19:55 ID:???
>>186-187
理解できました。
ありがとうございます。

グローバル定数のPDO_ATTR_ERRMODEが5.1まで使用されていたけれど
今後はどんどんPHPを拡張していくから、グローバル定数増やすの嫌だから
PDO::ATTR_ERRMODEの様にクラスで定義されてる定数で呼び出してくれって事ですね。
190nobodyさん:2008/04/16(水) 23:25:36 ID:???
>>188
php.netのクラスの部分は読んだんですけど
他言語でOOPの経験っていうか、特にJAVAの経験がないから
クラスの部分の説明が全然わかんないんですよ。
聞いても良いじゃないですか。

勉強してるだけで別に壊れて危険な物は作ったり公開してる訳じゃないんで
かっかしないでくださいよ。
191nobodyさん:2008/04/17(木) 00:26:56 ID:???
かっかじゃないよ。呆れてるんだよ。
192nobodyさん:2008/04/17(木) 01:00:13 ID:???
>>190
だったらJavaやってこいよ
PHPがOOPに対応してるのはJavaからの移行者のため
PHPしかやらないような人間が無理してOOPする必要はない
PDOは確かに便利だが使い方わからないならネイティブ関数使うとか他に方法はある
そんなにクラスを理解したいなら先にJavaのサイトまわってこいよ
OOPのプログラム手法でわからないとこの質問ならまだしも
OOP教えてくれっていうのはお門違いだろ
手取り足取り教えてやる義理はない
193nobodyさん:2008/04/17(木) 02:10:19 ID:???
       .ni 7       .M
     l^l | | l ,/)     | i|                 _/\/\/\/\/\/\_
     ', U ! レ' /   / ̄ ̄ ヽ,              \                 /
     /    〈   /        ',        .n      < こっこしないでくださいよ >
          ヽっ{゚}  /¨`ヽ {゚},       l^l.| | /)   /                 \
       /´ ̄ ̄ .l   ヽ._.イl  ',      | U レ'//)  ̄|/\/\/\/\/\/\/\/ ̄
     /  ィ-r--ノ   ヘ_/ノ   ',    ノ    /
        ,/        |! |    ヽ rニ     |
       丿'        W     ヽ、  `ヽ   l
     . !/                  ヽ、 |   |
194nobodyさん:2008/04/17(木) 02:12:07 ID:???
おまえはOOP言いたいだけちゃうんかと
195nobodyさん:2008/04/17(木) 02:57:25 ID:???
196nobodyさん:2008/04/17(木) 08:49:20 ID:YHuC7Xot
質問なんですが
例えばショップサイトで商品のデータをDBに入れます

それを呼び出すときは **.php?category=01&data=0000
とかで呼び出すわけですよね

それでこの商品の数が膨大になったりアクセスが増えると負荷がかかると思うのですが
どのような対処方があるのでしょうか?

鯖の性能を上げるといっても何がどうなってるのか概念みたいなものがわかりません
おおまかでいいのでご教授ください
197nobodyさん:2008/04/17(木) 09:57:43 ID:???
加齢に擦るー
198nobodyさん:2008/04/17(木) 11:00:28 ID:M2mwea+h
PHPで書いたWebページからサーバー上のプロセスを起動したいが、
終了するのを待ちたくない場合はどうすりゃいい?

一応execでC++で書いたプログラム(仮にaiueoという名前にする)を起動し、
aiueoの中でfork(), exec()してみた.親プロセス(aiueo)のほうはwaitを
しないで終了すればokかなと思ったら、aiueoがゾンビになって
結局起動した子プロセスが終了しないとwebページを操作できない・・

こーいう場合どうしたらええのん?
199nobodyさん:2008/04/17(木) 11:11:15 ID:???
>>196
俺の経験則。反論もあるだろうし、信じなくて良い。

まずJOINを一つも無くす。その状態で並び替え条件にインデックスを張る。
そして一つのテーブルをシーケンシャルに検索する。

これはパフォーマンスをあげるための方法、
普通の設計ではJOINを無くすなんてことはしない。
むしろ逆。正規化をする。

検索条件にインデックスをはっても良い。
検索条件にインデックスをはることで遅くなることもある。注意。
like検索する所ははっても無意味。

10万件ぐらいならば、それが一番速い。
200nobodyさん:2008/04/17(木) 11:53:39 ID:???
場合によって「あえて正規化しない」ってのはアリだと思うけど
ドラゴンボール板向けのネタだよなとも思う。
201nobodyさん:2008/04/17(木) 13:43:22 ID:M2mwea+h
>>198
解決.親プロセスと子プロセスの両方で、fclose(stdout)が必要だった.

おさわがせしました
202nobodyさん:2008/04/17(木) 15:08:09 ID:yQIY/Upa
もし、そういった設計をされてる方がいらっしゃいましたら聞きたいのですが、
DBにバイナリ(画像等)を登録するメリットを教えてください。
203nobodyさん:2008/04/17(木) 15:29:12 ID:K4JzsNpf
フレームワークで入門用のものでおすすめありませんか?
シンプルなものからはじめてコード読んで勉強したいと思ってます
204nobodyさん:2008/04/17(木) 15:34:59 ID:???
すいません。くだらない質問ですが教えて下さい。

いま、無料の掲示板(PHP)を使おうと思っているのですが
googleを入れたく思っています。

表示エリアには
// 表示
echo " <tr><th colspan=¥"2¥" $_class><p class=¥"header_menu¥">$res$edit$del</p>$title</th></tr>¥n";
echo " <tr>¥n";
echo " <td class=¥"t_row1¥">$name<br /><br />$id</td>¥n";

とあり、$IDの後に入れたいと思っています。

入れるgoogleは

<script type="text/javascript"><!--google_ad_client = "pub-11111111111";/* 125x125, 作成済み 08/04/16 */google_ad_slot = "11111111111";google_ad_width = 125;google_ad_height = 125;//-->
</script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script>

となっております。

その場合どのよう入れれば表示しますでしょうか?
上の行で$で指定する文章を入れるのが良いのでしょうか?

恐れ入りますが、ご教授下さい。
205nobodyさん:2008/04/17(木) 16:00:22 ID:???
>>204
//表示 の直後に下記の5行
$google = <<<OMAEHAKUDARAN
<script type="text/javascript"><!--google_ad_client = "pub-11111111111";/* 125x125, 作成済み 08/04/16 */google_ad_slot = "11111111111";google_ad_width = 125;google_ad_height = 125;//-->
</script><script type="text/javascript"src="(p)http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script>
OMAEHAKUDARAN;

であとはecho文の入れたいところに$googleを入れる。たとえば
echo " <td class=¥"t_row1¥">$name<br /><br />$id $google</td>¥n";
206nobodyさん:2008/04/17(木) 16:01:34 ID:???
あ、わりぃ。 rep2でリンクに付く(p)までコピーしてもた。
そこは無視でよろ。
207nobodyさん:2008/04/17(木) 16:09:21 ID:???
ちょっと酷いよ。
<<<OMAEHAKUDARAN
208204:2008/04/17(木) 16:12:04 ID:???
やっぱりうそですよね・・・。T_T
209nobodyさん:2008/04/17(木) 16:14:58 ID:???
いや、あってることはあってるよw

ヒアドキュメントをより先にまず "は\でエスケープすること学ぼう
210204:2008/04/17(木) 16:35:24 ID:???
やっぱり出来ない。現状

$google = <<<GOOGLE
<script type=¥"text/javascript¥"><!--google_ad_client =¥"pub-1111111111¥";/* 125x125, 作成済み 08/04/16 */google_ad_slot =¥"pub-1111111111¥";google_ad_width = 125;google_ad_height = 125;//-->
</script><script type=¥"text/javascript¥"src=¥"http://pagead2.googlesyndication.com/pagead/show_ads.js¥">
</script>
GOOGLE;


として入れてるんですが、HTMLはき出した後ソースを見ると円マークが残ったままになっています。本来HTMLにはき出した後のソースは消えていますよね・・・。

やはり初心者にはむりですかね・・・・。
211nobodyさん:2008/04/17(木) 16:44:41 ID:???
>>210
>205で言われた通りにやろうよ。
ヒアドキュメントに¥でエスケープは要らない
212204:2008/04/17(木) 16:51:44 ID:???
すいません。
ありがとうございます。
ヒアドキュメントという言葉を知らず、見落としました。

現状何となくエリアが出たのですが、表示はしていませんが
何となく出そうな感じまで行きました。


ちょっこり、色々いじってみます。ありがとうございました。
213nobodyさん:2008/04/17(木) 17:03:04 ID:???
ひゃあドキュメントってなんかエッチな感じがするな。なぜだろう?ひゃあ!
214nobodyさん:2008/04/17(木) 17:50:59 ID:???
またオマエか
215nobodyさん:2008/04/17(木) 18:01:14 ID:???
春は新しい出会いにときめく学生さんがここに遊びに来てるんだからオマエとかいわず温かい目でみてやれよ
216nobodyさん:2008/04/17(木) 19:02:05 ID:???
>>212
初心者か否かは関係ない。
真剣やる気があるかどうか、人の話を聞けるかどうかが問題。
217nobodyさん:2008/04/17(木) 19:12:00 ID:???
>>216
そんなくだらんレスするくらいなら、>>202>>203にでもレスしろよ。
218nobodyさん:2008/04/17(木) 19:14:45 ID:???
>>217
そんなくだらんレスするくらいなら、>>202>>203にでもレスしろよ。
219217:2008/04/17(木) 19:23:39 ID:yQIY/Upa
>>202
やったこと無い。
>>203
ちいたんじゃダメか?w
220nobodyさん:2008/04/17(木) 19:45:53 ID:???
すいません、教えてください。
Apache2.63にPHP5.25をインストールしました。
PHPファイルをモジュールで動かしてたのですが、勉強のため一部のファイルのみCGIとして動かしたいんです。

動かしたいファイルのソースはこれです。これを実行させるとechoで出力はできるのですが、#!C:/php5/php-cgi -qが文字列として表示されてしまいます
ということはCGIとして動いてないからなんでしょうか・・・?
#!C:/php5/php-cgi -q
<?php
echo 1111111;
?>
221nobodyさん:2008/04/17(木) 20:19:24 ID:???
CGIとして動かすためにしたことは?
222nobodyさん:2008/04/17(木) 20:30:25 ID:???
>>221さんありがとうございます
一行目に#!〜おまじないをいれてみましたができません

httpd.confにcgiとして設定しないとできないのでしょうか?
223nobodyさん:2008/04/17(木) 20:46:52 ID:???
httpd.confをCGIが動くように設定したのか?してなかったら恥
224nobodyさん:2008/04/17(木) 21:23:22 ID:???
てかid出せボケ
225nobodyさん:2008/04/17(木) 21:31:27 ID:???
>>224
氏ね答えられない低脳
226nobodyさん:2008/04/17(木) 21:34:40 ID:???
このスレはこの程度か!
どうもありがとうございました
227nobodyさん:2008/04/17(木) 21:35:07 ID:???
いえいえおよび出ないですよ
228nobodyさん:2008/04/17(木) 21:39:06 ID:???
>>225-227
無職乙
229nobodyさん:2008/04/17(木) 21:40:04 ID:???
>>228
ニート乙
230nobodyさん:2008/04/17(木) 21:40:35 ID:???
マジきめええwwww
答えられないならでてこなくていいからw
231nobodyさん:2008/04/17(木) 22:08:12 ID:???
つうかもういい加減id出してない質問にレスするのやめようぜ
232nobodyさん:2008/04/17(木) 22:12:02 ID:???
仕切り厨でましたね
233nobodyさん:2008/04/17(木) 22:46:48 ID:???
仕切り厨でもなんでもいいがルールぐらい守れミジンコ共が
234nobodyさん:2008/04/17(木) 22:47:05 ID:???
粘着妖精さんもスルー
235nobodyさん:2008/04/17(木) 22:56:16 ID:???
>>220=225=226=230=232=234
http://pc11.2ch.net/test/read.cgi/php/1158647441/
ほれこっち池
236nobodyさん:2008/04/17(木) 22:57:36 ID:???
phpで、携帯のサイトを作っているのですが、
セッション管理が必要なサイトで、
セッションIDの情報をURLに埋め込んでいます。

ただ、ユーザーの中にセッションIDが入ったURLをブックマークとして
公開する人がいて、セッションハイジャックが毎日行われています。

これって、仕様として客に説明しているのですが、
客が納得してくれず、携帯であるが故に技術的に不可能なことを説明しているのですが堂々巡りです。

こういう場合、どのような資料を提示して納得してもらえるのでしょうか?
宜しくお願いします。
237236 :2008/04/17(木) 22:58:55 ID:8cCEOmJ0
すみません、下げていました。
238nobodyさん:2008/04/17(木) 23:00:47 ID:???
有効期間つければ?
239nobodyさん:2008/04/17(木) 23:02:20 ID:???
>>236
仕様って!!www
そんなサイトでセッションIDを生で埋め込むなよ
240236 :2008/04/17(木) 23:08:32 ID:8cCEOmJ0
>>238
アドバイスありがとうございます。
有効期間はつけているのですが、
短いと、すぐにセッションが切れると苦情が来るし、
長いと、2chやブログでURLが貼られた場合に、セッションハイジャックが多発してしまします。
結局、有効期間ですと根本的には解決されないのではというのが結論です。

>>239
いや、携帯のサイトですから・・・
241nobodyさん:2008/04/17(木) 23:13:21 ID:???
>>240
IPの範囲みたりとかしたら?
あとauはクッキー使えるし
242nobodyさん:2008/04/18(金) 00:07:02 ID:???
IPアドレスや個体識別番号を持たせておけばいいだけじゃないの?
243nobodyさん:2008/04/18(金) 00:09:22 ID:???
URL埋め込みのSIDだけで何とかしようと思うほうがどうかしてる
244nobodyさん:2008/04/18(金) 00:30:00 ID:???
んむ クッキーがどうとか全く関係ないな
セッションハイジャックの対策をしていない事が問題なだけ
245nobodyさん:2008/04/18(金) 00:33:53 ID:???
「セッションハイジャックが毎日行われています。」

「fscanfがおかしいです。」も好きだけど、これも気に入った。
246nobodyさん:2008/04/18(金) 00:40:53 ID:???
無知なクライアントでよかったねぇ
うちの下請けが「これが仕様です」なんて言ってきたら二度と仕事回さないぞ
247nobodyさん:2008/04/18(金) 00:52:58 ID:???
>>240
> いや、携帯のサイトですから・・・
携帯サイトやからセッションIDを生で埋め込まへんねんて
248nobodyさん:2008/04/18(金) 01:40:20 ID:???
mixiとか大手はどうしてんだろ?
249nobodyさん:2008/04/18(金) 01:46:33 ID:???
uidじゃね?
250nobodyさん:2008/04/18(金) 06:04:41 ID:???
if (!isset($a))
$a = "hoge";

isset($a) ? $a : "hoge"
をもっと簡潔に(短く)書く方法はありますか?
251nobodyさん:2008/04/18(金) 06:40:54 ID:???
あるけどそんな微々たるところの効率なんか工夫しようとすんな
252nobodyさん:2008/04/18(金) 13:48:09 ID:VW/Du+vX
掲示板つくってます。
【日付,名前,本文,削除pass,IP】とデータをログファイルに残してます。
出力はこのログを頭から順にだしてます。

ここから返信機能つき掲示板に組み替えたいのですが、
ログファイルにどのようにデータを残し、
どのように出力するように動作させたらよろしいのでしょうか?
流れだけでもどうかご教授お願いいたします。

253nobodyさん:2008/04/18(金) 14:03:31 ID:???
>>252
とりあえず全てのスレッドにユニークなIDをつける。

新しいテーブル(データベースの場合)、またはファイルを作成。

【ユニークID,本文】でデータを取る。

ユニークIDが新テーブルと一緒の物だけを表示。

(例) データベース使ってる場合のsql
>>252の作ってるテーブルのユニークID(55)を一覧する場合
select * from new_table where ユニークID = 55

こんな感じでいいのかな?
254nobodyさん:2008/04/18(金) 14:04:08 ID:???
まずデータにIDが必要
255nobodyさん:2008/04/18(金) 14:14:18 ID:VW/Du+vX
ありがとうございます、勉強になりました。
さっそく取り掛かります。
ありがとうございました。
256nobodyさん:2008/04/18(金) 14:48:16 ID:???
正規表現にマッチした数を返してほしいのですがそんな関数はあるでしょうか?
以下だったら3を返してほしいです。
$preg = "12HOGE.;asd123HOGE.;52HOGE";
/(\d+)HOGE/
257nobodyさん:2008/04/18(金) 14:52:05 ID:???
>>256
そのものずばりではないが
preg_match_all
258nobodyさん:2008/04/18(金) 14:54:12 ID:???
返して欲しいんだからズバリなんじゃないの
259nobodyさん:2008/04/18(金) 16:06:53 ID:???
>>257
なんでも正規表現で答えれば間違いないと思っている馬鹿って何なの?
それしか解決方法を知らないの?
260nobodyさん:2008/04/18(金) 16:07:57 ID:???
正規表現嫌なら煽ってないでお前が答えてやれよ
261nobodyさん:2008/04/18(金) 16:21:37 ID:???
ずばりそのものだろ?
262256:2008/04/18(金) 16:36:42 ID:???
自己解決しますた
ほんと使えねえカスばっかだな
263nobodyさん:2008/04/18(金) 16:53:22 ID:???
fscanfがおかしいです
264nobodyさん:2008/04/18(金) 16:54:10 ID:???
>>256

preg_match_all
返り値
パターンがマッチした総数を返します(ゼロとなる可能性もあります)。 または、エラーが発生した場合に FALSE を返します。

これより楽な方法はないよね
265nobodyさん:2008/04/18(金) 16:57:20 ID:???
>>262
またオマエか
266nobodyさん:2008/04/18(金) 17:07:53 ID:???
ID出さないやつにご丁寧に答えて議論してやってるお前らが微笑ましい
267nobodyさん:2008/04/18(金) 17:48:00 ID:???
ID出す出さないに関係なく自分の糧になるのなら質問も回答もするのが俺様のセオリー
268nobodyさん:2008/04/18(金) 18:10:03 ID:???
右乳首が痛いのですがどうすれば治りますか?
バージョンアップするしかないのでしょうか?
269nobodyさん:2008/04/18(金) 18:10:22 ID:???
preg_match_allの第三引数で
変数にマッチした値を格納できますが、
$matched[0]にあたる値はいらないので変数に格納しないでほしいのです。

$matched[1]とかは(?:)でできるのは知っています。
$matched[0]はどのようにすればいいのでしょうか?


$str = "1234abs=2;1234abs=7;432abt=3;";
preg_match_all("/[\d]+abs/",$str,$matched);
270nobodyさん:2008/04/18(金) 18:10:35 ID:???
正規表現がダメな理由は、その処理速度の遅さ。
forループ文の中に、正規表現で処理するロジックが入っていたら、それこそ最悪。
また、正規表現の処理のために仮想メモリーを浪費するため、異常なメモリーの食い方をする。

現実的に出来るかどうかを検証せずに、出来る出来ると主張しているところが青臭さを感じるといっただけ。
271nobodyさん:2008/04/18(金) 18:20:24 ID:???
正規表現は神
272nobodyさん:2008/04/18(金) 19:09:30 ID:???
否定するのは誰でもできます
解決方法をかけない奴はいくら言ってもダメ
273nobodyさん:2008/04/18(金) 19:32:15 ID:???
特にお前とかな
274nobodyさん:2008/04/18(金) 19:40:42 ID:???
>>270
現実的に出来るかどうかを検証してから、

ダメと主張してくださいねw
275nobodyさん:2008/04/18(金) 19:44:40 ID:???
方法を提供もしないでこれはダメあれはダメなんて幼稚すぎる
276nobodyさん:2008/04/18(金) 20:22:29 ID:???
>>270
そりゃ組み方が下手なだけだろ
277nobodyさん:2008/04/18(金) 20:27:33 ID:???
その遅い正規表現は何秒かかるの?
それが問題になる処理じゃなければ使ってもいいだろ。
遅いってんならPHP使わないでCで組めや
278nobodyさん:2008/04/18(金) 20:38:41 ID:???
>>270さん正規表現に変わる手法を教えてください
279nobodyさん:2008/04/18(金) 20:54:41 ID:???
代案も出さずに批判するとは民主党もびっくりだわw
280nobodyさん:2008/04/18(金) 21:33:57 ID:???
ここまで技術的な考察まで書いてやっているのに、
人に代替案まで求めるって、どこまでスィーツ脳なんだ?

技術者としての素質もなければプライドもないのかね?
281nobodyさん:2008/04/18(金) 21:34:58 ID:???
スイーツ脳なんて特徴的な言葉使うのお前だけ
よく常駐して煽ってるいつもの馬鹿か
282nobodyさん:2008/04/18(金) 21:36:11 ID:???
>>281
おまえもな
283nobodyさん:2008/04/18(金) 21:36:48 ID:???
>ここまで技術的な考察まで書いてやっているのに

ぷっ

284nobodyさん:2008/04/18(金) 21:38:57 ID:???
技術的(笑)
考察(笑)
285nobodyさん:2008/04/18(金) 21:47:56 ID:???
(笑) (笑)
286nobodyさん:2008/04/18(金) 21:57:15 ID:???
()笑
287nobodyさん:2008/04/18(金) 21:58:07 ID:???
代替案が欲しいわけじゃないんだわ

お前さんが本当に代替案を考えられる技術があるのか
その方法が標準の正規表現関数と比べてどの程度早くなるのか
それが知りたいだけ
288nobodyさん:2008/04/18(金) 22:03:28 ID:???
真性キティにマジレスカコワルイ
289nobodyさん:2008/04/18(金) 22:32:13 ID:???
口だけだったみたいだからあんまりいじめないであげよ
290nobodyさん:2008/04/18(金) 23:54:36 ID:???
>>289
他人のふりせずに素直にやめてくださいって言えよw
291nobodyさん:2008/04/19(土) 00:43:26 ID:???
実力がある人って批判だけするとこみたことないねえ
かならず何らかの提案をもってきてくれる
292nobodyさん:2008/04/19(土) 01:14:59 ID:???
批判だけする人って
勘違い君が多い
293269 :2008/04/19(土) 01:26:36 ID:???
お願いします
294nobodyさん:2008/04/19(土) 01:36:11 ID:???
だから、必死になって代替案出せって何よ?
本当は知りたいくせに、煽っているってるって、
好きなくせに女の髪の毛引っ張って気を引こうとしている中年男と一緒だろw
295nobodyさん:2008/04/19(土) 02:01:36 ID:???
池沼うざい
296nobodyさん:2008/04/19(土) 02:08:33 ID:???
本当に知りたいと思ってる人はいないよ。
PCREのパターン展開エンジンを*PHPで*自前実装したい人だけが
高度な技術的考察をしとけばいい。

/^\d+$/ → ctype_digit()
/^Mozilla/ → strpos(), strstr()
>>256のお題がこんな話に見える素質がなくてよかった。
297nobodyさん:2008/04/19(土) 02:27:54 ID:???
>>293
>>11をちゃんと読んでから出直してこい
298nobodyさん:2008/04/19(土) 02:50:25 ID:???
>>294
いや、批判するなら最初からレスしなくていいと思ってる
299nobodyさん:2008/04/19(土) 06:08:17 ID:???
>いや、批判するなら最初からレスしなくていいと思ってる

馴れ合いキモ
300nobodyさん:2008/04/19(土) 06:14:31 ID:???
>>293
第4にPREG_OFFSET_CAPTURE入れて
0をunsetしれ
301nobodyさん:2008/04/19(土) 10:19:29 ID:???
>>296
CTYPEはそれとイコールじゃないよ。
俺も昔つっかかった
302nobodyさん:2008/04/19(土) 12:03:10 ID:???

【迷言ランキング】
 1 : fscanfがおかしいです
 2 : ここまで技術的な考察まで書いてやっているのに

トップ揺るがず。


303nobodyさん:2008/04/19(土) 12:44:33 ID:???
質問です。
<?php
$word = $_POST['text'];
$pointer=fopen("./log.dat", "a");
flock($pointer, LOCK_EX);
fputs($pointer, $word);
flock($pointer, LOCK_UN);
fclose($pointer);
?>
<form action="パス" method="post">
<input type="text name="text" size="30">
<input type="submit" value="送信">
</form>

こんな感じのを応用して簡単な掲示板を作ろうと思うのですが、
更新すると何個も同じものを送信してしまいます。
どうすればよろしいのでしょうか?
304nobodyさん:2008/04/19(土) 13:05:00 ID:???
>>303
同じものであるか判定する処理

真だったら拒否,偽だったら書き込み
305nobodyさん:2008/04/19(土) 13:10:36 ID:???
306nobodyさん:2008/04/19(土) 13:41:34 ID:???
PDO+SQLite使えば楽なの何故いまだファイル使うかなぁ
307303:2008/04/19(土) 14:27:57 ID:EugqgBl5
>>304 その処理が分からないです…
>>306 サーバーがSQLite対応してないです
308nobodyさん:2008/04/19(土) 14:56:51 ID:???
>>303
更新すると同じものを送信するのはブラウザ側の問題なので、サーバで二重投稿かデータチェックする。

ケース1)
ログファイルの最後に書き込まれたデータと比較して、同じならアウトにする。

ケース2)
フォームにセッションを使ってユニークIDをhiddenに埋め込む。
サーバにhiddenで送られてきたユニークIDを見て、セッションと同じ値でなければアウトにする。
309nobodyさん:2008/04/19(土) 15:46:00 ID:nFas9Qcl
?

てst
310nobodyさん:2008/04/19(土) 15:49:34 ID:nFas9Qcl
マックからフォームで〜を入力すると?(←2chではwinだとハテナに見えるかもしれません)となってしまいます。
これをログに記録すると、文字化けしてしまいます。

マックからの「〜」を文字化けしないでログに書き込むにはどのような方法がありますでしょうか?

311nobodyさん:2008/04/19(土) 16:06:28 ID:???
文字コード統一汁(機種依存は論外)
312nobodyさん:2008/04/19(土) 16:06:31 ID:???
>>310
外部、内部、それぞれの文字コードは何?
313nobodyさん:2008/04/19(土) 16:18:13 ID:nFas9Qcl
文字コードはUTF-8で全て統一しております。
ただ、どうしてもマックからフォームに〜を入力すると、以下のサイトにかいてあるような現象になります。
http://oshiete1.goo.ne.jp/qa1937623.html?ans_count_asc=20

う〜ん、いままでwinしか使ったこがなくて、マック環境が無いので不安なんですが、
マックの「〜」はwinでは機種依存文字扱いとされるのでしょうか?

314nobodyさん:2008/04/19(土) 16:26:34 ID:nFas9Qcl
自己解決しました。
ログを開くのに使用しているエディタの内部文字コードがsjisのために起こった現象です。
使用してたのはサクラエディタでえす。
お気に入りのエディタでしたが、この機会に別のエディタに乗り換えます。

引用:ttp://ja.forums.wordpress.org/topic.php?id=51
残念ながら、サクラエディタは、Shift_JIS なのに ISO-2022-JP と誤認した前科 (WPJ フォー
ラムのキャッシュ) があるので、今回は「紹介するべきではない」代物です。
単に「巨大なテキストを開けるエディター」として出すならいいんですが、
今回は文字コード変換に使うため、「文字コードを誤認するエディター」を選ぶのは、よろしくありません。
サクラエディタは内部文字コードが SJIS らしく、UTF-8 を扱うにはよいエディターとは
言えません (「波ダッシュ」が化けたりするらしい)。
そういう面ではマトモなのは EmEditor ぐらいしかなさそうです (TeraPad, K2Editor など、Windows のエディタの多くは内部コードが Shift_JIS)。

あと、質問者が Windows を使っているかどうか不明なので、「Windows ならば○○○」という限定を入れてほしかったです。Mac ユーザーだとすると「サクラエディタがおすすめ」と言われても困りますので。(Linux ユーザーは文字コード変換で悩むことはないでしょうが)
315nobodyさん:2008/04/19(土) 16:26:55 ID:???
痴漢すればいいじゃん
316nobodyさん:2008/04/19(土) 16:27:55 ID:???
       ヽ(・ω・)/   ズコー
      \(.\ ノ
317nobodyさん:2008/04/19(土) 16:38:11 ID:???
Emediterも半角英数字だけのファイルを保存すると
ShiftJISで保存する糞エディタだな
318nobodyさん:2008/04/19(土) 16:47:53 ID:???
terapad→サクラエディタと着たが俺も乗り換えるか・・・
319nobodyさん:2008/04/19(土) 17:37:31 ID:???
>>317
ちょwww笑わすなwwww
BOM無しUTF-8とEUCとSJISの文字コードを判別する方法思いついたら教えてくれwwww
エディタ作ってやんよwwwwww
320303:2008/04/19(土) 18:12:34 ID:EugqgBl5
連続投稿は防げましたがタグを使われるとおかしくなります。
htmlspecialcharsで無効化しようと思ったのですが、
<font color="#ff0000">が<font color=\"#ff0000\">となります
なせでしょうか?
321nobodyさん:2008/04/19(土) 18:23:23 ID:???
ポストされたデータをどっかでエスケープしてるんじゃないの?
覚えが無いならmagic_quotes_gpcを確認
322nobodyさん:2008/04/19(土) 20:00:37 ID:???
>>320
おまえはまず人からアドバイス受けたらありがとうの気持ちぐらいだせ
323中沢:2008/04/19(土) 20:02:45 ID:8RVDFTU7
こんにちは(^_^;)
ログファイルに保存された配列を元に検索機能を作りたいのですがどうすればよいのでしょうか?
詳しく書きますと
log.datに
155<>名前155<>年齢155<>
5<>名前5<>年齢5<>
4<>名前4<>年齢4<>
1<>名前1<>年齢1<>

とあったとします。
検索では、完全一致した場合に表示させる、id検索と、部分一致した場合に表示される、名前と年齢検索ができるとして、
id検索で1
と検索すれば、$ken件マッチしました。
id:$id
名前:$name
年齢:$age
と表示させ、見つからなかったらエラールーチンに飛ばさせます  
次に、名前検索で部分一致したら表示させる場合は、
「前1」
と検索したら、今回は2件マッチするので
$kenマッチしました

2件とものデータを表示させたいです
このような検索できるスクリプトを作りたいのですが、分かりません。よろしくお願い致しますm(_ _)m
324nobodyさん:2008/04/19(土) 20:08:05 ID:???
>>323
わからないならまだ作るのは早いってことです
ここは宿題お手伝いのお部屋ではありません
325nobodyさん:2008/04/19(土) 20:13:26 ID:+VgtfKgh
今、メモ帳でphpのプログラム書いてるんですが
専用のソフトとかってないですか?

プログラム書いてて関数とか変数が色ついたり
見やすくしてくれるヤツです。
326nobodyさん:2008/04/19(土) 20:16:07 ID:???
 はじめまして、よろしくお願いします。

 PHPでデリヘルによくあるような出勤表を作りたいと思っています。
女の子情報はMYSQLで管理しています。

 ■欲しい機能

・管理画面から出勤スケジュールを登録
・本日の出勤一覧ページ

いろいろ考えているのですが…

・女の子情報の登録時に『出勤フラグ』をラジオボタンで付けて
フラグがtrueのときに内容(時間)を表示 とか。
 →どうやってカレンダーと合わせる?


 詰まっています。
 ヒントでもいいのでお願いします。 
327nobodyさん:2008/04/19(土) 20:17:39 ID:???
>>325
phpエディタでもつかいなされ
メモ帳使いがいきなりIDEは厳しいとおもうけど
興味あるならEclipse PDTでも使ってみなされ
328nobodyさん:2008/04/19(土) 20:18:15 ID:???
>>326
329nobodyさん:2008/04/19(土) 20:21:42 ID:???
まず金払え。
330>>323中沢:2008/04/19(土) 20:24:08 ID:8RVDFTU7
array_serch
を使うのはわかるのですが、中に正規表現をいれたいのです。
どうすればよいのでしょうか?
331nobodyさん:2008/04/19(土) 20:27:43 ID:???
>>330
どうすればいいのですかではなく、自分で考えてコードを書け
332326:2008/04/19(土) 20:28:35 ID:???
ヒントだけでも。
333nobodyさん:2008/04/19(土) 20:30:02 ID:???
学歴だけでPGすっ飛ばしてSEになるとわからないよなw
334nobodyさん:2008/04/19(土) 20:30:44 ID:???
答:仕様書書いてPGに組ませる
335nobodyさん:2008/04/19(土) 20:32:04 ID:???
これでもPGより給料多いんだぜ?
336nobodyさん:2008/04/19(土) 20:38:59 ID:???
>>330
同じ苗字で恥かかすなや
337nobodyさん:2008/04/19(土) 20:44:33 ID:???
このスレはこの程度かよ
ksg
338nobodyさん:2008/04/19(土) 21:26:11 ID:???
>>337
またオマエか
339nobodyさん:2008/04/19(土) 21:42:16 ID:???
ループかよ
340中沢:2008/04/19(土) 22:25:14 ID:8RVDFTU7
誰か答えクレクレ(^^)/
お願いいたします
341nobodyさん:2008/04/19(土) 22:33:51 ID:???
342nobodyさん:2008/04/19(土) 22:35:04 ID:???
ああごめん、デリヘル依頼者とごっちゃになってたわ
343nobodyさん:2008/04/20(日) 04:40:12 ID:???
???

デリヘル依頼者と正規表現とどう関係があるの?
344nobodyさん:2008/04/20(日) 04:46:05 ID:???
両方とも珠玉の一品に出会えます
345nobodyさん:2008/04/20(日) 05:28:17 ID:???
>>344
よく分からない。珠玉の一品って、つまり締まりがいいマンコとかってこと?
346nobodyさん:2008/04/20(日) 07:20:37 ID:???
あとは、でかいチンコも。
347nobodyさん:2008/04/20(日) 15:51:29 ID:cb0wPZjr
配列$_POSTの中身の一つ一つにhtmlspecialchars($_POST, ENT_QUOTES, 'UTF-8')の様な処理をして
戻したいです。

arra_mapを使ったところ、第3引数のENT_QUOTESが配列では無いと怒られてしまいます。
$_POST = array_map('htmlspecialchars',$_POST, ENT_QUOTES, 'UTF-8');
どうしたら良いでしょうか。
348nobodyさん:2008/04/20(日) 16:19:18 ID:???
怒られないようにしたら?
349nobodyさん:2008/04/20(日) 16:52:53 ID:cb0wPZjr
>>348
ありがとうございます。
怒られないようにしたら出来ました。
350nobodyさん:2008/04/20(日) 16:53:26 ID:???
亜鈴魚喰
351Defort:2008/04/20(日) 17:11:16 ID:QNOTdt2p
フリーページ
http://tool-1.net/
について聞きたいのですが、index.cgiのスクリプトが丸見えみたいなのですが、どうやったらみれるのですか?
ヌルバイト攻撃使っているのですか?
352nobodyさん:2008/04/20(日) 17:31:23 ID:???
gethostbyaddr()
で得られるホスト名って信頼できる?

たとえば、gethostbyaddr($hoge)
で ***.yahoo.co.jp みたいなのが
でたら、 $hoge は yahoo関連のIPと断定できる?
yahooとは関係ない第三者のIPが ***.yahoo.co.jp みたいなホスト名を
返すことってありえませんか?
353352:2008/04/20(日) 17:33:32 ID:???
自己解決しました
354nobodyさん:2008/04/20(日) 17:57:34 ID:Tze2JaW2
セッションのGCの挙動を変えたくて、session_set_save_handlerを使って
gc_test()に置き換えようと思っています。
session_set_save_handler("", "", "", "", "", "gc_test");
session_set_save_handler(null, null, null, null, null, "gc_test");
と試してみましたが
Warning: session_set_save_handler() [function.session-set-save-handler]: Argument 1 is not a valid callback in xxx.php on line 3

というwarningが出て目的が達成できません。
openその他の関数をデフォルトのままにするにはどのようにすれば良いでしょうか?

355320:2008/04/20(日) 18:38:39 ID:???
>>321
ありがとうございました!
magic_quotes_gpcがずっとわからなかったのですが
.htaccessで設定できるのですね!
文字化けの心配がなくなりました。
356nobodyさん:2008/04/20(日) 19:26:38 ID:8958Dk4L
<form method="post" enctype="multipart/form-data" action="./uploader.php">
<input type="file" name="data" size="30">
<input type="submit" value="アップロード">
</form>
<?php
$filedir = "./file/";
$filename = $_FILES['data']['name'];
if(file_exists($_FILES['data']['tmp_name'])){
$filesize = filesize($_FILES['data']['tmp_name']);
if($filesize <= 1050000){
if(move_uploaded_file($_FILES['data']['tmp_name'],$filedir.$filename)){
echo "アップロードしたファイル・・・ファイル名:".$filename." ファイルサイズ:".$filesize."Byte";
echo "<br><br>";
}
}
else{
echo "ファイルサイズが大きすぎます!";
}
}
if($filename){
echo "<img src='./$filedir/$filename'>";
}
?>

このような感じでアップローダーを作ってるのですが、
ファイル名がそのまま保存されるのをfile0001みたいな感じで保存することはできますか?
357nobodyさん:2008/04/20(日) 19:33:38 ID:???
それ自分で書いたコード?
358nobodyさん:2008/04/20(日) 19:46:33 ID:???
自分で書いてたらはじめから連番を振る仕様になってそうだね。

まあ、どっかのサイトとか本が $filename = $_FILES['data']['name']; で説明してたのを
使い回してるのかもしれない。
359nobodyさん:2008/04/20(日) 19:47:01 ID:8958Dk4L
友達から教えてもらったです。
360nobodyさん:2008/04/20(日) 19:59:36 ID:???
きめぇw
361nobodyさん:2008/04/20(日) 20:00:21 ID:???
>>360
きめぇw
362nobodyさん:2008/04/20(日) 20:08:01 ID:???
ら、らめぇ
363nobodyさん:2008/04/20(日) 20:11:57 ID:???
じゃその友達に聞けばいいじゃん
364nobodyさん:2008/04/20(日) 20:51:05 ID:???
めでたしめでたし
365nobodyさん:2008/04/20(日) 21:28:40 ID:???
くだらない質問、お願いします。

OSはWinXP、webサーバはapacheです。
perl、phpは実行できる環境です。

ダウンローダーからのアクセスをhttpステータス403で
返したいです。その為、webサーバのログをcronで
調査し、ある条件(例えば1分間に60回アクセス)
に合致したホスト(IPアドレス)を.htaccessの
deny fromに追加したいです。
そのような、perl,PHPはあるでしょうか?
366nobodyさん:2008/04/20(日) 21:29:20 ID:PJ8uyzSs
age忘れました。

くだらない質問、お願いします。

OSはWinXP、webサーバはapacheです。
perl、phpは実行できる環境です。

ダウンローダーからのアクセスをhttpステータス403で
返したいです。その為、webサーバのログをcronで
調査し、ある条件(例えば1分間に60回アクセス)
に合致したホスト(IPアドレス)を.htaccessの
deny fromに追加したいです。
そのような、perl,PHPはあるでしょうか?
367nobodyさん:2008/04/20(日) 21:42:41 ID:???
WinXPでcron動いてるのか?
368nobodyさん:2008/04/20(日) 22:10:51 ID:PJ8uyzSs
>>367
pycron.exeってやつで、
unixのcron相当を動かしてます。
369nobodyさん:2008/04/20(日) 22:21:56 ID:???
cronって、結局時間で動かすだけのプログラムだろ、
本気でやるならJP1とか使えよ。

本気じゃねーのかよ。
370nobodyさん:2008/04/20(日) 23:16:26 ID:???
>>369
ここは下らねぇ回答者のスレではありません。
371nobodyさん:2008/04/20(日) 23:52:57 ID:???
>>370
異常系の処理も考慮しない馬鹿ですか?w
372nobodyさん:2008/04/21(月) 00:51:15 ID:???
パソコンの電源がつかないのですけどどうしたらいいですか?
373nobodyさん:2008/04/21(月) 00:55:33 ID:???
374366:2008/04/21(月) 07:24:16 ID:f7rHed3v
JP1とかはどうでもいいんで、
私の質問に対して、良い案は
ありますか?
お願いします。
375nobodyさん:2008/04/21(月) 07:37:38 ID:???
phpでいくらでも.htaccess編集したればいいじゃん
376nobodyさん:2008/04/21(月) 07:56:46 ID:???
なかったら作れよ

>>375
377nobodyさん:2008/04/21(月) 12:32:43 ID:8HZkrnGU
mail関数を連続で実行することで、
メールの遅延が発生したりするのでしょうか?

お問い合わせフォームを作った時、管理者・問い合わせ者・保存用と
3つの箇所に送信するのですが、たまにメールの受信が遅かったり
バラバラに受信したりします。
378nobodyさん:2008/04/21(月) 12:41:06 ID:???
>>377
だから、そういう時のためJP1を使ってジョブの異常系を制御しろよ。
379nobodyさん:2008/04/21(月) 12:50:44 ID:???
>>377
メールってそんなもんだろ
380377:2008/04/21(月) 13:08:39 ID:8HZkrnGU
>>378
「JP1」と言うのを検索しましたが、
メール処理とあまり関連しないような気が・・・。
>>379
「そんなもんだ」とは思っているのですが、
メールが届かない事による語弊もありますし、
プログラムに詳しくない人は「メールは必ず届くものだ」と
考えるので、お問い合わせフォームでそれが起きると不安がられます。
381nobodyさん:2008/04/21(月) 13:16:15 ID:???
「遅れることがあるよん」と謳っておけ

いつでもラグレスで届くシステム作ったらそれだけで億万長者になれるわw
382nobodyさん:2008/04/21(月) 13:20:19 ID:???
>>377
SMTPサーバのログとキューを確認したら?
きちんとmail関数で送信できる?
それとPOP/IMAPサーバの方もチェックした?


>>378
JP1は無関係だろ?
一応は送信できているんだからジョブは生きてるだろ
383nobodyさん:2008/04/21(月) 13:26:25 ID:???
週末から今日までのログを読んで笑わせてもらった。
ありがとう。
384377:2008/04/21(月) 13:36:11 ID:8HZkrnGU
>>381
それは注意事項に記載しているのですが、
いかんせん電話までしてくる人が多くて‥。

>>382
サーバの事は疎くてSMTPサーバのログとキューは確認してないです。
また、mail関数(厳密に言えばmb_send_mail関数)を使っていて
これまで問題なく送信、一括配信など行えていたのですが、
なぜか今作っているサイトでは遅延が発生します。

やっぱりサーバの問題もあるんですかね?
さくらインターネットのサーバなんですが。
385377:2008/04/21(月) 13:38:55 ID:???
少しググったのですが、もしかして
サーバのPHPが4.3.9なのが原因なのかも・・・。
386nobodyさん:2008/04/21(月) 13:48:07 ID:???
>>384
> これまで問題なく送信、一括配信など行えていたのですが、
> なぜか今作っているサイトでは遅延が発生します。

どちらも正常な動作ですよ。電話鳴らされるのはご愁傷様としか言えない。
メール配送の仕組みや MTA のご機嫌の問題を PHP で解決するのは大変そう。
387nobodyさん:2008/04/21(月) 13:53:45 ID:???
てか、メール遅延なんて、自分の鯖だけで解決する問題じゃないだろ
388nobodyさん:2008/04/21(月) 13:54:56 ID:???
その気持ちは分かるけど、俺も人を疑うことを止めて、
人を信じることから接してみたら?

俺もそうしたら、幸せなことが増えたと思う。
苦情をネガティブに考えないで、感謝する気持ちで捉えてみて。
389377:2008/04/21(月) 14:01:16 ID:???
>>386
やっぱり「普通のこと」なんですね。
さっきサーバに詳しい友人にも電話して聞いてみたのですが、
「メールの遅延や送られないことはある。でもPHPのバージョンを変えるとか
 サーバの設定を変えるとかそういう操作は時期早々。やらない方が良い」

と言われました。ですので、このまま静観します。
ご回答いただいた方、ありがとうございました。
390nobodyさん:2008/04/21(月) 14:01:53 ID:eazv5Nmh
error_reportingの設定って、みんなE_ALLとかE_STRICT使ってる?
391nobodyさん:2008/04/21(月) 14:05:44 ID:???
送信数が多いならキューを分割してプロセスをリッスンして心太方式にするのもいいカモメ
392nobodyさん:2008/04/21(月) 14:06:06 ID:???
>>389
プロなら、しょうがないで済まさないぞ。
メールが送信できないケースには様々な原因が考えられるが、
リターンメールが帰ってくるケースではそれに対処するプログラムを組む必要がある。
でないと、到達不能メールが無限ループを繰り返し、相手のサーバーは中継サーバーもダウンさせる。
そうなったら、威力業務妨害で捜査を受ける場合もあるし、賠償問題にも発展する。
かかる観点まで見通して実装するかどうかが、プロとアマの分水嶺だよ。
393nobodyさん:2008/04/21(月) 14:08:42 ID:???
>>384
ログ解析したら、だいたのボトルネックが分かるものだよ
394nobodyさん:2008/04/21(月) 14:18:19 ID:???
「問い合わせフォーム」にMAILER-DAEMONさんへ自動返信する機能を
実装するかどうかが分水嶺なのですね。わかります。
395377:2008/04/21(月) 14:19:08 ID:???
mb_send_mail関数を使ってもサーバのメールログに情報が残るんですか?
お恥ずかしながら、sendmail送信の場合、ログが残らないと思っていました・・。

と言うことは、そのログを閲覧できるレンタルサーバを借りなければ
いけないと言うことですよね?さくらじゃ無理そうだ・・・
396nobodyさん:2008/04/21(月) 14:22:38 ID:???
共有レンサバじゃ厳しいだろな
送信関連の規制にひっかかってるんじゃね?
スクリプトである程度調整できるかもしれないけど。
397377:2008/04/21(月) 14:25:00 ID:8HZkrnGU
>>396
1日10件もお問い合わせがないので、送信規制にかかってなさそうです。
アクセスも多くて500PVほどですし。

結構、簡単に考えていたのですが、色々と考えるべき事が多いのですね。。
398390:2008/04/21(月) 14:25:02 ID:eazv5Nmh
漏れの質問はスルーですか、そうですか。
399nobodyさん:2008/04/21(月) 14:27:24 ID:???
スパムメールサーバーとして、ルートサーバーに登録されてしまったら、
そこから送信されるメールは一切受け付けてくれなくなるよ。
インターネットで死亡宣告を受けるようなもの。

数件ならいいけど、数百件にもなったら危険水域。
400nobodyさん:2008/04/21(月) 14:30:40 ID:???
>>390
(PHP_OS != 'WINNT') ? error_reporting(0) : error_reporting(E_ALL);
401nobodyさん:2008/04/21(月) 15:55:39 ID:tP2T0+Jy
phpmyadminのようにサーバ上のSQLiteデータベースファイルをブラウザで
編集できるアプリってありますか?
402nobodyさん:2008/04/21(月) 16:13:15 ID:???
探したら、あった
http://phpsqliteadmin.sourceforge.net/
403nobodyさん:2008/04/21(月) 16:21:47 ID:tP2T0+Jy
>>402 ありがトン!早速試します。
404nobodyさん:2008/04/21(月) 16:46:56 ID:???
JP1JP1って日立の中の人なのか?
405390:2008/04/21(月) 16:47:11 ID:eazv5Nmh
>>400
サンクスコ
406366:2008/04/21(月) 16:53:15 ID:???
自分で作りました。
ありがとございました。
407nobodyさん:2008/04/21(月) 21:40:04 ID:???
粘着キティは通院日かな?
408nobodyさん:2008/04/21(月) 21:56:39 ID:???
このスレ、回答者が釣りなのかマジなのかわかんねぇ。
無限ループって何だよ。
Fromを入力可能にするとか?ありえないし。
メールヘッダーインジェクション可能だと、サーバー止められるかもだけど。

>>390
作る時はE_STRICTでやってる。

なんか、本番環境でdisplay_errorがonの所多過ぎない?
ちなみにdisplay_errorはini_setしてもあまり意味無い。
iniでdisplay_error offで、ini_setでonにすると、
パースエラーの時、ini_set自体が実行されないのでパースエラーが表示されない。
逆も然り。
まあ、逆の場合は本番環境でパースエラーは無いだろうから良いっちゃ良いけど、
精神衛生上良くない気がする。
409のし図:2008/04/21(月) 23:17:05 ID:YYj5TAUN
mkでこんなセキュホみつけたのですが、ここからindex.cgiのソースを見るにはどうすればよいのでしょうか?
http://mk-board.net/koukoku.pm
穴みたいです
セキュリティに詳しい方教えて下さい
410nobodyさん:2008/04/21(月) 23:22:27 ID:???
ここはperlじゃないよ。

cgiは関連付けされてるから見えないみたい!?
411のし図:2008/04/21(月) 23:28:53 ID:YYj5TAUN
>>410
何かと方法ってないのですか?
412nobodyさん:2008/04/22(火) 00:07:08 ID:???
ここはperlじゃないよ。
413nobodyさん:2008/04/22(火) 03:24:49 ID:???
そんな穴じゃ抜けない
414nobodyさん:2008/04/22(火) 11:42:41 ID:dlLjXVhc
phpのsymlinkってアトミックなんでしたっけ・・・?
DBがMysqlのmyisam使わなきゃで、行ロックの代わりをやる必要が・・。
415nobodyさん:2008/04/22(火) 11:49:33 ID:???
アトミックで鉄腕アトム的ってこと?
416nobodyさん:2008/04/22(火) 11:50:02 ID:???
>>415
ちょーーー受けるwwwww
417nobodyさん:2008/04/22(火) 11:50:32 ID:???
>>415
その発想はなかったわwwww
418nobodyさん:2008/04/22(火) 12:41:18 ID:???
このスレもこの程度か
相手になりませんでした
419nobodyさん:2008/04/22(火) 13:17:40 ID:???
クォリティ高須クリニック
420nobodyさん:2008/04/22(火) 14:11:59 ID:???
>>415-419
無職ニート池沼うざい
421nobodyさん:2008/04/22(火) 15:32:48 ID:???
mkboardの穴なつかしすぐるw
wwwlangとかあゆ板とかなゆ板にもあるんだよな
422nobodyさん:2008/04/22(火) 18:20:03 ID:???
mkタクシュリティ
423nobodyさん:2008/04/22(火) 21:57:48 ID:???
固定の拡張子を付けてテンポラリファイルを作りたいんですけど
何かいい手法はありますか?

tempnamでprefixじゃなくてsuffixの指定ができれば悩む必要なかったのだが
424nobodyさん:2008/04/22(火) 22:30:17 ID:???
>固定の拡張子を付けてテンポラリファイルを作りたい
何故に?
425nobodyさん:2008/04/22(火) 22:31:44 ID:FtmTZwRr
一意の名前ということなら
time() . '.tmp' じゃだめ?
426nobodyさん:2008/04/22(火) 22:39:33 ID:???
一時的なファイルではあるんですけど、セッションの途中でブラウザに渡す必要があったもので
コミットしちゃえば正式なファイル名を振るんでユニークなIDも付けるんですが

time() . ".tmp"だと1秒以内に同時に作成されたときに一意性が保証されないですよね
microtime()を使ってファイルを作ってみてダメならリトライを数回やるってのは
よほどのアクセスが無ければ大丈夫な気はしますが泥くさいかなあ
427nobodyさん:2008/04/22(火) 22:42:11 ID:???
uniqidは?
428nobodyさん:2008/04/22(火) 22:44:15 ID:???
あ、microtimeを使うならuniqidでも一緒でしたね
429nobodyさん:2008/04/22(火) 22:47:02 ID:???
uniqidでやってみます
ありがとうございました
430nobodyさん:2008/04/23(水) 02:18:22 ID:Wcjf8rbS
すみません、下記の2点がわからなくて困っています。
すみませんが対処法をお分かりになられる方がおられましたら教授よろしくお願いいたします。

1.PHPでフォルダ(中にフォルダ・ファイルが入っています)を削除(unlinkやrmdir)しようとrmdirコマンドを実行しましたが、「中にファイルなどが入っているので消せません」とエラーになりました。再帰的にファイルを削除するしか方法はないのでしょうか?
参考になる再帰的にファイル・フォルダを削除するロジックを
ご存じでしたらご教授よろしくお願いいたします。


2.同様に、フォルダ(中にフォルダ・ファイルが入っています)をコピーしようとcopyコマンドを実行したら「権限がありません」とエラーが表示されました。
当方の環境はlinux環境ではなくwindows環境ですので権限とか関係ないように考えていたのですが、
windows環境でもディレクトリに権限の設定が必要なのでしょうか?
(また、chmod関数で0777権限を設定しましたがコピーできませんでした・・・)

431nobodyさん:2008/04/23(水) 02:23:13 ID:???
>>430
1.いい経験になるから自分で考えられるところまで作ってみるべし
432nobodyさん:2008/04/23(水) 03:07:35 ID:???
>>430
そのあたりのファイル関数は単体に使うものなので再帰的に処理するのが普通
環境依存してもいいとかならsystem()で"rm -rf foo"等のCLIコマンドを叩く方法もあるけどオススメしない
opendir()とか使ってロジックを組んでみるといいよ
433nobodyさん:2008/04/23(水) 05:14:59 ID:???
>>430
既出だが、異常系の処理をしっかりと対応するなら、JP1とかがお勧め。

そういうのを最初から実装するのは手間とお金が掛かるし、
なんでもphpという一つの技術だけで解決しない方がいい。
434nobodyさん:2008/04/23(水) 05:26:30 ID:???
あらやだ。JP1君がいらしたわ。
435nobodyさん:2008/04/23(水) 05:51:15 ID:???
JP1に敵意むき出しの富士通社員がいるね。
436nobodyさん:2008/04/23(水) 06:25:52 ID:???
jp1にこだわりをみせるフリをした新米se君がいるスレですね
437nobodyさん:2008/04/23(水) 08:33:19 ID:???
日本一()笑言語w
438nobodyさん:2008/04/23(水) 09:06:47 ID:???
phpも極めてる人のソースはすごいけどね
439nobodyさん:2008/04/23(水) 10:30:51 ID:???
         __ ____
      //   ̄  \\    
     //--.--  -─\\    
   //  (● ●) ((●(●) \            地震とかどこの田舎だよ
 .| |.|    ( . ((_人_人__)    | _ _== =   
     \\    ⌒ ` /,/ | |    ̄ ̄ ̄  ̄| ||
    ノ         \\| | | |           ||
  /´                 | |          | |
 |    l                | |          |||
 ヽ    -一ー_~、⌒)^),-、   | |_________| |
  ヽ ____,ノγ⌒ヽ)ニニ- ̄   | |  | = =
440nobodyさん:2008/04/23(水) 19:54:20 ID:???
>>439の画像、より目にして、
黒の目玉を二つにすると、
なんと画像が立体に見えません。
441nobodyさん:2008/04/23(水) 23:30:52 ID:???
php5を使っていると、不定期に「Out of memory (Needed 2095360 bytes)」
のエラーが発生していて困っています。

具体的には、MYSQLに接続してmysql_queryを発行した後に結果セットが返却されません。
このエラーが発生した直後の接続は、半分程度の確率で以下のエラーが発生してDBへの接続エラーが発生します。
:mysql_connect() [<a href='function.mysql-connect'>function.mysql-connect</a>]: Lost connection to MySQL server at 'reading initial communication packet', system error: 0

対処方法がありましたら、教えて下さい。
宜しくお願いします。
442nobodyさん:2008/04/23(水) 23:31:14 ID:k1ODucws
441です。sageてました。
443nobodyさん:2008/04/23(水) 23:31:28 ID:???
メモリ食いすぎの部分を直す
444nobodyさん:2008/04/24(木) 00:22:52 ID:???
ファイルが存在する場合のみ処理を実行するため、
$fp = fopen("./$abc.txt", "r");
if($fp != null)
処理〜

というように組んでいるのですが、
この時、ファイルが存在しておらず、$fpの値がnullだった場合でもfcloseで閉じる必要はあるのでしょうか?
445nobodyさん:2008/04/24(木) 00:58:17 ID:???
>>444
fopenでファイルの存在確認するのはお行儀が悪いですね
446nobodyさん:2008/04/24(木) 00:59:05 ID:LaHdtlHM
>>439の画像、目玉をトリプルクリックするとなんと目からビームを発射しません。
447nobodyさん:2008/04/24(木) 00:59:25 ID:???
>>444
しかもfopenで失敗したのだからファイルは開けてないのに何故閉じる必要があるのだ
あけてないものを閉じる意味が理解不能
448nobodyさん:2008/04/24(木) 01:01:45 ID:???
> fopenでファイルの存在確認するのはお行儀が悪いですね
それは素人の意見ですね。

どうせfopenの前にfile_existsとかで調べろといっているのでしょうが、
file_existsとfopenの間にファイルが消されたらどうするんですか?
マルチタスクOSなのだからありえる話です。
449nobodyさん:2008/04/24(木) 01:01:47 ID:???
とりあえず・・・そんなあなたにfile_exist()
450nobodyさん:2008/04/24(木) 01:03:10 ID:???
書く前に否定された。
451nobodyさん:2008/04/24(木) 01:04:50 ID:???
file_exists(笑)
452nobodyさん:2008/04/24(木) 01:08:05 ID:???
なんで最後に「マルチタスクOSだから!OSがマルチタスクなんだから!」という
ネタを持って来るんだ。
453nobodyさん:2008/04/24(木) 01:09:47 ID:???
どうでもいいところに突っ込むな
454nobodyさん:2008/04/24(木) 01:26:58 ID:???
>>>444=448
455nobodyさん:2008/04/24(木) 01:28:00 ID:???
つーことは、お前、質問者に
ダメ出しされてるのかよw
456444:2008/04/24(木) 01:32:57 ID:???
>>445-
ありがとうございました。fcloseは必要ないようですね。
fopenで処理を分けるのもよく無さそうなので再考してみます。
457nobodyさん:2008/04/24(木) 02:08:48 ID:???
ファイルの存在確認後に削除されてたなら、それが正しい「Worning」たる理由なんじゃね?
458457:2008/04/24(木) 02:09:11 ID:???
Warning.
459nobodyさん:2008/04/24(木) 02:13:26 ID:???
何を言いたいのかさっぱりわからんw
460nobodyさん:2008/04/24(木) 02:40:13 ID:LhY+BYrB
PHPでCのように 7 / 2 で整数の 3 が欲しい時は
floor(7/2) とするのが一般的ですか?
461nobodyさん:2008/04/24(木) 03:19:38 ID:???
>>460
C99 と合わせたかったら 0 に近付くように丸める。
intval(7/2) か整数型へのキャスト (int)(7/2) で。
462nobodyさん:2008/04/24(木) 04:00:47 ID:???
file_exists、fopen、 両方で判別するのが大人。

どっちの方法とか言ってる時点でウンコ。
463nobodyさん:2008/04/24(木) 04:19:28 ID:???
セーフモードも考慮するとfile_existsなんて使わないで別の関数があるだろ
464nobodyさん:2008/04/24(木) 04:21:02 ID:???
>>462
それで満足気に話しているお前が痛々しいだけ。

file_existsで存在を確認した後に、fopenの処理をするまでの間に
ファイルが存在しなくなる可能性はある。
1日10万PV位のサイトを運営していると、そんなケースなんて日常茶飯事。

まぁ、素人に言ってもしょうがないがwww
465nobodyさん:2008/04/24(木) 04:24:12 ID:???
煽りたいだけの奴はよそいってくれ
466nobodyさん:2008/04/24(木) 04:36:22 ID:???
素人ども向けに「俺様がてめえらに教えてやる排他制御」でも書いてくれたほうが
煽りよりずっといいよ。
467nobodyさん:2008/04/24(木) 04:41:32 ID:???
>>462
JP1は黙れ。
468nobodyさん:2008/04/24(木) 05:26:59 ID:???
レスが増えてると思ったら煽るだけで提案しないバカがまた沸いたのか
469460:2008/04/24(木) 06:31:20 ID:1f8tGK11
>>461
ありがとうございます
470nobodyさん:2008/04/24(木) 10:09:19 ID:???
俺はPerl出身なんだけど、普通、ファイルオープンするだけでも
やっぱそこまでファイルの存在の確実性を意識しないとダメ?
if(($IN = @fopen($file,'r+')) < 0)
これじゃダメ?

あと、書き込みの時は、物理的ロック(自作ロック)して、
ファイルオープンしてflockってしてるんだけど、これでもやっぱ不十分?
物理的ロックってのはロック用ファイル作成する方法です。
471nobodyさん:2008/04/24(木) 10:32:12 ID:???
おれはデータベース使ってロックする方法を取り入れてる
472nobodyさん:2008/04/24(木) 11:29:16 ID:???
データベースのロック機構使いながらファイル使うって、
レインコートを着ながら、傘を差すようなものだな。
頭にウジでも湧いているじゃないだろうか?
473nobodyさん:2008/04/24(木) 11:33:25 ID:???
頭に蛆は湧いていないけど、風呂場に蛆が湧いているよw
474470:2008/04/24(木) 11:47:44 ID:???
いや、俺も最近はデータベースばっかだけど、
でもファイル使わないといけない時もあるしな。RSSとか。
475nobodyさん:2008/04/24(木) 11:56:29 ID:???
>>472
君はいろんなものを作って知識を貯めたほうがいいよ
自分の無知を晒すことになるから
476nobodyさん:2008/04/24(木) 12:09:45 ID:???
無知をさらしているのはお前だよw
データベースも実体はファイル。
ファイルを操作するI/Fが違うだけ。

使うばかりじゃなくて、仕組みを理解しないと、応用が効かないよ。
477470:2008/04/24(木) 12:27:26 ID:???

> if(($IN = @fopen($file,'r+')) < 0)
これじゃまだダメだと思う?
478nobodyさん:2008/04/24(木) 12:34:58 ID:???
>>477
う〜ん、なんかごまかしって感じ
479nobodyさん:2008/04/24(木) 13:09:05 ID:RVXwLuUy
Wikipediaみたいな
ttp://example.com/KEYWORD
みたいなURLってPHPでどうやるの?
index.php?←消せるの?
480nobodyさん:2008/04/24(木) 13:11:46 ID:???
>>479
$_server['path_info']
481479:2008/04/24(木) 13:17:47 ID:RVXwLuUy
>>480
PATH_INFOって↓みたくなるんじゃないの?
ttp://example.com/index.php/KEYWORD
482nobodyさん:2008/04/24(木) 13:20:33 ID:???
それかrewrite
483nobodyさん:2008/04/24(木) 13:30:51 ID:???
こういう口の利き方の質問者は教えても感謝をしないから教えなくて良いよ
484nobodyさん:2008/04/24(木) 14:23:25 ID:???
>>470
> やっぱそこまでファイルの存在の確実性を意識しないとダメ?
それは要求次第。
単純に読み取りしたい時は調べても無駄だからやらない。
状態が分かってもそれは fopen() を呼んだ時点の状態ではないから。
>>444 が言う「ファイルが存在する場合のみ処理」の場合は
存在が分かればいいのだから file_exists() がより妥当っていうお話でしょう。
質問にまともに答えず別の話にもってく奴が悪いんだけどな。

あと fopen() の返り値はリソース型もしくは論理型の false なので
比較は fopen() !== false または is_resource(fopen()) で。

> ロック用ファイル作成する方法
システムコールのロックが使えない、欠陥がある場合や
mandatory lock したい時は使わる一つの手だね。
485nobodyさん:2008/04/24(木) 14:37:34 ID:WKXs89Ye
質問させてください
ヘッダとフッタだけ出力する.PHPに 中身のコンテンツを表示させる.PHPを
includeさせているとします。
このとき、中身のPHPにheader関数でリダイレクトさせる機能はつけられないんでしょうか?
この機能はそれより前に何も出力してないことが条件とありますが、
(親の.phpが)ヘッダを出力してるから無理?
テストしたところ動かないです。 これは上記の理由によるものですか?
486nobodyさん:2008/04/24(木) 14:44:04 ID:???
こういう図か
test.phpの中身
フッタ
コンテンツ(ここは外部ファイルをインクルードして表示)
ヘッダ

んでtest.phpではじめの出力でheaderを送信させてリダイレクトさせたいということか?
487nobodyさん:2008/04/24(木) 14:44:23 ID:???
質問の仕方としては15点
488485:2008/04/24(木) 14:57:52 ID:WKXs89Ye
<html>
<header></header>
<body>
<?php
include "nakami.php";//中身を読み込み。この中でリダイレクトさせてる(header()で)
?>
</body>
</html>
って感じです(外側の.php)
こういうやり方だと、リダイレクトしないんです。
489485:2008/04/24(木) 15:02:12 ID:WKXs89Ye
>>486
どうもです
リダイレクトの関数を設置してるのは、読み込まれている側(コンテンツ部分)の
.phpです
490nobodyさん:2008/04/24(木) 15:05:25 ID:???
>>485 yes
491nobodyさん:2008/04/24(木) 15:07:19 ID:???
>>488
nakami.phpを読み込んでheader関数使う前にタグが出力されてんじゃん
492nobodyさん:2008/04/24(木) 15:09:14 ID:???
>>488
で、なんでリダイレクトする必要があるわけ?
アフィ厨で不正やろうってわけじゃないよな
出力させたいページをそのコンテンツ部分に読み込ませればいいじゃん
493485:2008/04/24(木) 15:14:28 ID:WKXs89Ye
すみません、沢山の人に答えてもらって感謝してます
結局ムリってことですよね、親のphpに出力されてるから…
この場合はjavascriptを中身の.phpに入れるしかないですよね?

>>492
フォームで、アンケート.php に「トップ.php」「確認.php」「完了.php」を
読み込ませてるんです。(ブラウザに表示されるURLは常にアンケート.php)
完了まで行ったら二重送信防止にリダイレクトさせたくて。。 って事情でした
494nobodyさん:2008/04/24(木) 15:17:33 ID:???
ファイルを分けたいのなら

アンケート.phpにいろんなファイルを読み込ませて一つのファイルで処理してるように見せかけたいの?
なんかあなたがやってるのは無駄な処理だな
495485:2008/04/24(木) 15:21:36 ID:???
>>494
どんなやり方がオススメですか? 良かったら聞かせてください
496nobodyさん:2008/04/24(木) 15:24:59 ID:???
id隠れてるのは偽者?
497nobodyさん:2008/04/24(木) 15:26:08 ID:???
>>485
ここまでの回答の流れをぶったぎってレス
ob_start 使えば実現できる
498nobodyさん:2008/04/24(木) 15:34:24 ID:???
Smarty使えば一発で解決する
499485:2008/04/24(木) 15:36:55 ID:WKXs89Ye
>>496
僕のことですか? >>495も僕ですよ
本題とずれてきたのでsageたほうがいいかなと思いました
enq_top.php > enq_conf.php > enq_rewrite.php > enq_finish.php と、
トップから完了まで全パターンの.phpを(使いまわせるはずのヘッダやフッタ含めて)
作るのがめんどくさいのでincludeさせたんですが、、 他にどんな良い方法があったんだろうと
気になってます。 smarty使えば、ヘッダやフッタをテンプレートとして効率よく管理できるとは思いますが…

>>497
ありがとうございます 調べてみます
なんだか特殊な機能みたいで難しそうですが、、 ありがとう
500485:2008/04/24(木) 15:39:29 ID:WKXs89Ye
>>498
あ、やっぱりsmartyですか…
一度勉強し始めて、基礎も出来てないのによしておこうと思ってやめました
またやってみようかなぁ。。 プロはみんな使ってるんでしょうか?>smarty
501nobodyさん:2008/04/24(木) 17:02:09 ID:???
ob_*なんてデフォで使えるようになってるだろ
502nobodyさん:2008/04/24(木) 17:57:45 ID:???
$url="hoge"; を<a href=hoge>hoge</a>にする楽なやりかたないでしょうか?
503nobodyさん:2008/04/24(木) 18:22:27 ID:???
echo "<a href=\"$url\">$url</a>";が面倒ですと?
504nobodyさん:2008/04/24(木) 18:40:44 ID:???
こういうときは間違った方向に走るもんじゃないのか。

$str = '$url="hoge"; がいっぱい出てくる $url="hoge"; だらけの文字列';
echo str_replace('$url="hoge";', '<a href=hoge>hoge</a>', $str);
505nobodyさん:2008/04/24(木) 18:45:03 ID:???
俺は printf( "<a href=\"%s\">%s</a>", $url, $url ); の人
506nobodyさん:2008/04/24(木) 18:59:23 ID:???
メソッドっていうのか
echo linkfy($url);
こうできませんかね。。。
507nobodyさん:2008/04/24(木) 19:01:45 ID:???
jibunndekannsuuwotukurebaiijannka
508nobodyさん:2008/04/24(木) 19:01:56 ID:???
メソッドは知ってるけど関数は知らないのか?
509nobodyさん:2008/04/24(木) 19:09:35 ID:???
ということはVBの人か。
510nobodyさん:2008/04/24(木) 19:15:05 ID:???
>>506
http://www.php.net/manual/ja/language.functions.php
ここ読んで function linkfy($arg) 作ればいいよ。
sprintf( "<a href=\"%s\">%s</a>", $arg, $arg) を return するだけの関数。
511nobodyさん:2008/04/24(木) 19:16:46 ID:???
なんだこの流れ・・・
512nobodyさん:2008/04/24(木) 19:22:07 ID:???
素質ある技術者の技術的な考察とかJP1よりは、のどかでいいよ。
513nobodyさん:2008/04/24(木) 19:26:21 ID:???
>>510
キモイ書き方薦めるのやめれ
514nobodyさん:2008/04/24(木) 20:18:10 ID:1f8tGK11
このマニュアルってオフラインで使えるダウンロード版はありますか?
http://www.php.net/manual/ja/index.php
515nobodyさん:2008/04/24(木) 20:39:33 ID:???
ここから好きなの落として使って

http://www.php.net/download-docs.php

516nobodyさん:2008/04/24(木) 21:15:56 ID:mjxa+9jc
本当にくだらない質問で申し訳ございません。

リンク先のa.phpに文法エラーが存在する場合、IE6:500エラー Firefox:syntax error が
表示されます。
上記の場合、IEでsyntax errorを出現させる設定等あるのでしょうか?

どなたかご教示くださいませ。
517nobodyさん:2008/04/24(木) 21:25:59 ID:???
IE側の設定だった気がす
518nobodyさん:2008/04/24(木) 21:30:32 ID:???
メニューの
[ツール] - [オプション]

[詳細設定]タブ
ブラウズ カテゴリの
 HTTP エラー メッセージを簡易表示する
のチェックを外す

これIE6ね。IE7はワカンネ
519516:2008/04/24(木) 21:35:25 ID:mjxa+9jc
>>517-518

IE6です。>>518の設定方法を試してみたところ syntax error が表示されました。
本当にありがとうございました。
520nobodyさん:2008/04/24(木) 21:44:51 ID:???
どういたしまして。
521nobodyさん:2008/04/24(木) 21:46:13 ID:???
>>518
IE7でも同じ設定項目があるyo
522nobodyさん:2008/04/24(木) 22:50:12 ID:???
>>518
JP1でも同じ設定項目があるyo
523nobodyさん:2008/04/25(金) 07:00:29 ID:???
JP1って流行っているの?
何なの、このJP1、JP1ってレス?
524nobodyさん:2008/04/25(金) 08:22:49 ID:???
JP1を売り込む営業さんが数字伸ばすためにここで宣伝してるんだろ
営業へただからここで宣伝してるんだろ
525nobodyさん:2008/04/25(金) 15:18:13 ID:ETeE5V7l
PHPからcronにジョブを足したり消したりできませんか?
526nobodyさん:2008/04/25(金) 15:19:24 ID:???
>>525
それができたらどうなるかわかりますか
527nobodyさん:2008/04/25(金) 15:31:54 ID:???
>526が何を懸念してるのか知らないが、system使えば出来るんじゃ?
やったことねーけど
528nobodyさん:2008/04/25(金) 15:40:10 ID:???
>>526
PHPでスケジューラーが作れます
529nobodyさん:2008/04/25(金) 20:54:21 ID:???
phpでもperlでも、良いんですが、
フリーの掲示板のcgiを探しています。
条件は
1.英語の掲示板であること。
2.投稿時にCAPTCHA認証すること。
です。
知ってましたら、教えてください。
530nobodyさん:2008/04/25(金) 20:55:42 ID:???
>>529
kentにcaptchaがついてた
日本語は自分で英語にすりゃできる
531nobodyさん:2008/04/25(金) 21:06:33 ID:???
大文字JPはゆうメイトを思い出すからやめれくれ
532nobodyさん:2008/04/26(土) 00:43:34 ID:???
とりあえずPHPエディタというエディタのスタンドアローン版でも使ってみたら?
533nobodyさん:2008/04/26(土) 00:45:30 ID:???
>>532
phpspotさん乙
534nobodyさん:2008/04/26(土) 00:50:37 ID:???
あれは使えん
535nobodyさん:2008/04/26(土) 01:10:46 ID:???
Emacs使ってるけど、ヒアドキュメントがちと書きにくい。
536nobodyさん:2008/04/26(土) 01:52:48 ID:???
FlashDevelopは意外と快適。
537nobodyさん:2008/04/26(土) 06:10:19 ID:???
JP1、JP1ってもういいよ。
確かに、一流のソフトであることは間違いないし、
色々な公共機関、金融システムで使われているし、
そんなことは周知の事実だと思うよ。
538nobodyさん:2008/04/26(土) 10:59:49 ID:???
>>537
ってか、そういうレスしているのが逆に宣伝になっていると思うんだが・・・
539nobodyさん:2008/04/26(土) 11:18:17 ID:???
>>538
537はJP1JP1ってうるさい奴だろ
批判するような感じで宣伝してるんだ
540nobodyさん:2008/04/26(土) 12:50:06 ID:???
PHPからうまくメールが送れません。
というか、maillogをみると、Fromが変わらないので、localhost.localhostからメールが飛んでしまい
受信先に拒否されてる感じです。

もともと、ZendFramwork使っていたのですが、問題を特定するために
mail("[email protected]",'test','body','From: [email protected]' . "\r\n");
という最小限のコードで試しました。

php.iniのsendmail_from=なんかもいじってみましたが、Fromがlocalhost.localhostになってしまいます。

他になんか送らなきゃいけないheaderとかあるのでしょうか?
541nobodyさん:2008/04/26(土) 12:59:44 ID:???
営業成績上げないと夏ボが危ういんじゃね?w
542nobodyさん:2008/04/26(土) 13:20:52 ID:ZONOtLDh
543nobodyさん:2008/04/26(土) 13:21:44 ID:???
>>542
グロ注意
544nobodyさん:2008/04/26(土) 13:42:04 ID:???
>>540
そういうのは環境依存の可能性が高いんだから、環境を書くべき。
あと、騙られる前にあげとけ。
545nobodyさん:2008/04/26(土) 14:13:17 ID:???
>>544
お前に、そんな偉そうにレスされる覚えはない。
546nobodyさん:2008/04/26(土) 14:28:18 ID:???
>>545
質問者なのに、随分と偉そうですね。
そういう人には、誰も答えないと思いますよ。
547nobodyさん:2008/04/26(土) 16:46:11 ID:eenghTEY
簡易的なウェブメールプログラムを作っています。
mb_send_mail でメールを送信する際に
あて先を
山田 <[email protected]>
など使いたいのですが、
日本語や任意の文字列をアバウトに許可すると
セキュリティ的に怖いと感じます。

mb_send_mail のあて先部分は
この文字列を制限・エスケープかけておけばOKという
基準はあるでしょうか?
またお勧めの方法がありましたらお願いします。
548nobodyさん:2008/04/26(土) 17:32:23 ID:???
>>547
入力文字のエスケープに関してのみならば
"メールヘッダーインジェクション"で検索すると
詳しいページが出てくる。

でも、その対策だけでは不充分。
掲示板で、htmlspecialcharsだけ使っても、大量の投稿であっという間に
荒らされるのと同じ。

一定時間内の多重投稿を防いだり、送信者のIPをメールの本文に記録したり
宛先がユーザーから入力可能な場合は、かなり対策が面倒。

ここでメールヘッダーに関して質問しているレベルで
メールの宛先をユーザーが入力可能なウェブメールなんてやると、
確実にメールサーバーがブラックリストに載る。
549nobodyさん:2008/04/26(土) 17:32:47 ID:???
ググレば不具合があるmb_send_mailを何故貴様は使ってるのだ
550nobodyさん:2008/04/26(土) 18:08:34 ID:TgkCKAum
サーバー部門からロードアベレージの原因はディスクI/Oが原因みたいだけど
プログラム側で何とか軽減できないかって、相談をうけているんだすけど
出来るだけディスクへの負荷を減らす為のプログラムの設計だったり
そんな素敵なノウハウをまとめているサイトてありませんかね
551nobodyさん:2008/04/26(土) 18:18:03 ID:???
ググレカス
552nobodyさん:2008/04/26(土) 18:20:09 ID:???
ククレカレー
553nobodyさん:2008/04/26(土) 18:21:45 ID:???
クレクレカレー
554nobodyさん:2008/04/26(土) 18:21:54 ID:iM9ZNRfW
コンパイル済みプログラム atract (バイナリ)をPHPから呼んで
動かしたいと思い、シェルスクリプトatr.sh
#!/bin/bash
/dir/atract
を用意して、index.php中で

<?php
system("./attract", $ret);
?>
として動かそうとしましたが、$ret=127が返ってくるのみで、
attract自体は動きませんでした。

もちろん、シェルで./atr.shと打つと atract が動きます。
どうしてphpから呼んだときだけ動かないのでしょうか?

環境はRed Hat Enterprise Linux v5、Apache2.2.3、php4.3.9(cgi)です。
555nobodyさん:2008/04/26(土) 18:37:22 ID:???
場所は?
556nobodyさん:2008/04/26(土) 18:39:38 ID:iM9ZNRfW
場所は/public_html/atract/にindex.phpとatr.shがあります。
557nobodyさん:2008/04/26(土) 18:49:40 ID:uk8GT5CY
質問です。

PHPのオブジェクト指向を勉強できる書籍で、オススメなのありますか?
ご教示ください。
558nobodyさん:2008/04/26(土) 19:01:26 ID:???
"シェル本体 シェルファイル"
559nobodyさん:2008/04/26(土) 19:09:33 ID:iM9ZNRfW
>>558
system("/bin/bash /dir/atr.sh", $ret);
ともしてみましたが、動きませんでした。
560nobodyさん:2008/04/26(土) 19:20:35 ID:???
>>557
PHPマニュアル
561nobodyさん:2008/04/26(土) 19:30:51 ID:uk8GT5CY
>>560
ありがとうございます。
もう少し丁寧に解説しているものが欲しいです・・・
562nobodyさん:2008/04/26(土) 19:47:35 ID:???
>>561
ここ
563nobodyさん:2008/04/26(土) 20:19:06 ID:uk8GT5CY
常駐します。今日からよろしくお願いします。
564nobodyさん:2008/04/26(土) 20:43:25 ID:???
PHPのオブジェクト指向とか基本がズレてる
オブジェクト指向を学んでPHPに取り入れろ
565nobodyさん:2008/04/26(土) 20:48:59 ID:???
>>564
オブジェクト指向を覚えることが偉いとでも(笑)
566nobodyさん:2008/04/26(土) 21:01:40 ID:???
Java禁止
567547:2008/04/26(土) 22:58:04 ID:???
>>548
サンクスコ


>>549
ソースきぼんぬ
不具合って脆弱性でしょうか、
ちなみに現最新バージョンのPHPでも直ってないのでしょうか?

568nobodyさん:2008/04/26(土) 23:33:03 ID:???
>>567
興味があるんなら自分で調べろよ
有名なんだからググればすぐみつかるし、プログラム書く人間なら知らないのが疑問
569nobodyさん:2008/04/26(土) 23:54:09 ID:EXulrG+H
php3ってクラス使える?
570nobodyさん:2008/04/27(日) 00:05:10 ID:???
>>569
つマヌアル
571nobodyさん:2008/04/27(日) 00:19:21 ID:TNTz3zy3
Zend Frameworkをちょっと勉強しているんだけど、
フレームワークって簡単なものは作れるけど、
結局、サイトによって独自関数やクラスを多用しなきゃいけないから
わざわざフレームワークにする意味無いよね?

単に、「他者と作業する上で便利」なだけであって、
開発者が自分だけの場合は、気にしなくて良いのかな?
572nobodyさん:2008/04/27(日) 00:24:25 ID:???
>>571
フレームワークにたよるのって気持ち悪くてやりたくない
自分だけのネイティブなコードだけ残したいから
573nobodyさん:2008/04/27(日) 00:35:45 ID:???
>>571
一人で構築してるけど使ったほうが楽で助かる。抽象的に考えられるのがいい。
合わないと感じたなら無理に使わなくてもいいんじゃない?仕事ならともかく趣味の範疇なんだし。
574nobodyさん:2008/04/27(日) 01:34:12 ID:???
一度Ethna使ってみたことがあるけど、
自作クラスの関数内から(Ethnaから呼ばれることを前提とした)既存クラスにアクセスするところで嫌気がさしてやめた。
その手の問題を起こさない(もしくは処理できる)スキルがあれば一人FWもいいかも。
575nobodyさん:2008/04/27(日) 01:48:03 ID:???
中堅規模のサイトをいくつか製作したら
自然とFWが出来上がった漏れは天才。
576nobodyさん:2008/04/27(日) 04:28:19 ID:???
JavaよりPHPやJavaScriptのオブジェクト指向の方が優れている件について。


PHPのバージョンが古い鯖に移植とかする際、関数毎にバージョン確認が面倒です。
ソース内の関数をリストアップして、バージョン○○以降で動きます、
みたいなチェック関数とかありませんか。
自分で作ればいいんだろうけど関数が数千もあるとさすがに面倒。
PHPマニュアルから自動取得するような技術力はありません。
577nobodyさん:2008/04/27(日) 04:43:21 ID:???
自分で作れ
578nobodyさん:2008/04/27(日) 04:54:38 ID:???
PHP4 以降で、関数の存在チェックだけでいいのなら、 token_get_all と function_exists で比較的簡単に作れんじゃないの。
まぁ関数名は、変数名と同じくシンボルとしてしかパースされなかったと思うから、判定が若干面倒ではあるけど。
579540:2008/04/27(日) 05:00:08 ID:pXevviUZ
>>544
遅レスですがサンクス
2chブラウザ使ってるんですけど、一回下げるとそれ覚えてるみたいで思いがけず下げちゃうことがあるんですよね。
すいません。

ちなみに>>545は別人です。

別サーバーで問題なく遅れてたんですけど、新しいサーバーかりてそこに入れてみたら
まったくFromを変えられなくなったんですよ。
ちなみにCentOS5+qmail+PHP5.1.6です。

サーバーの設定の問題かと思ってサーバー借りてるところのサポートに連絡取ってみたら
「PHPの問題だ、こんなことで連絡してくんな。ググれカス!」
って怒られて、いろいろ調べてみたんですけど、にっちもさっちも行かなくて。

やっぱりPHPの問題なのですか?

580nobodyさん:2008/04/27(日) 05:08:05 ID:???
PHPの問題だ、こんなことで連絡してくんな。ググれカス!
581nobodyさん:2008/04/27(日) 05:27:03 ID:???
sendmail_path か QMAILの設定の問題なのかなぁ。
とりあえずQMAILのエラーログも見てみたら?
582nobodyさん:2008/04/27(日) 12:00:48 ID:???
583nobodyさん:2008/04/27(日) 13:01:00 ID:EBk2n3bR
PHP開発5年ほどやってるが、あんまり他と交流ないのでチョット疑問なのですが、
$_SESSIONって、どれくらいの値を入れてます?

$_SESSION['user_id'] だけ入れて、各処理毎にDB接続は鯖コスト高いだろうし、
俺はログイン処理後DBからパスワード以外(user_id, user_name, user_mail)は入れてます。

変数でいうと10個分くらいまで とか勝手な基準でやってたんですが、
$_SESSION['html'] とかで、膨大なデータ(文字列、配列)を入れたりしてる人もいますか?
584nobodyさん:2008/04/27(日) 13:02:55 ID:???
はい?何のために入れんの?
585nobodyさん:2008/04/27(日) 13:09:17 ID:???
セッションセーブパスにDBから受け取ったユーザー情報を
一度全部書き出して、処理後はガーベッジコレクションを待ったり、
あるいは自分で消したりする処理を書き加えたりしたいですか。
586547:2008/04/27(日) 13:18:03 ID:???
>>568
ぐぐっても現状で改善されていないmb_send_mailの
問題なんて見つからないから聞いてるんだけど。
まさか昔の脆弱性やバグの話持ってきて、
不具合が、、、とか言ってるんじゃないよね?
587583:2008/04/27(日) 13:22:27 ID:EBk2n3bR
あっー言葉足らずで非常に申し訳ないです。
$_SESSION['html']は喩えでして、

MySQLでユーザ情報テーブルがあり、そこに繋がるTEXT長のフィールドがあった場合でも、
通常DB接続は鯖コスト的に高いし、ソースコード的にも$_SESSION参照よりは冗長になるし
セッションに格納したほうが見通しは良いのかなと思いました。

※今は$_SESSION['message_id']と数値で保存して、表示の際にDB接続という処理を作る場合が多いです

セッションファイル読み込む際に鯖メモリ使うわけだし、ケースバイケースですよね。
すんませんでした。
588nobodyさん:2008/04/27(日) 14:11:52 ID:???
>>586
昔からバグなんて無いよ。
文字化けしてる奴はini設定間違ってるだけだろ。
589nobodyさん:2008/04/27(日) 14:24:39 ID:???
>>586
きっとスーパーハカーなんだよ
590nobodyさん:2008/04/27(日) 14:49:03 ID:???
>>587
前にいた会社はめちゃくちゃセッションに入れまくってた。
検索結果を全部セッションに入れて、それをページングして表示してたりした。
ログイン時にユーザ情報もほぼ丸ごとセッションに入れてたなあ。
まあそれほど規模が大きいわけでもなかったから別に問題はでなかったけど。
591nobodyさん:2008/04/27(日) 16:30:17 ID:???
>>590
それ何の自慢だよ
592nobodyさん:2008/04/27(日) 22:06:13 ID:???
今、HTTP:requestを使ってよその検索エンジンのAPIへ問い合わせて結果をリターンするプログラムを作って置いてるんだけど
リクエスト数が毎秒ってぐらい半端じゃなく多くなりました

全てサーバー回線で問い合わせてるから異常なほどリクエストが多いとアク禁を食らう可能性もあるかと思い
PHPでJavascriptのAjax.requestみたいに(非同期通信?)利用ユーザー回線で問い合わせる方法ありますか?
593nobodyさん:2008/04/27(日) 22:12:53 ID:???
PHPがどこで動いてると思っているんだ?
594nobodyさん:2008/04/27(日) 22:14:13 ID:???
PHPは医療業界を救えますか?
595nobodyさん:2008/04/27(日) 22:18:56 ID:???
>>594

  ∧ ∧     ┌─────────
  ( ´ー`)   < シラネーヨ
   \ <     └───/|────
    \.\______//
      \       /
       ∪∪ ̄∪∪
596nobodyさん:2008/04/27(日) 22:23:35 ID:???
>>593
ですよね。めんどいけどローカルで動くようprototype使ってjavascriptで書き直します
597nobodyさん:2008/04/27(日) 22:47:27 ID:???
明日からインターネットが使えなくなるので
今入れといたほうが良いものってありますか?
ちなみにfirefox2.0、php5.25、apache2.61,DWは入れてます
598nobodyさん:2008/04/28(月) 01:41:34 ID:???
>>597
何がしたいんだ・・・
599nobodyさん:2008/04/28(月) 02:09:46 ID:???
>>597 AV
600nobodyさん:2008/04/28(月) 02:38:25 ID:XDsHBgsJ
質問させていただきます。よろしくお願いします。

別ドメインのphpからjavascritpを出力させたいのですが、

<iframe marginwidth="0" marginheight="0"
   type="text/javascript"
src="http://example.com/example.php"
>
</iframe>

とすると、Javascriptがそのままテキストとして表示されてしまいます。
後で部分的に更新させたいのでフレームを使いたいのですが、
このような使い方は出来ないのでしょうか?
ほとんどスレ違いかと思いますがよろしくお願いします。
601nobodyさん:2008/04/28(月) 04:17:52 ID:???
動的にスクリプトを読み込ませたいなら、scriptをcreateElement して、documentにaddChildするのが定石だと思う。
javascript 動的ロード とか Dynamic Script でぐぐって見て。
JSAN とかも参考になるかも。

詳しくは Javascriptスレでやったほうがいいと思う。
602nobodyさん:2008/04/28(月) 05:12:11 ID:???
>>598
PHPの開発だろ条項
603nobodyさん:2008/04/28(月) 08:44:54 ID:???
PHPでサイトを作っているのですが、携帯に対応しようと思っています。
そこでサイト閲覧の経過時間を表示したいのですが、
方法がわかりません。
携帯ではJavaScript使えないみたいなので。

スレ違いだとは承知していますがよろしくお願いいたします。
604nobodyさん:2008/04/28(月) 08:47:52 ID:???
>>603
SESSION
605nobodyさん:2008/04/28(月) 08:58:14 ID:???
>>604
すみません。説明不足でした。
サイト閲覧時間をデジタル時計みたいに1秒区切りで
随時表示していきたいのです。

それともそれがSESSIONでできるのでしょうか?
無知で申し訳ありません
606nobodyさん:2008/04/28(月) 09:07:47 ID:???
flashとか使うしかないんじゃないの?
607nobodyさん:2008/04/28(月) 09:09:09 ID:???
>>605
SESSION使えば出来るでしょ。
別にSESSIONじゃなくても、初期時間を常に引き回せば良いのでは?
ページ表示中もリアルタイムでカウントアップしたいならFLASHも一緒に使いなはれ
608nobodyさん:2008/04/28(月) 09:10:35 ID:???
>>606
flashを使うという手がありましたね。
参考になりました。
ありがとうございました。
609nobodyさん:2008/04/28(月) 09:12:10 ID:???
>>607
ページ表示中もリアルタイムでカウントアップしていきたかったのです。
検討していただきありがとうございました
610nobodyさん:2008/04/28(月) 09:21:50 ID:eHo0WZE0
認証しないと見れないページを作ってます。
ログインフォームにIDとパスを入力して、正しかったら$_SESSION['login']に1を格納してます。
認証しないと見れないページで$_SESSION['login']に1が入ってるか確認して、入ってたらページを見せます

これはセキュリティ的にどうなんでしょうか?
改善するとしたらどのようにしたらよろしいでしょうか?
611nobodyさん:2008/04/28(月) 11:22:21 ID:???
>>610
色々な意見は有るだろうけど、少しでもシビアにやる必要が有るのなら
私なら、少なくとも一緒にIPとUAぐらいは格納しておいて常時チェックします。
と、セッションの有効期限を短めに。

ま、セッションハイジャックされても大して困らないようなサービスだったら、
login=1だけでもいいと思います。
612nobodyさん:2008/04/28(月) 11:58:35 ID:U6D2eVEj
VirtualHostを使って80とは別のポートで受けているのですが
$_SERVER['SERVER_PORT']の値がおかしい時があります
ポートを変えているのに、なぜか80が入っています
URIを長くしたりすると、正しいポートの番号が入っていたりします
その規則性が分からないのですが、
この問題についてご存じの方がいたら教えてください
SetEnvを使って、代替となる環境変数を設定するか、
ホストを自分でパースすれば、
ポート番号を知りたいという要求は満たせるのですが、
奇妙な動作なので気になります。
613nobodyさん:2008/04/28(月) 16:35:05 ID:ASacEEs/
PHPでSOAP使ってるんですが、Digest認証のページにアクセスするいい方法ってあります?
Basic認証のページへはSoapClientのコンストラクタに引数渡してアクセス出来るんだけど、
Digest認証のところでひっかかって先に進めないのです。
614nobodyさん:2008/04/28(月) 17:09:28 ID:???
echo '<table width="'.$width.'"';
echo ( $titleHeight )? ' height="'.($aaa-$bbb).'"':' height="'.($aaa-$bbb).'"';

プログラムが長すぎるのでエラーが出る行だけの書き込みです。

$titleHeight っていう値がないので削除したいのですが

echo '<table width="'.$width.'"' height="'.($aaa-$bbb).'"':' height="'.($aaa-$bbb).'"';

とするとエラーでPHPが正常に処理してくれません。
どこがおかしいのでしょうか??
615nobodyさん:2008/04/28(月) 18:30:45 ID:???
echo
'<table width="'
.
$width
.

'"'
height="'
.
($aaa-$bbb)
.
'"'
:
' height="'
.
($aaa-$bbb)
.
'"';
616nobodyさん:2008/04/28(月) 18:31:23 ID:???
>>614

>>615を100回嫁
617nobodyさん:2008/04/28(月) 19:23:00 ID:???
三項演算子だお

echo '<table width="'.$width.'" height="'.($aaa-$bbb).'"';
618nobodyさん:2008/04/28(月) 19:53:50 ID:???
しかし糞汚ねえゴミソースだな
619nobodyさん:2008/04/28(月) 20:51:50 ID:???
>>618
見本をお願いします。
620nobodyさん:2008/04/28(月) 21:00:34 ID:???
ヒント:太いにあって大にないものが足りない。
621nobodyさん:2008/04/28(月) 21:04:21 ID:???
>>619
見本出してやるから元のコード出せ
つうかechoでhtml全部吐くな
ちゃんとviewと分離しろ
622nobodyさん:2008/04/28(月) 21:07:33 ID:???
viewと分離ってどういう意味?
別ファイルにしろってこと?
623nobodyさん:2008/04/28(月) 21:09:03 ID:???
太を
大と

に分けるってこと
624nobodyさん:2008/04/28(月) 21:10:24 ID:???
<html>
<head>
</head>
<body>
<table width="<?php echo $width; ?>" height="<?php echo $aaa-$bbb; ?>">
</body>
</html>

こういうことだろ
625nobodyさん:2008/04/28(月) 21:29:48 ID:???
埋め込み方式で<?php echo $hoge; ?>ってのを短縮するやつあったよな
<?= $hoge ?>だっけ?
626nobodyさん:2008/04/28(月) 21:34:18 ID:???
>>624
それだと掲示板みたいに増減する複数個のテーブルを、
内容を変えながら表示すること出来ないんじゃね。
627nobodyさん:2008/04/28(月) 21:39:58 ID:???
>>624
期待して損した
これはヒドイw
ブログのテンプレートとか見て勉強してこいクズ
628nobodyさん:2008/04/28(月) 21:44:25 ID:???
>>626
それはControllerの仕事だよ
629nobodyさん:2008/04/28(月) 22:07:12 ID:???
>>626
複数個のテーブルを表示したいなら

<?php foreach(ほげほげ){ ?>
<table width="<?php echo $width; ?>" height="<?php echo $aaa-$bbb; ?>">
内容
</table>
<?php } ?>

すればいいんじゃないの?
630621:2008/04/28(月) 22:11:27 ID:???
>>627
ブログのテンプレートが見本だなんて頭大丈夫か?
あんなスパゲティ糞コードいらね
お前みたいのはPerlでもやってろ
一番いいのはCakePHPのソースを見ること
命名規則やコーディングが若干気に入らないが勉強になるぞ
631nobodyさん:2008/04/28(月) 22:33:01 ID:???
>>630
デザインと分離するんじゃなかったのか?
だいじょうぶか?あたま
632nobodyさん:2008/04/28(月) 22:40:59 ID:ofPhinBe
会員制サイトで
仮登録→登録という流れのとき、

$reg_key = sha1(uniqid(rand(), true));
のように、メールを受信した人にしかわからないトークンを作り、

認証のアドレス.php?email=xxx®_key=yyy
や、
認証のアドレス.php?id=xxx®_key=yyy

としている場合が多いのですが、
パラメータとして渡すのは、reg_keyだけではだめなのでしょうか?

uniqidが入っているので、問題ないかと思うのですが・・・

説明が足りないところがあるかもしれませんが、
理解していただける方がいましたら、アドバイスお願いします。
633nobodyさん:2008/04/28(月) 23:02:26 ID:???
それだけで賄えるならそれでいいじゃん
634nobodyさん:2008/04/29(火) 00:08:00 ID:AbJjjUx5
以前php.iniについて質問したものです。
教えて頂いた方法で数週間試してみましたが、
全くエラーが出来なくなりました。

お礼が遅くなりましたが、どうもありがとうございました。
めちゃ助かりました!
635597:2008/04/29(火) 00:15:02 ID:UrbOD/FY
だれかおねがいします
636nobodyさん:2008/04/29(火) 00:36:53 ID:???
>>635
使えてるみたいだしいいじゃねーか
637nobodyさん:2008/04/29(火) 02:39:37 ID:???
>>636
今日モデム返すのですよ
638nobodyさん:2008/04/29(火) 03:44:02 ID:???
coLinux
639nobodyさん:2008/04/29(火) 03:50:53 ID:???
何ヶ月もつなげられないような僻地にでもいくのか?
とりあえずマニュアルをオフラインでも見れるようにダウンロードしといたほうがいいんじゃね?
あとDW使ってPHP書いてるんならそれでもいいけどEclipseとかのIDE入れたり
あとはMySQLなりPostgreSQLなりDBもちゃんと入ってるか?
phpMyAdminやphpPgAdminなどのWebから使えるDBの管理者ツールとか
必要ならDBのマニュアルなんかもダウンロードしといたほうがいい
メール開発するならメールサーバも必要
XAMPPなら全部入ってるが自力で各個いれて設定できるなら余裕だろ
640nobodyさん:2008/04/29(火) 04:57:58 ID:???
>>515
レス遅くなり申し訳ありません。
ちゃんとサイト内にあったのですね
ありがとうございます
641nobodyさん:2008/04/29(火) 07:55:26 ID:???
>>613
コンストラクタの $options に
'authentication' => SOAP_AUTHENTICATION_DIGEST
を追加してみるとどうでしょうか。
ドキュメント化されてないので確証はないですが。

>>632
reg_key が一意なら使えます。
見直す点は uniqid() も sha1() も返り値が一意的でない事。
642632:2008/04/29(火) 08:57:25 ID:QM2GtqNT
>>633
>>641

回答ありがとうございます!

>>見直す点は uniqid() も sha1() も返り値が一意的でない事。

そうですか・・・uniqidだけではだめなのですね。

一応、データベース側でreg_keyをユニークに指定してあるので、それほど問題はないかもしれませんが、
やはりエラーがでてしまうのは避けたいです。

お手数ですが、
もしよかったら、値が一意になる具体例(こうすれば一意になるというもの)を教えていただけないでしょうか?
よろしくお願いします。
643nobodyさん:2008/04/29(火) 11:46:43 ID:???
rand()だけでなくユーザIDも一緒に
644641:2008/04/29(火) 12:53:49 ID:???
>>642
データベースに UNIQUE KEY 制約が指定してあるなら sha1(uniqid()) で問題ないですよ。
一意かどうかは集約側に問い合わせるまで保証できませんので、
適当に生成→クエリが成功するまでトライするぐらいしか思い付きません。
データベース側で生成できるならそちらで。
MySQL の場合は UUID() とストアドプロシージャで出来そうな気もします。
詳しくないのでやり方はDB板にお任せします。
645nobodyさん:2008/04/29(火) 13:16:12 ID:???
UNIX/Linux系OS上において、PHPでの開発実務経験者

っていう求人に応募したいのですが、これはlinuxが入ってるパソコンでコードを書いて開発してる人だけってことですか?
windowsでコードかいてlinuxにアップロードして開発するのはこの枠には含まれないのでしょうか?
646nobodyさん:2008/04/29(火) 13:51:56 ID:???
WINEつかって開発すればいいんだよ。
647nobodyさん:2008/04/29(火) 13:59:35 ID:???
>>645
こんなところで聞いている時点で何だかな〜って気がするけど、
応募先に質問すればすぐに分かることじゃない

質問先が明確にあるなら、まず聞く

以上
648nobodyさん:2008/04/29(火) 14:05:37 ID:???
だからここで聞いてるだろ?
649nobodyさん:2008/04/29(火) 14:13:54 ID:???
募集先ってことじゃないの?

ここで聞いて
「そっか!大丈夫なんだ!るんる〜ん♪」
と応募しても、
先方が却下だったら却下なわけだしね
650nobodyさん:2008/04/29(火) 14:54:31 ID:???
あんなマゾいlinuxだけで完結して開発してる人なんているわけ?
651nobodyさん:2008/04/29(火) 15:06:49 ID:???
UNIX/Linux系OS上において(動く)、PHPでの開発実務経験者

って意味だろw
652nobodyさん:2008/04/29(火) 15:56:32 ID:???
>>645 は
知るかボケ、と言われるのが好きなマゾ。
653初心者:2008/04/29(火) 17:09:19 ID:o9+cl7aK
質問です。

aaaa
aaab
aaac
.
.
.
zzzy
zzzz

とこのようにaからzまでの4文字の数字を全種類表示させるにはどうしたらいいでしょうか?
654nobodyさん:2008/04/29(火) 17:15:53 ID:???
for($i='aaaa'; $i<='zzzz'; $i++){
echo $i."\n";
}
655nobodyさん:2008/04/29(火) 17:18:21 ID:???
こんなのもね。
<?php
 foreach(range(a,z) as $str1){
   foreach(range(a,z) as $str2){
     foreach(range(a,z) as $str3){
       foreach(range(a,z) as $str4){
         print "{$str1}{$str2}{$str3}{$str4}<br>\n";
       }
     }
   }
 }
?>
656初心者:2008/04/29(火) 17:24:33 ID:o9+cl7aK
>>654
そりゃ違うよ。

>>655
ありがとう^^
657nobodyさん:2008/04/29(火) 17:34:40 ID:???
>>656
>>654>>656も結果は同じ。
初心者のうちは、まず試してみること。
658nobodyさん:2008/04/29(火) 17:37:06 ID:???
初心者のくせに何で否定してるんだよw
659nobodyさん:2008/04/29(火) 17:37:16 ID:???
>>656
試しもしねーアタマの硬いクズは二度と来るな
660nobodyさん:2008/04/29(火) 17:42:10 ID:???
>>654の不憫さにフイタwwww
661nobodyさん:2008/04/29(火) 18:06:48 ID:FcuzQKHA
index.html
<html><body>
<form action="index2.php" method="post">
<input type="text" name="keyword" size="40">
<input type="submit" value="送信">
</form>
</body></html>

index2.php
<html><body>
<?php echo $keyword ?>
</body></html>


こういった単純なプログラムなのですが、index2.phpにて入力した文字が表示されません。
本来ならばindex.htmlで入力した文字が変数$keywordに代入されて、index2.phpで表示されるはずなのですが・・・。
何が原因なのでしょうか?
662nobodyさん:2008/04/29(火) 18:12:37 ID:???
これは釣りなのか?w
PHP云々じゃなくてHTTPやWebプログラムの基本から勉強したほうがいいよ

http://www.php.net/manual/ja/reserved.variables.post.php
663nobodyさん:2008/04/29(火) 18:18:31 ID:???
まだ、覚え始めたばかりで基本を勉強している方なんだろうけど、
そんなコードが生み出せる勉強方法があるのかと不思議に思う。
664nobodyさん:2008/04/29(火) 18:19:53 ID:???
>>661
もし参考にしてる本か何かが「そうなるはず」だと
説明してるのなら、記述が古すぎるかも。

http://www.php.net/manual/ja/language.variables.external.php
665nobodyさん:2008/04/29(火) 18:24:39 ID:TMlzPliF
wordpressを導入しようと思い、phpにも取り組み始めたのですが、phpファイル内に直接日本語を記入すると出力時に文字化けしてしまいます。
例えば
<h1><a href="<?php echo get_option('home'); ?>/"><?php bloginfo('name'); ?></a></h1>
だと正常に表示されますが
<h1><a href="<?php echo get_option('home'); ?>/">テスト</a></h1>
だと化けてしまいます。
charsetはutf-8にしています。(wordpressもMySQLも統一してます)
対処法がありましたらアドバイスお願いします。
666nobodyさん:2008/04/29(火) 18:24:51 ID:???
>>662-664
ありがとうございます。どうやら根本的な勘違いだったようですね・・・。
ちなみにこの方法はこちらのページを参考にしました。
ttp://www.stackasterisk.jp/tech/php/php02_06.jsp
667nobodyさん:2008/04/29(火) 18:30:09 ID:???
>>654
これ動かないだろ
668nobodyさん:2008/04/29(火) 18:30:59 ID:???
>>665
エディタはちゃんと内部文字コードがunicodeのやつをつかってるよな?
669664:2008/04/29(火) 18:31:56 ID:???
>>666
> 【動作環境】
> バージョン PHP3
こういう古い解説には気をつけましょうね、ということです。

おまけ。
http://www.php.net/manual/ja/faq.using.php#faq.register-globals
670nobodyさん:2008/04/29(火) 18:40:50 ID:???
>>667
コピペじゃね
671665:2008/04/29(火) 18:53:49 ID:???
>>665
どうもそういう問題だったようです。
DreamWeaverで書いていたのですが、sakuraでUTF-8で開きなおして保存したら表示できました。
ありがとうございました。
672nobodyさん:2008/04/29(火) 19:03:35 ID:???
Dreamweaverも文字コード指定できると思うんだが

>>667
$i<='zzzz' この書き方はダメかもしれないね
文字列に++するのは問題ないんだけど
673nobodyさん:2008/04/29(火) 19:25:44 ID:???
>>671
サクラとかterapadは内部文字コードsjisだから〜←とかの文字が化けるぞ
いまからでもエディタは秀丸とかemediterとかunicodeのやつを使ったほうが良い
674nobodyさん:2008/04/29(火) 19:39:57 ID:???
>>661って要はPOSTで値を変数に格納してないのが間違いなんだよな。
675nobodyさん:2008/04/29(火) 19:46:20 ID:???
register_globalsがデフォルトでonだった危険極まりない頃なら間違いじゃないんだけど

php3を勉強しかかってる人を止められてよかったね、と
676665:2008/04/29(火) 20:36:21 ID:???
>>672
指定していたつもりだったのですが、「エンコードを指定していない〜」という欄にチェックが入っていたためか、コピペして使っていたファイルに適用されていなかったようです。
ただ、プロパティで変更できることに気づきました。
>>671
助言ありがとうございます。
ちょっとした変更は秀丸を使うことにします。
677nobodyさん:2008/04/29(火) 21:18:09 ID:???
>>672
>$i<='zzzz' この書き方はダメかもしれないね

だめじゃないって。試してからレスしようよね。
678nobodyさん:2008/04/29(火) 21:33:27 ID:???
だめだろう。おまえ本当に試してから書いてるのか?
679nobodyさん:2008/04/29(火) 21:46:07 ID:???
>>654を試したら止まらないのだがどう修正すればいい?
680nobodyさん:2008/04/29(火) 21:48:16 ID:???
ネタをどこまでひっぱるんだい
681nobodyさん:2008/04/29(火) 21:48:52 ID:???
for($i='aaaa'; $i!='aaaaa'; $i++){
echo $i."\n";
}
682nobodyさん:2008/04/29(火) 23:08:02 ID:8TiTMo6p
PHPプログラムに限った話ではないかもしれないのですが、PHPで開発してる
のでここで質問させてください。

if($ext != "jpg" && $ext != "jpeg" && $ext != "gif" && $ext != "png")
{
...
}

上記のif文の中身を美しく書き換えたいのですが、($ext !=の繰り返しをなくしたい)
どのようにすればいいか分かりません。教えてください。お願いします。
683nobodyさん:2008/04/29(火) 23:20:10 ID:???
if(!in_array($ext, array('jpg', 'jpeg', 'gif', 'png'))
684nobodyさん:2008/04/29(火) 23:22:50 ID:???
$ary= array('jpg', 'jpeg', 'gif', 'png');
if(!in_array($ext,$ary)
685682:2008/04/29(火) 23:40:33 ID:???
>>683,684
ありがとう。配列にしないといけないのか。
今環境ないので明日やってみます。ありがとうございました。
686nobodyさん:2008/04/29(火) 23:50:01 ID:???
配列にしないといけないわけではないけど、こっちのほうがいい
687nobodyさん:2008/04/29(火) 23:54:29 ID:???
MYSQLでデータベースを構築しようと考えてます。
まず何から始めればいいのか分かりません。
PHPの知識はもちろんあります
688nobodyさん:2008/04/29(火) 23:59:00 ID:???
まずMysqlのホームページからプログラムをダウンロードしてきてください
689nobodyさん:2008/04/30(水) 00:00:34 ID:???
>>688
インストールしました。
PHPMYADMINも導入しました。
690nobodyさん:2008/04/30(水) 00:08:41 ID:???
はじめてこのスレを覗いたのだが、ここの住人は親切で向上心があって素晴らしい。
PHPやってて良かったと思った。
691nobodyさん:2008/04/30(水) 00:09:53 ID:???
>>689
よし、つぎはphpmyadminからデータベースをつくれ
692nobodyさん:2008/04/30(水) 00:55:18 ID:+RqiWmec
ちょっとスレチかもしれませんがお願いします。
URLを開きたいのですがphpのfopenと同じ関数はperlにありますか?
693nobodyさん:2008/04/30(水) 01:07:32 ID:???
694nobodyさん:2008/04/30(水) 01:11:11 ID:+RqiWmec
>>693
はい。そこ見ましたがURLを開く関数が載ってなかったのです。
695nobodyさん:2008/04/30(水) 01:32:03 ID:???
phpのfopenと同じ関数はperlにありますか



URLを開く

はイコールじゃないんだが
696nobodyさん:2008/04/30(水) 02:08:24 ID:???
URLを開くことができるphpのfopenと同じ関数はperlにありますか?
697nobodyさん:2008/04/30(水) 02:14:06 ID:???
>>696

>>695を100回読んでもう一度出直してきてね
698nobodyさん:2008/04/30(水) 02:20:46 ID:???
「URLを開くことができるphpのfopen」

これ理解できませんか?
699nobodyさん:2008/04/30(水) 02:25:54 ID:???
もうあっちで聞いた方がいいよ
ここじゃ答えてくれないと思う

【ANTI】今、あえてPerlで攻める【PHP】
http://pc11.2ch.net/test/read.cgi/php/1046651476/
700nobodyさん:2008/04/30(水) 02:27:55 ID:???
やっと理解できたみたいですね(笑)

PHPのfopenはURLを開けるんですよ。

はいはい。初心者は消えた消えた
701nobodyさん:2008/04/30(水) 02:28:19 ID:???
>>687=689
まず↓で色々と聞いてくるといいと思うよ

MySQL 総合 Part13
http://pc11.2ch.net/test/read.cgi/db/1201632550/
702nobodyさん:2008/04/30(水) 02:52:22 ID:???
ここはphpもロクにできない集まりかよw
perlもわかんないやつ多すぎてフイタ
703nobodyさん:2008/04/30(水) 03:38:29 ID:???
なんでperlスレで聞かないんだ?
それにURL開くならfile_get_contentsとかcurlとか使うだろ
704nobodyさん:2008/04/30(水) 05:55:36 ID:???
Perlもわかんないって別物だから当然だろ
705nobodyさん:2008/04/30(水) 07:14:44 ID:???
ホレ

use LWP::Simple;
print get('http://www.2ch.net');
706nobodyさん:2008/04/30(水) 07:55:55 ID:UIHB9PA8
っていうか、
「URLを開く」って表現がおかしいんじゃないか?
「URLを読み込む」の方がいいような気がする・・。
707nobodyさん:2008/04/30(水) 08:02:11 ID:???
「URLを読み込む」ってなんだよ
ってレスが3つは付くね
708nobodyさん:2008/04/30(水) 10:09:26 ID:???
「URLを読み込む」ってなんだよ
709nobodyさん:2008/04/30(水) 11:16:56 ID:???
「URLを読み込む」ってなんだよ
710nobodyさん:2008/04/30(水) 11:57:43 ID:???
>>692
Perlならソケット使うしか俺は知らん。
711nobodyさん:2008/04/30(水) 12:25:11 ID:???
「URLを読み込む」ってなんだよ
712nobodyさん:2008/04/30(水) 12:56:59 ID:???
完全論破w
このスレはこの程度かwww
713nobodyさん:2008/04/30(水) 13:08:47 ID:???
職場の花でしかない女性PGは黙ってろwww
714nobodyさん:2008/04/30(水) 13:10:54 ID:???
URLをfopenで開くやつは素人
715nobodyさん:2008/04/30(水) 13:26:50 ID:???
じゃあ何で開くんですか
716nobodyさん:2008/04/30(水) 13:38:00 ID:???
ケイコの夢は夜ひらく
717nobodyさん:2008/04/30(水) 14:18:48 ID:???
ケイコの股も夜ひらく
718nobodyさん:2008/04/30(水) 15:05:21 ID:C5WTvXyu
すみませんちょっと質問です。

PHP×MYSQLで検索システムを作ってるんですけど、外部のページからもフォームから
検索したいと要望がありました。MYSQLのポート開けて、外部から接続するのは条件的に
厳しいです。何かいい方法ありませんでしょうか?API的なものを用意できれば良いのでしょうけど。
719nobodyさん:2008/04/30(水) 15:28:38 ID:???
>>718
フォームから検索したいのになぜ外部にポート解放する必要があるのか逆に質問したい
720nobodyさん:2008/04/30(水) 15:31:58 ID:???
>>718
アプリケーション層(PHP)ですべて解決しようとせずとも、
TCP/IP や VPN で解決してはいかがでしょう?

統合型 Firewall などを導入していれば、
パケットを転送してあげればよいと思います

ネットワーク板あたりで該当スレを探してみては?
721nobodyさん:2008/04/30(水) 15:41:58 ID:???
レスありがとうございます。

>>719
検索対象のDBは、Webサイトの置いてあるサーバーと違うところにあるんですね。
DBの置いてあるサーバーに、検索キーワードを投げて、XMLやJSONで返り値を
もらうような仕組みを書けばいいのかなーと、漠然と考えておりました。

>>720
なるほどですね、そうすればセキュリティを保ちながら通信できそうですね。
パフォーマンスなども考えつつ、再度検討してみます。ありがとうございます。
722nobodyさん:2008/04/30(水) 16:01:14 ID:itZeUQTn
携帯サイトで、php_value session.use_trans_sid の機能使ってURLにPHPSESSIDを自動でくっつけてるんだけど、
この値が毎回ころころ変わるんだよ。
家鯖環境だと大丈夫なんだけど、レンサバ(ファーストサーバ)にUPしたとたんに変化する。
なにが原因かおしえて。
723nobodyさん:2008/04/30(水) 16:14:35 ID:???
>>722
バージョンぐらい書いたらどうだ
724nobodyさん:2008/04/30(水) 16:42:15 ID:???
>>722
あなたはここよりも↓の方がいい

くだすれPHP(超初心者用)3
http://pc11.2ch.net/test/read.cgi/php/1193295871/
725nobodyさん:2008/04/30(水) 16:43:33 ID:???
>>724
氏ねカス
726松田 ◆QkRJTXcpFI :2008/04/30(水) 16:48:57 ID:k+045YDQ
HTMLとPHPの初心者です。
すみませんが教えてください。

(index.phpの記述)
<form action="hoge.php" method="post">
<input type="text" name="MMM" size="40"value="" tabindex=1>
<input type="submit" value="送信"tabindex=2>
</form>

hoge.phpから、またindex.phpにリンクで帰ってきた時に、ぐーぐるのTOPのようにすぐに文字を入力できるようにカーソルを入れたいのです。

現状では、index.phpが開いたら、カーソルは何処にもなくて、TABキーを押すと、テキストBOX内にカーソルが現れます(当然なんですよね?)

OS WindowsXP
バージョン PHP-5.2.4(セーフモード)
サーバー会社 http://atpages.jp/

入力者が最初にTABキーを1回押せば済む話ではあるのですが、出来るのならやりたいです。よろしくお願いします。
727nobodyさん:2008/04/30(水) 16:51:47 ID:???
>>726
つjavascript
728nobodyさん:2008/04/30(水) 16:58:40 ID:???
>>726
<ぼdy 音ロアd=”どくめんt。げtElementById(’ほげ’)。ふぉくs()”>
729nobodyさん:2008/04/30(水) 16:59:20 ID:???
>>726
ここでは初心者と自ら名乗る行為は嫌われるのでご注意を

本題ですがそれはJavaScriptを使ってやるのでPHPは関係ありません
例えばこのようにします

<body onload="document.foo.MMM.focus()">
<form name="foo" action="hoge.php" method="post">
<input type="text" name="MMM" size="40" value="" tablindex=1>
<input type="submit" value="送信"tabindex=2>
</form>

次からはJavaScriptスレでどうぞ
730松田 ◆QkRJTXcpFI :2008/04/30(水) 17:20:52 ID:k+045YDQ
>>727-729
レスありがとうございます。お騒がせしました。
>>729
ありがとうございます。感謝致します。
731nobodyさん:2008/04/30(水) 18:01:08 ID:8kfJ8k7x
$in{'mode'}="ins";
恥ずかしながらこういう書き方初めて見たんだけど、
これって何をしてるんですか?配列に代入?
732nobodyさん:2008/04/30(水) 18:07:47 ID:???
>>731
Perlユーザと思われる
733nobodyさん:2008/04/30(水) 18:10:20 ID:???
$inが未定義だから新たにハッシュを作ってる。
試しにその前に$in = '1234';とでも入れてみると面白いよ。

詳しくは
http://jp.php.net/manual/ja/language.types.string.php
http://jp.php.net/manual/ja/language.types.array.php
など参照
734nobodyさん:2008/04/30(水) 18:13:06 ID:???
>>731
#!/usr/bin/perl
require './cgi-lib.pl';
ReadParse(*in);

そのスクリプトにこんな記載はないですか。
735731:2008/04/30(水) 18:18:04 ID:ln6uHZdx
ありがとう!チェックしてみます。ハッシュかー
736731:2008/04/30(水) 18:26:36 ID:ln6uHZdx
>>735
いや、phpの掲示板スクリプトを読んでるんです。今までそんな書き方見たことなかったからハテナ?でした。
737nobodyさん:2008/04/30(水) 18:32:08 ID:???
ん?ハッシュ?
738nobodyさん:2008/04/30(水) 18:34:56 ID:???
>>736
Perlがその書き方で、PHPでも動くんよ
739734:2008/04/30(水) 18:41:28 ID:???
自分宛てだと思うので。

>>736
Perl だと
・配列=添字が数値。 $array[0] で要素を扱う。
・ハッシュ=連想配列。添字に文字列使える。$hash{'mode'} で要素を扱う。
なんですよ。$in{'mode'} は>>734な時代のおやくそく記法。たぶんオチは>>732

ところで PHP では連想配列もひとくくりで「はいれつ」だと思う。
740731:2008/04/30(水) 18:42:24 ID:ln6uHZdx
へー、pealも動くんだ。全然知らなかった。。
733のリンクにヒントがあるんですよね。今携帯からだからリンク先読めないんだけど。。
戻ってチェックしてみます。ありがとうございました!
741731:2008/04/30(水) 18:48:39 ID:???
>>739
丁寧にありがとうございます。perlの記法なんですね。なるほど
742nobodyさん:2008/04/30(水) 18:59:04 ID:???
PerlとJavaとCの記法がごっちゃになっててカオスなんだよなPHPは
俺はJavaユーザなんでもっぱらオブジェクト使ってるけど
743__:2008/04/30(水) 19:03:55 ID:???
画像投稿後の完了ページでF5を押すと同じ画像が投稿されてしまいます。
これを防ぐにはどうしたらいいでしょうか?
headerで飛ばす以外でお願いします。

僕が考えたものとしては以下になります。
具体的にはどうすればいいかお教えください。m(_ _)m
 投稿時にパラメータを埋め込み内部で照合→あわなければNG
 
744nobodyさん:2008/04/30(水) 19:08:48 ID:???
二重投稿チェックすればいいじゃん
745ぴよ:2008/04/30(水) 19:27:35 ID:LQbFwuBs
質問させていただきます。
ホームページをPHPにしてincludeで、ヘッダーやメニューを呼び出そうと思っています。
PHPで可能かどうなのか分からないのですが

メニューのところを、CSSで、フレーム風にし、スクロールできるようにします。
通常のフレームでは、スクロールして、ある項目をクリックした場合
スクロールした状態が保たれますが、CSSのフレーム風では
スクロールした状態が保たれません。

これをPHPでスクロールした状態を保つことはできますでしょうか?
もしできるのならば、やり方、もしくは、参考サイトを教えていただけないでしょうか。
どのようなキーワードで検索すればいいのかも分かりません。
どうぞよろしくお願いいたします。
746nobodyさん:2008/04/30(水) 19:41:05 ID:???
できません
ていうかどう考えてもCSSでの擬似フレームの話でPHP関係ないでしょ
747nobodyさん:2008/04/30(水) 19:49:37 ID:???
そういう見た目てきにどうこうしたいがHTMLじゃ無理そうってのは
たいていJavaScriptなんだよ
PHPは見た目とかUIの機能とかに関しては全く無関係で
そういうのはHTMLとかJavaScriptでどうにかするしかない
PHPは言ってみれば単にHTMLのソースを条件等によって処理して吐くだけ
748nobodyさん:2008/04/30(水) 19:52:31 ID:???
つflash
749747:2008/04/30(水) 19:55:03 ID:???
>>748
そういえばそんなのもあったな
すっかり忘れてたぜ
750ぴよ:2008/04/30(水) 19:56:47 ID:???
てっきりPHPでできると思ってました。
すみませんでした。
JavaScriptで質問してみます。

flashは、ソフトがないのと、勉強に時間がかかりそうなので・・

どうもありがとうございました。
751nobodyさん:2008/04/30(水) 19:59:51 ID:???
flashは無料ソフトでも作れます
752鯖術:2008/04/30(水) 19:59:56 ID:FX5sdMAt
xrea.comのs336鯖を借りています。
PHPで、パーミッションを666にしてファイルを作成するスクリプトは動くのですが、mkdirでtestというディレクトリを作成することまでは可能なのですが、パーミッションを777にしようと
chmod("test",0777);
を指定するとエラーがでます。教えて下さい
753nobodyさん:2008/04/30(水) 20:06:28 ID:???
xreaはsafemodeかかってるんでcgiとして動作させてみ
phpの1行目に
#!/usr/local/bin/php
っていれて拡張子をcgiに変えてパーミッションは755で動作させる
754nobodyさん:2008/04/30(水) 20:08:06 ID:itZeUQTn
>携帯サイトで、php_value session.use_trans_sid の機能使ってURLにPHPSESSIDを自動でくっつけてるんだけど、
>この値が毎回ころころ変わるんだよ。
>家鯖環境だと大丈夫なんだけど、レンサバ(ファーストサーバ)にUPしたとたんに変化する。
>なにが原因かおしえて。

すまん。情報が足らなかったようだ。
PHPバージョン云々より設定とか問題と勝手に思い込んでた。

問題の起きているレンサバの環境はPHP5.2.5 DSO版
問題が起きなかった頃のレンサバ環境はPHP4.4.8 DSO版

ちなみにソースは.htaccessも含め全部一緒。(php_value session.use_trans_sid 1)
単純な実験ページを用意してやってみても同様。
なんでこんなことがおこるんだ??
755nobodyさん:2008/04/30(水) 20:11:55 ID:???
>>752
パーミッション777はsuexecのせいだと思う
鯖の仕様だからそれ以外にする
756nobodyさん:2008/04/30(水) 20:30:54 ID:???
>>754
質問するときは言葉使いに気をつけよう
757nobodyさん:2008/04/30(水) 20:35:05 ID:itZeUQTn
>>756
え?2chってこういう風に書くのが良いって聞いたんだけど?
あれは嘘?やっぱ普通に書いた方が良かったの?

で、なにか知ってるの?
758nobodyさん:2008/04/30(水) 20:37:57 ID:???
ネタにはしったのか残念
ID:itZeUQTnはスルーしますね
759nobodyさん:2008/04/30(水) 20:42:54 ID:itZeUQTn
>>758
やっぱ2chってキモチワルイネ。
そんじゃ、普通の言葉で普通の場所で聞くことにするよ。

知ってるなら教えてくれればいいし知らなければ無視すればいいだけだろ?
「おまえが気に入らないから教えてやらない」的空気で悦に浸ってるのか?
程度が低いな。
760nobodyさん:2008/04/30(水) 20:45:11 ID:???
はい次。
761nobodyさん:2008/04/30(水) 20:46:07 ID:???
ID:itZeUQTn=ゆとり
762nobodyさん:2008/04/30(水) 20:50:40 ID:itZeUQTn
ゆとりってwww 
話には聞いていたが、会話が成立しなくなったら相手を「ゆとり」扱いってのは本当だったんだなw
なにかコンプレックスでもあるのか?w
763nobodyさん:2008/04/30(水) 20:52:21 ID:???
答えてもらえなかった途端煽りに走るとかゆとりの典型
ガキ向けのスレじゃないのでお帰り下さい

以下何事もなかったかのようにどうぞ
764nobodyさん:2008/04/30(水) 20:54:01 ID:???
もうね、顔が真っ赤になってますよね
765nobodyさん:2008/04/30(水) 20:56:39 ID:???
phpで乳首タブルクリックしたらエロサイト立ち上がる関数はありますか?
また自作する場合どのような点を気をつければいいか教えてください。
766nobodyさん:2008/04/30(水) 20:57:45 ID:itZeUQTn
答える気もないのに、上から仕切るなよ。
そっちこそ知らないなら最初から無視しろよ。

「まず気持ちよくしてもらわないと、僕おしえてあげないよ」ってか?

ここあんたの所有か?勘違いもここまでくるとほんとに気持ち悪いな。
どこにでもいるんだなこういう人間って。
767nobodyさん:2008/04/30(水) 21:05:12 ID:???
768nobodyさん:2008/04/30(水) 21:06:06 ID:???
どっちが勘違いなんだか
2chだから何でもありとかどんだけゆとり脳なんだよ
人に物を聞くときは態度をわきまえるのは実社会でもネット社会でも同じ
スレのルールは>>1に明示されいるとおり
理解できるまで>>1を読み返したあと巣に帰れ
769nobodyさん:2008/04/30(水) 21:07:45 ID:???
質問の態度を指摘された時点で、素直に謝って、質問しなおしてればよかったのに。

・ 質問者として、態度をわきまえること。
770nobodyさん:2008/04/30(水) 21:09:16 ID:???
>>767の優しさに嫉妬
771nobodyさん:2008/04/30(水) 21:15:46 ID:???
このスレはこの程度か
どうもありがとうございました
772nobodyさん:2008/04/30(水) 21:21:27 ID:???
どこもこの程度ですよ
こちらこそありがとうございました
773鯖術:2008/04/30(水) 21:43:18 ID:???
>>753
ありがとうございました。
次なのですが、ディレクトリをパーミッション737で作成して、FTPをログアウトしたら、再度ログインした際に、パーミッションが755に勝手になるのは、xreaだからですか?
分かる方お願いいたします
774nobodyさん:2008/04/30(水) 22:17:09 ID:???
>>771
俺が最初に言った言葉なんだけどマネしないでくれる?
775nobodyさん:2008/04/30(水) 23:38:16 ID:???
質問させていただきます。

【前提条件】
・各種レンタルサーバでの動作を想定しているため、多くのサーバが
 対応していると思われるPHP4での動作を想定
・仕様の都合上、サーバの設定はいじらない

(続く)
776nobodyさん:2008/04/30(水) 23:39:23 ID:???
(続き)

【問題その1】
設定ファイルを以下の方法でプログラム上で作成するのですが、
あるサーバ(以後「相手サーバ」)で、このファイルが所有者nobodyとなり
ffftpでのファイルのダウンロードや削除ができないようです。

[ソース]
if(!file_exists([ファイルパス])){
//書き込む内容を定義
$writeStr = "〜〜〜〜〜〜";

//ファイルを作成し、パーミッションを変更
touch([ファイルパス]);
chmod([ファイルパス],0666);

//ファイルに書き込み
$fp = fopen([ファイルパス],"w");
flock($fp,2);
fwrite($fp,$writeStr);
fclose($fp);
}

(続く)
777nobodyさん:2008/04/30(水) 23:39:55 ID:???
(続き)

ちなみに私がテストで使用しているロリポップのサーバ(以後「自サーバ」)
では、ファイル所有者が「apache」になりffftpでのファイル操作も
問題なく行えます。

相手サーバは直接確認できていないので、詳細はわかりませんが、
おそらくnobodyにchmodの実行権限がないためかと思われます。

前提条件にあるように、サーバの設定をいじれないため、プログラムのみで
これを動作可能にする方法があれば、教えていただきたく思います。

無理なようなら、空の設定ファイルをffftpでサーバに上げ属性変更を行う
という対応を考えていますが、可能な限り自動で行いたいです。

(続く)
778nobodyさん:2008/04/30(水) 23:40:19 ID:???
(続き)

【問題その2】
このプログラム、
・利用者に動作しているのを意識させない
・ブラウザを閉じられても動作を終了しない
という動作を行うようになっています。

現時点では以下のように実装してあります。

[execute.php]
<?php
System("php [実際の処理を行うPHPのパス] > /dev/null &");
?>

[HTMLファイル(該当箇所のみ抜粋)]
<iframe src="execute.php" style="display: none;">
</iframe>

こちらも自サーバでは動作を確認していますが、相手サーバでは動かないようです。

本来cronを使うべきなんでしょうが、これも前提条件のため、この方法で
実現しています。

何かよい解決策があれば教えていただけると幸いです。
779nobodyさん:2008/04/30(水) 23:50:25 ID:???
780nobodyさん:2008/04/30(水) 23:50:49 ID:???
処理を指定した行かラベルに飛ばしたいのですが、どうすればいいのでしょうか?
検索しても調べ方が悪いのかまったくヒットしませんでした。
781780:2008/04/30(水) 23:52:06 ID:???
文章だとわかりにくいですね。要は

A地点
echo "A地点を通過"
B地点
echo "B地点を通過"
C地点
echo "B地点を通過"

というプログラムで、A地点の中にC地点までジャンプさせる命令をしたいんです。
782 ◆butDCCtu7M :2008/05/01(木) 00:06:48 ID:???
>>779
775〜778です。
すみません、見落としていました。

使用するサーバはLinuxだと思われますが、あちこちのレンタルサーバでの
動作を想定しているため、Webサーバ、PHPバージョンは不特定です。
(PHPファイル自体を配布して使用してもらうようになっているため)

可能な限り多くのサーバで動くようにしたいです。

テストに使っている自サーバはロリポップで契約したレンタルサーバです。
LinuxでWebサーバはApacheですが、バージョンはどこで見るのか……
PHPはver.4.4.6だそうです。

ただこの自サーバではうまく動作していて、問題は相手サーバなのですが、
相手サーバのほうの環境は把握できていません。

これで回答お願いできないでしょうか?
783nobodyさん:2008/05/01(木) 00:20:11 ID:lhcqDE2k
素人ですがどなたか教えて下さい。

フォーム(TEXTAREA)を入力し、確認ボタンを押すと確認画面に行き、戻るボタンを押すと
元の入力画面に戻るようにしています。入力画面に戻ったとき、直前に入力した内容を表示
させたいので、最初は<INPUT type='button' value=' 戻る ' onclick='history.back()'>
で戻らせていました。しかし、その後セッション管理を追加したところ、入力内容が保持さ
れなくなってしまいました。
そこで素人ながら色々考えて、hiddenでTEXTAREAの内容を受け渡してみたのですが、入力内容
に改行があると画面がおかしくなります。(戻るボタンや改行以降の内容がずれて表示されます。)
しかも、受け渡された内容は改行よりも前の文字しか入っていません。


■確認画面
$textdata = htmlspecialchars(stripcslashes($textdata));
$body .= "<FORM action='$PHP_SELF' method='POST' enctype='multipart/form-data'>
<INPUT type='submit' onSubmit='FldChk()' value=' 戻る '>
<INPUT type='hidden' name='textdata' value=$textdata>
</FORM>";

入力内容に改行が入っていると、これを表示した時点で戻るボタンの横に改行
された内容が表示されたりします。


■入力画面(戻ったとき)
$textdata = htmlspecialchars(stripcslashes($textdata));
$body .= "<TEXTAREA COLS=82 ROWS=15 NAME=textdata>$textdata</TEXTAREA>";
$textdataには、改行より前の文字のみ入っています。

入力→確認画面→戻る という画面構成はよくあると思うのですが、一般的には
どのように制御しているのでしょうか?hiddenとか使わなくても良い方法がある
のでしょうか?よろしくお願い致します。
784nobodyさん:2008/05/01(木) 00:26:53 ID:???
なんか宿題がまざってきたな
785nobodyさん:2008/05/01(木) 00:32:11 ID:???
>>782
>>11

>>1のトリップ出せって言うのは勝手に付け加えられた文言で
スレ的に質問者はageてちゃんとID出さないと答えてもらえないことになっている
1日に同じ質問を何回してもいいので(ただし小出しよりはまとめて質問すべし)IDは必ず出してくれ
786 ◆butDCCtu7M :2008/05/01(木) 00:36:37 ID:LcM9SKUi
>>785
ご指摘ありがとうございます。了解しました。
ageて再度質問いたします。
小出しというか、入力文字数制限で入りません。

質問させていただきます。

【前提条件】
・各種レンタルサーバでの動作を想定しているため、多くのサーバが
 対応していると思われるPHP4での動作を想定
・仕様の都合上、サーバの設定はいじらない

(続く)
787 ◆butDCCtu7M :2008/05/01(木) 00:37:50 ID:LcM9SKUi
(続き)

【問題その1】
設定ファイルを以下の方法でプログラム上で作成するのですが、
あるサーバ(以後「相手サーバ」)で、このファイルが所有者nobodyとなり
ffftpでのファイルのダウンロードや削除ができないようです。

[ソース]
if(!file_exists([ファイルパス])){
//書き込む内容を定義
$writeStr = "〜〜〜〜〜〜";

//ファイルを作成し、パーミッションを変更
touch([ファイルパス]);
chmod([ファイルパス],0666);

//ファイルに書き込み
$fp = fopen([ファイルパス],"w");
flock($fp,2);
fwrite($fp,$writeStr);
fclose($fp);
}

(続く)
788 ◆butDCCtu7M :2008/05/01(木) 00:38:49 ID:LcM9SKUi
(続き)

ちなみに私がテストで使用しているロリポップのサーバ(以後「自サーバ」)
では、ファイル所有者が「apache」になりffftpでのファイル操作も
問題なく行えます。

相手サーバは直接確認できていないので、詳細はわかりませんが、
おそらくnobodyにchmodの実行権限がないためかと思われます。

前提条件にあるように、サーバの設定をいじれないため、プログラムのみで
これを動作可能にする方法があれば、教えていただきたく思います。

無理なようなら、空の設定ファイルをffftpでサーバに上げ属性変更を行う
という対応を考えていますが、可能な限り自動で行いたいです。

(続く)
789nobodyさん:2008/05/01(木) 00:39:01 ID:0ps46wqd
setlocaleで'ja_JP'なり'Japanese_Japan'なりした時に
%a で曜日を出力する際、出力される文字コードはどこで設定されるん?
なんかwindowsだとcp932で固定っぽいんだけどどうなの?
790 ◆butDCCtu7M :2008/05/01(木) 00:39:39 ID:LcM9SKUi
(続き)

【問題その2】
このプログラム、
・利用者に動作しているのを意識させない
・ブラウザを閉じられても動作を終了しない
という動作を行うようになっています。

現時点では以下のように実装してあります。

[execute.php]
<?php
System("php [実際の処理を行うPHPのパス] > /dev/null &");
?>

[HTMLファイル(該当箇所のみ抜粋)]
<iframe src="execute.php" style="display: none;">
</iframe>

こちらも自サーバでは動作を確認していますが、相手サーバでは動かないようです。

本来cronを使うべきなんでしょうが、これも前提条件のため、この方法で
実現しています。

何かよい解決策があれば教えていただけると幸いです。
791nobodyさん:2008/05/01(木) 00:39:41 ID:???
>>789また昨日のおまえか
792 ◆butDCCtu7M :2008/05/01(木) 00:40:24 ID:LcM9SKUi
【補足】

使用するサーバはLinuxだと思われますが、あちこちのレンタルサーバでの
動作を想定しているため、Webサーバ、PHPバージョンは不特定です。
(PHPファイル自体を配布して使用してもらうようになっているため)

可能な限り多くのサーバで動くようにしたいです。

テストに使っている自サーバはロリポップで契約したレンタルサーバです。
LinuxでWebサーバはApacheですが、バージョンはどこで見るのか……
PHPはver.4.4.6だそうです。

ただこの自サーバではうまく動作していて、問題は相手サーバなのですが、
相手サーバのほうの環境は把握できていません。

これで回答お願いできないでしょうか?
793ID出します:2008/05/01(木) 00:41:35 ID:Qhoj/T/S
処理を指定した行かラベルに飛ばしたいのですが、どうすればいいのでしょうか?

A地点
echo "A地点を通過"
B地点
echo "B地点を通過"
C地点
echo "B地点を通過"

というプログラムで、A地点の中にC地点までジャンプさせる命令をしたいんです。
794nobodyさん:2008/05/01(木) 00:48:19 ID:???
>>792
サーバのバージョンが違うだけでそうそうプログラムが180度違う処理をすることなんてないんじゃない
PHPのバージョンなら4にあわせてコード書くとかマジッククォートの設定の有無に左右されないようにコードを書く
あとglobalなんとかってやつは対応するかしないかはあらかじめ決めたほうが良い

で、問題1のファイルが削除できない件は、ローカルでファイルを作ってそれをサーバにアップしたら削除できるんじゃない
795nobodyさん:2008/05/01(木) 00:51:31 ID:???
>>783
よくわからんけど、そういうときは対象のファイルの<body>タグのスグしたあたりに
以下を出力してデータを確認してみれ

echo "<pre>";
echo "ポストデータ";
print_r($_POST);
echo "セッションデータ";
print_r($_SESSION);
echo "</pre>";
796nobodyさん:2008/05/01(木) 00:55:13 ID:???
>>793
HSPのgoto文みたいなことがやりたいのかわからんが

switch ($_POST['key']) {
case "a":
a();
break;
case "b":
b();
break;
case "c":
c();
break;
}

function a() {
echo "aの処理";
}

function b() {
echo "bの処理";
}

function c() {
echo "cの処理";
}
797789:2008/05/01(木) 00:55:17 ID:0ps46wqd
>>791
ID:itZeUQTn?のことでしょうか?
すいません、証明は出来ませんがそれは私ではありません。
失礼いたしました。

PHP 5.2.3 CLI
Windows XP SP2
以上の環境で

mb_internal_encoding('UTF-8');
mb_http_output('cp932');
ob_start('mb_output_handler');
setlocal(LC_ALL, 'Japanese_Japan');

とした場合、
strftime('%a');
とすると日本語での曜日が出力されるのですが
strftimeの出力がsjisになっているようで文字が化けてしまいます。
strftime -> (1. sjis) -> mb_output_hander -> (2. utf8) -> 出力
※2. の部分で化ける

strftimeの出力する日本語文字コードを変更したいのですが
どのようにすればよいのでしょうか?
また、変更は出来るのでしょうか?
798 ◆butDCCtu7M :2008/05/01(木) 00:56:04 ID:LcM9SKUi
>>794
回答ありがとうございます。

サーバのバージョンはさほど気にしなくてもよいということですね。
コードはPHP4に合わせて書いております。(テスト環境もPHPはver.4.4.6)

問題1の件は>>788の最後で書いてあるように、想定はしているのですが、
利用者が操作せずに行えるのならそうしたいとの要望があり、プログラム上で
実現できる可能性を質問した次第です。

読解力がなくて申しわけありませんが、「globalなんとか」っていうのは
どの部分への回答でしょうか?
799nobodyさん:2008/05/01(木) 00:59:19 ID:???
cp932ってsjisを拡張したものだから・・
800nobodyさん:2008/05/01(木) 01:02:13 ID:???
>>790
設定ファイルがなんの設定ファイルなのかわからないけど
PHPからは、環境変数からどこまでの権限を自分が持ってるかを
知る事はできても権限を越えることは無理だから無理。

出来ることは、環境変数しらべて、条件があわなかったら
お使いのサーバーは条件を満たしておりませんのエラーで終了。
801nobodyさん:2008/05/01(木) 01:03:12 ID:???
>>797
あとできないことはないが変換ライブラリなんか利用したほうが楽
rubyだとこんなやつ
ttp://jp.rubyist.net/magazine/?0009-BundledLibraries#l24
802nobodyさん:2008/05/01(木) 01:06:56 ID:???
>>798
ファイルをサーバ側で作るんじゃなくて、ローカルからサーバにうpしたほうがいいよ
803nobodyさん:2008/05/01(木) 01:08:00 ID:???
>>797
mb_internal_encoding('UTF-8');
mb_http_output('cp932');
ob_start('mb_output_handler');
setlocal(LC_ALL, 'Japanese_Japan');

の条件ならcp932で出力されるのは当たり前だと思うけど?
なんでutf-8で出ると考えてるの?
804 ◆butDCCtu7M :2008/05/01(木) 01:08:34 ID:LcM9SKUi
>>800
回答ありがとうございます。
無理ですか……残念です。
問題1の方はftpでのアップロードで行うことにします。
805nobodyさん:2008/05/01(木) 01:10:02 ID:Qhoj/T/S
>>796
なるほど、switchを使うんですか。
ありがとうございました。
806789:2008/05/01(木) 01:13:56 ID:0ps46wqd
>>799
はい、それは把握しています

>>801
出来ないことはないとはどういうことでしょうか?
大元の定義ファイルがあり、それの文字コードを変換してからコンパイルし直す
といった類のやり方でしょうか。
動的に変更出来ないのであれば諦めますが
可能性があるならヒントでも頂けると助かります。

>>803
mb_output_handlerの部分で ( utf8 -> cp932 ) 変換が掛かるのですが
strftime からの出力は cp932 なので
cp932をutf8としてcp932に変換するので文字が化けてしまいます。
書き方がわかりにくかったですね。
すいません。

>>798
4.2.0以前ではデフォルトでOnになっている設定のことだと思われます。
http://php.benscom.com/manual/ja/security.globals.php
807789:2008/05/01(木) 01:29:22 ID:???
ああ、わかりました。
windowsだと日本語のロケールが一つしかないんですね。
Unix系だとja_JP.SJISなりeucJPなりUTF-8なりで対応すると。
ありがとうございました。
808nobodyさん:2008/05/01(木) 01:31:33 ID:???
>>806

つiconv

これでできなければそれ以外のやりかたは知らない
809nobodyさん:2008/05/01(木) 02:03:18 ID:???
今更なのですがピュア中部の2ショットで、ログが残せて管理者が確認出来るタイプのCGIを探してます。
配布終了になってサイトも無いので、お持ちの方はいらっしゃらないでしょうか?

# 2SHOT-RIGHT v1.02 (フレーム専用、sjis用) <FreeSoft>
#
# by RIGHT http://herz.pobox.ne.jp/cyder/doc/right_top.htm

# Original Script "2SHOT-CHAT version 4.1"
# By RESCUE www.rescue.ne.jp
これを今使ってるのですが、前メッセージが残っていたりと微妙に使いにくいのです。
ほかに2ショットでチャットログを残せるタイプのものは無いでしょうか?
810nobodyさん:2008/05/01(木) 03:02:47 ID:jmqAlJjw
携帯サイトでよくあるPHPのログインをどうやったら破れるか考えて
いるのですが、外部からログファイルを取得するしか方法はありませんか?
811nobodyさん:2008/05/01(木) 04:18:34 ID:???
>>810
犯罪に荷担してしまう可能性のあるご相談はお受けすることができません
ご了承ください
812nobodyさん:2008/05/01(木) 07:41:32 ID:???
$a = 0;
class HOGE
{
    var $a = $a;
}
これって通らないの? なんで? クソ言語過ぎない?
813nobodyさん:2008/05/01(木) 07:45:31 ID:???
お前は何を言ってるんだ
814810:2008/05/01(木) 08:49:53 ID:Bd+Jl0DJ
>>811
それでは1つ教えてください!
自分なりには入力された文字をテキストファイルなどの形式でサーバーに送って
それをログファイルと比較しているのかなと思ってます。
それでサーバーにアクセスするにはどうすればいいのか
アクセスしたところで拒否されないだろうかと考えています。
この仮説は正しいですか?
815nobodyさん:2008/05/01(木) 08:55:45 ID:???
犯罪に荷担してしまう可能性のあるご相談はお受けすることができません
ご了承ください
816nobodyさん:2008/05/01(木) 08:58:50 ID:Bd+Jl0DJ
>>815
しつこくて申し訳ありません。他人に頼らず自力で勉強するしかないということですね。ありがとうございました。
817nobodyさん:2008/05/01(木) 13:04:01 ID:???
>>816
私怨たっぷり3流クラッカーさんですね、わかります
818nobodyさん:2008/05/01(木) 13:28:42 ID:???
一応書いておきます

ブルートフォースアタックをかける結論に至ると思いますが、
対象サーバのアクセスログに著しく情報が残る+その結果対策もとりやすいため、
パスワード解析以前にすぐバレてお縄になってしまうでしょう

したがって、潔く諦めることをお勧めします >>816
819nobodyさん:2008/05/01(木) 13:56:12 ID:???
ID:Bd+Jl0DJよ
貴様が厨房であることは分かったからさっさとこのスレからうせろ
820nobodyさん:2008/05/01(木) 14:18:34 ID:???
>>812
これは釣りだよな?どの言語のクラスでもこんな書き方しないだろ。
821nobodyさん:2008/05/01(木) 15:31:12 ID:???
動的にクラスを生成するのをよくやる言語や環境ならやるかも。
822nobodyさん:2008/05/01(木) 18:33:46 ID:???
質問がないとひまだお
823nobodyさん:2008/05/01(木) 19:13:28 ID:???
うーん、いまのとこないw
824nobodyさん:2008/05/01(木) 19:38:05 ID:???
じゃ質問置いておきますね
http://pc11.2ch.net/test/read.cgi/php/1164731497/
825816:2008/05/01(木) 19:42:34 ID:Bd+Jl0DJ
自己解決しました。なんとかサーバーにアクセスしてもcryptされていたらダメなんですね。
やっとこの関数の重要性を理解しました。
結局ブルートフォースしかないんですね。
826nobodyさん:2008/05/01(木) 19:44:59 ID:???
>>825
未来の犯罪者乙
827816:2008/05/01(木) 20:06:55 ID:Bd+Jl0DJ
怒られない程度に遊びたいだけで、三流クラッカーにさえなれない厨房です。
828nobodyさん:2008/05/01(木) 20:07:19 ID:???
>>827
死ねクソガキ
829nobodyさん:2008/05/01(木) 20:15:14 ID:???
4桁パスワードの掲示板で、手動で総当りアタックでもやればいいじゃない

830nobodyさん:2008/05/01(木) 20:19:19 ID:???
831nobodyさん:2008/05/01(木) 20:21:37 ID:???
まだいたのですね…
ブルートフォースアタックについて補足します

昨今の Firewall は統合型のものが多く、
侵入検知、自動防御などの機能が同居していることがほとんどです

外部から調査しても一見すると Firewall がないように感じる場合がありますが、
Stelth 機能を使って Firewall を隠蔽するような、無いように振る舞っているだけです

したがって、どこの企業、組織、レンタルサーバ類でも確実にログが採取されており、
ブルートフォースのようなことをしかければ確実に足跡を追跡できると覚えておいてください

つまり、潔く諦めることをお勧めします >>816=825
832nobodyさん:2008/05/01(木) 20:23:17 ID:???
まあ、やらせといて捕まってもらえるほうがうれしいけどね
厨房は生きる価値ないから
833nobodyさん:2008/05/01(木) 20:26:49 ID:???
4桁のパスワードか。

数字10個、アルファベット26個×2(大文字小文字)で62個の場合で考えると
総当りで14776336パターン。

俺が作ったシステムは、一回のパスワード認証で
一秒ウェイトを入れているから最悪でも171日で突破できるな。
記号も考慮すると1年ぐらいか。

だから何?といわれても困るがw
834nobodyさん:2008/05/01(木) 20:55:07 ID:???
短時間に認証エラーを繰り返したIPはブラックに自動登録、
以降のアクセスは警視庁・インターポールにリダイレクトしてる漏れは天才。
835nobodyさん:2008/05/01(木) 21:05:11 ID:???
>>833
そういうのが Firewall にとっては最も検知しやすかったりします

スレ違いな話題だし、問題児はそろそろネットワーク板にでも誘導するか…('A`)
836nobodyさん:2008/05/01(木) 21:18:32 ID:???
最近はログイン条件にパスの他にプロバイダ入れるのが主流だな。
国内の特定のプロバイダからしかアクセスできないようにしておけば
万が一の時もすぐタイーホ。

銀行なんかは重要な手続きは携帯からやらせて、
端末ID使ってる所もあるね。
837nobodyさん:2008/05/01(木) 22:44:33 ID:???
主流・・・なのか?
838nobodyさん:2008/05/01(木) 23:10:15 ID:???
ログイン情報って無駄なものを入れないためにいつも1っていれて判断してたけど
プロバイダいれるメリットは?
839nobodyさん:2008/05/01(木) 23:36:23 ID:???
主流かどうかは知らんが、アカウントに許可IPアドレスを設定するのは普通にある
メジャーなプロバイダならログもちゃんと管理してるだろうから、パスワード漏れ等でログインされても
追いやすいって話じゃね

つうか1で判断ってセッションハイジャック防止とかノーガードか?
840nobodyさん:2008/05/02(金) 00:09:18 ID:???
国内の特定のプロバイダからしかアクセスできないようにする
大変すぎだろ?

海外からのアクセスなんて当たり前にあるし、
プロバイダが増えたり減ったりしたらどうするんだ?

個人ブログじゃないんだしさ。
841nobodyさん:2008/05/02(金) 00:09:57 ID:???
>>839
セッションハイジャックおこるの?
842nobodyさん:2008/05/02(金) 00:16:59 ID:???
>>840
認証ページ(ディレクトリ)だけにアクセス制限をかければいいだけですよ
843nobodyさん:2008/05/02(金) 00:32:23 ID:ESOY+ESo
うまくすりぬける人はパスワードなんか無視してURLをゲットするの?
844nobodyさん:2008/05/02(金) 00:53:26 ID:???
>>842
だからそれじゃ特定のプロバイダ人しか
認証できないだろ。

それに悪意のある人間が日本国内から
アタックしたらどうするんだ?

意味無いじゃんか。
845nobodyさん:2008/05/02(金) 01:39:52 ID:71gb5g2D
遅レスだけど

>>654
えー!!!!こんなことできんの!?
プログラムはCから覚えた俺には強烈な型柔軟性に吃驚だよぅ
846nobodyさん:2008/05/02(金) 01:47:50 ID:???
おまえらプログラムもいいがたまにはオンゲーでもしようぜ
対人がおもしろいMMOだから遊びにおいで

ロストオンライン
http://game13.2ch.net/test/read.cgi/mmo/1209016763/
847nobodyさん:2008/05/02(金) 02:11:59 ID:???
>>846
なんでチョンゲーなん?
848nobodyさん:2008/05/02(金) 02:27:27 ID:???
C言語でも、同じようなことはできるがな。
849nobodyさん:2008/05/02(金) 02:28:24 ID:???
>>845
ほんとにCやった?
850nobodyさん:2008/05/02(金) 02:30:10 ID:???
C言語に文字の配列はあっても文字列変数なんて概念はないぞ
ましてそれをインクリメントなんてできんの?
851nobodyさん:2008/05/02(金) 02:33:25 ID:???
文字列をそのままできなくても文字のインクリメントはできる。
852nobodyさん:2008/05/02(金) 02:37:09 ID:???
文字列のインクリメントができるのが驚きなんじゃないか
さらに言えばCは文字のインクリメントができるんじゃなくて
文字コードを数値としてインクリメントができるだけだし

ってまあスレ違いだからどうでもいいか
853nobodyさん:2008/05/02(金) 02:55:18 ID:???
話してる内容自体には個人的には賛成なんだが

散々自分の意見言っといて
最後に「スレ違いだからここまで」って
典型的な荒らしの書き方じゃないか。
854nobodyさん:2008/05/02(金) 04:20:13 ID:???
スレチは他所で。
まともな意見だと思うがな。
855nobodyさん:2008/05/02(金) 05:29:35 ID:???
コンパイラとインタプリタをの優劣を論じても意味はない。
スレチ以前の話。
856nobodyさん:2008/05/02(金) 10:02:15 ID:???
上で出ているPHPの認証画面とは任意の人間に認証させるようなページ?
わたしは管理者だけが認証できればよいと理解していました

何らかのサービスを管理するための認証画面だと思っていたのですが
例えば、掲示板の書き込みを一括削除したり等する画面への認証など

であれば、管理者だけが管理画面に対して認証できればよいだけなので、
特定のRemote host(日本国内の限定されたISP)からのアクセスのみを
.htaccessなどで許可しておけばさらに安心だと思うのですが
857nobodyさん:2008/05/02(金) 10:44:23 ID:???
phpって文字列に対して(int)とか、
不正なキャストを行った場合の処理ってどうなる仕様なのでしょうか?
858nobodyさん:2008/05/02(金) 11:07:54 ID:???
マヌアルの中からあなたのかわりに探してあげたよ!
http://jp.php.net/manual/ja/language.types.integer.php#language.types.integer.casting
859nobodyさん:2008/05/02(金) 13:06:24 ID:???
うむ、ごくろう。
860nobodyさん:2008/05/02(金) 15:22:43 ID:eCOkp8a7
変数名に変数を使うことって出来ないのでしょうか?

$hoge = "bcd"
$a$hoge = "abcd"

だとしたら、
$hogeの内容が変数名に代入されて

$hoge = "bcd"
$abcd = "abcd"

となるようにしたいのですが・・・やっぱ無理でしょうか?
別の方法があれば教えてほしいです。
861nobodyさん:2008/05/02(金) 15:28:29 ID:???
あまり薦めないけど

$hoge = "bcd";
eval( "\$a$hoge = \"abcd\";" );

echo $abcd . "\n";
862nobodyさん:2008/05/02(金) 15:54:35 ID:???
evalなんぞ使わなくても
${'a'.$hoge} = 'abcd';
863nobodyさん:2008/05/02(金) 16:00:10 ID:???
>>862
なるほど、中括弧で括るのですか。
ありがとうございました。
864nobodyさん:2008/05/02(金) 16:00:44 ID:???
>>860
可能だがしかしそれどんな設計だよ
865nobodyさん:2008/05/02(金) 16:38:44 ID:1oP7bnHx
変数名に変数ねぇ。
やろうと思ったことすらない。 難読化に役立つんじゃねぇかなぁ。
866nobodyさん:2008/05/02(金) 16:43:12 ID:???
変数名に変数か、考えた事すら無かったわ
867nobodyさん:2008/05/02(金) 16:53:31 ID:???
同じく変数に関する質問なのですが、
「echo "あいうえお"; echo $ABC; $A=$C+$D」というプログラムをひとつの変数に収めることって出来ないんでしょうか?
868nobodyさん:2008/05/02(金) 16:55:06 ID:???
869nobodyさん:2008/05/02(金) 16:58:20 ID:???
>>868
氏ね
870nobodyさん:2008/05/02(金) 16:59:11 ID:???
志村〜
871nobodyさん:2008/05/02(金) 17:08:21 ID:???
>>867
$foo = 'echo "あいうえお"; echo $ABC; $A=$C+$D;';

で、なにがしたいんだ?
872nobodyさん:2008/05/02(金) 17:23:51 ID:???
「eval したいんです!」
「だからなんで eval が要るんだ?」
「使ってみたいだけなのに、なんで要るのか訊かれても…」

こんな感じじゃないのかな。
873nobodyさん:2008/05/02(金) 17:36:09 ID:???
変数名に変数、普通に使ってますが・・・だめですか・・
874nobodyさん:2008/05/02(金) 17:51:53 ID:???
普通は連想配列(PHPだと配列と区別ないが)を使って $a[ $hoge ] = "abcd"; とか書く
変数名に変数を使うと便利な状況が思いつかない
875nobodyさん:2008/05/02(金) 17:56:08 ID:???
こういうのは実際に"便利な状況"に遭遇してから分かるのであって、
初めから頭で考えても思いつかないだろ
876nobodyさん:2008/05/02(金) 18:19:24 ID:nE3gn/Rr
Perl 関係のスレにも ${$varname} したい人がときどき来るんですけど
自分も>>874な感覚で $array[$key] (PHP) / $hash{$key} (Perl) で済むように
思うことが多いなあ。${$varname} したい状況がわからない。

でも、言語仕様としては用意されてるから駄目ではないし(…です。>>873
今の自分は「C のポインタって何が便利なんすか?」って人と変わらん状態なのかな。
877nobodyさん:2008/05/02(金) 18:52:31 ID:???
うん、みんなが優しいのは分かったけど、
例外を作りつづけてもよくないと思うぞ?

>>1
・偽者防止に必ずIDを表示(メール欄に何も記述しない)、若しくはトリップをつける事。

質問者も質問するなら最低、
テンプレにくらい目は通そうぜ?
878nobodyさん:2008/05/02(金) 18:52:59 ID:???
うぅ〜んまんだむ!
879nobodyさん:2008/05/02(金) 18:55:26 ID:???
GETでもPOSTでも動くように可変変数使って書いたことがあるけど
それが最初で最後だなぁ
880nobodyさん:2008/05/02(金) 19:20:38 ID:???
>>879
それは、二行にすりゃいいんじゃw
881nobodyさん:2008/05/02(金) 21:02:31 ID:CcSXHmXb
動的に関数を定義するにはどうしたらいいですか?
882nobodyさん:2008/05/02(金) 21:03:05 ID:???
if(){
function b(){}
} else {
function a(){}
}
883ぬるぽ(^^)/:2008/05/02(金) 21:37:24 ID:???
PHPで、どんなセキュホがあれば、スクリプトみられたり するんですか?
教えて下さい。
http://z-z.jp/
なんでここはスクリプトみられてるのですか
教えて下さい
884nobodyさん:2008/05/02(金) 21:43:28 ID:???
phpじゃないじゃん
885nobodyさん:2008/05/02(金) 21:48:36 ID:???
そこのスクリプトの見方を教えてくれれば、
PHPのも教えてあげるよ
886nobodyさん:2008/05/02(金) 21:51:44 ID:???
>>883,>>885
さあ厨房は帰った帰った
887nobodyさん:2008/05/02(金) 22:47:59 ID:vDcZA+4C
おまえら友達居ないだろ?
888nobodyさん:2008/05/02(金) 22:57:12 ID:???
>>887
自分を攻撃すると意味の分からない話にもってくゆとり乙
889nobodyさん:2008/05/02(金) 23:00:15 ID:vDcZA+4C
>>888
俺はたしかにゆとり教育受けてるが、おまえみたいに友達いないよりはマシだ。
こんなところにずっと張り付いてて楽しいか?
890nobodyさん:2008/05/02(金) 23:01:31 ID:???
>>889
会ったことも無いのに友達がいないといえるところがゆとりだな
891nobodyさん:2008/05/02(金) 23:08:42 ID:???
友達いないけど彼女いるから
892nobodyさん:2008/05/02(金) 23:49:49 ID:???
そこは PHP 使われていないですよ

スレ違いだから↓あっちで聞きなさい!

くだすれPerl(超初心者用)2
http://pc11.2ch.net/test/read.cgi/php/1204488452/
893nobodyさん:2008/05/03(土) 00:38:01 ID:cJNbL5n/
php 5.2.3 windows xp sp1 apache2な環境ですが
コマンドラインの php -l ファイル名 と同じ動作をする php 関数かなんかはないでしょうか。
プライベート用のテスト鯖でDBにソースを保存して簡易CMS的に使おうと考えており
DBに保存する前にソースが動くかどうかの確認をしたいのです。
894ぬるぽ(^^)/:2008/05/03(土) 00:55:21 ID:???
PHPで、どんなセキュホがあれば、スクリプトみられたり するんですか?
教えて下さい。
http://z-z.jp/
なんでここはスクリプトみられてるのですか
教えて下さい
895nobodyさん:2008/05/03(土) 01:06:37 ID:???
>>894
そこにPHPは使われていません
Perlが使われています

下のところ↓で聞いてください

くだすれPerl(超初心者用)2
http://pc11.2ch.net/test/read.cgi/php/1204488452/
896nobodyさん:2008/05/03(土) 01:06:55 ID:???
>>894
氏ねゆとり
897nobodyさん:2008/05/03(土) 01:17:15 ID:3FEggVxI
ブログのテンプレートでよく見かける
<a href="{$BBSPATH}">掲示板トップ</a>
のようなことをしてデザインとプログラムを分けたいのですが、
どのような仕組みで作ればいいのでしょうか?
898nobodyさん:2008/05/03(土) 01:29:10 ID:???
正規表現を覚えて\{(\$[A-Za-Z_-]+)\}でマッチングさせて\1で
帰ってきた変数名で、その部分を置き換える。


っていうのは#FF0000なFALSEで、何も考えずにincludeして使えば良い。
{$変数}の"{"と"}"は、周りの文字にくっつかない為の方法で表示はされない。
単に変数埋め込んでるだけ。
899nobodyさん:2008/05/03(土) 01:38:21 ID:3FEggVxI
>>898さんの説明が難しくて私には・・・まだやすぎるのかな・・・

自分なりに考えたのですがこういうやり方はどうなんでしょうか?
プログラムファイルからスキンファイルをfile_get_contentsで読み込んで、
str_replaceを使ってスキンファイルに書かれている変数(たとえば{BBSPATH}など)を置換。
っていうのはダメですよね・・
900nobodyさん:2008/05/03(土) 01:47:21 ID:???
>>899
それで問題ない
901nobodyさん:2008/05/03(土) 01:54:15 ID:???
ありがとうございます。この方法なら自分にもできそうなので取り組んで見ます
902nobodyさん:2008/05/03(土) 02:06:58 ID:???
・・・まだやすぎるのかな・・・
903nobodyさん:2008/05/03(土) 02:07:24 ID:???
file_get_contentsでやっても、evalすれば
$varは展開されるけど、それで出来るのは、単一の値を持つスカラーしか置き換えられないから
smartyみたいなのはstr_replaceとか正規表現使ってるっぽい気がする。

ソース見てないけどあれってifとか使えるし、<option>タグで
中身ぞろぞろ引き出せるんだよね?…ってやっぱevalでも出来るかな?
まあ、自分で置換すれば、<option>で項目が増減するのも
タグに独自ルール作って扱えるよね。

ちなみにZendFrameworkは普通に<?php ?>だよ
<?php if(hoge): ?>
<?php endif; ?>って{}使わない方のもう一つのifの書き方を
使ってるのが見やすくてなるほどと思った。

常に表示枠固定じゃない限り、foreachはどうしても
使うことになると思うし、それ考えるとZendのやり方が良いと思う。
904903:2008/05/03(土) 02:13:06 ID:???
ごめん、開始タグと終了タグあるのはstr_replaceじゃ無理だ。
単に置き換えるだけなら出来るけど、それならevalした方が断然良い。
やっぱ正規表現必要。
905nobodyさん:2008/05/03(土) 02:18:04 ID:???
>>901
PHPBlosxomとか参考にすれば?

ttp://sourceforge.net/projects/phpblosxom/
906nobodyさん:2008/05/03(土) 04:22:31 ID:Bi5B2zuj
>>891
>友達いないけど彼女いるから
ワラタwww彼女いる事自体はなんの自慢にもなんないだろwww
妥協すればだれでもできるwww
907nobodyさん:2008/05/03(土) 08:52:05 ID:IxjoBmKw
preg_match("/<title>(.*)<\/title>/",$file_data,$file_title);

これで読み込んだファイル内のtitleタグのテキストを取得しています。
しかし、<title></title>の間に改行が入ると取得できなくなります。
改行が入っていても、取得するにはどうすればいいのでしょうか?
改行を削除する方法以外でお願いします。
908nobodyさん:2008/05/03(土) 09:18:15 ID:???
>>907

.
↑は改行を含んでませんよ
ちゃんと改行も含めないと
\nと.
909873:2008/05/03(土) 11:22:48 ID:???
遅レスだけど、変数名に変数を使うことってそんなに頻繁にはないけど
(言われてるように、連想配列で済む場合が多いから)
>>898みたいな正規表現と組み合わせる場合とか、変数と他の何かが
一定のルールで名称付けされてて、かつそれが膨大な量の時とか、
あとはリファレンス的に使ったりとか、そんな場合です。
これはPerlの時から使ってた。
確かにこれらの場合も、他のやり方とか、配列で済ませられるかもしれないけど、
簡単な方を選んでしまった。
910nobodyさん:2008/05/03(土) 11:45:38 ID:???
911nobodyさん:2008/05/03(土) 11:48:07 ID:???
てか普通にsmarty使えばいいんじゃね?って言うのはなしなの?
なんでわざわざ車輪を再発明すんの?
912nobodyさん:2008/05/03(土) 12:13:39 ID:???
phpのプログラマーって、論文とか書いたことがない奴ばかりか?

論理的思考もなく、単に関数と関数をパズルのような感覚でつなぎ合わせれば、
それなりのものが出来てきて、さぞ自分は有能なエンジニアだと錯覚を起こしているのではないですか?

有能か似非かを分ける方法は簡単。
設計書orテスト仕様書を書かせてみればすぐ分かる。
もっと言えば、作っているシステムを誰でも分かりように1枚の絵にまとめろ、という課題を出せばいい。

たちまち、化けの皮が剥がれる。
913nobodyさん:2008/05/03(土) 12:14:36 ID:???
掲示板のスキソのように使うまでもない小物とか、
テンプレートエンジンがない環境とか

実は俺もスキソのためにSmartyをダウソして中を見てみた訳だが、
何が何だかワケワカメだったw
914nobodyさん:2008/05/03(土) 12:45:58 ID:???
>>913
Smaryのコード自体は大してレベル高くないんだけどphp4仕様で書かれてるから非常に読みにくい
915nobodyさん:2008/05/03(土) 13:01:45 ID:???
メカニズムが車輪の再発明でも、雪道に強いタイヤとか
自分の欲しい物を作るのは、間違いじゃないと思うよ。

smartyみたいに、大した事出来ないのに無駄に大きいライブラリは
拡張するより、一から書いた方が早いだろうし。

今の風潮で何作るのにも出来合いのライブラリを使っていく発想だと
9割のクラスが使われないまま読み込まれていたりとかおかしな事になる。
916nobodyさん:2008/05/03(土) 13:10:32 ID:???
四角い車輪の再発明乙
917nobodyさん:2008/05/03(土) 13:13:26 ID:???
>>916
雑誌とかに惑わされずにsmartyの中見てみれば、
smarty自体が四角い車輪な事がすぐわかるはずだけど。
あれは、個人が適当に作ったのを公開してるのとレベルあまり変わらない。
918nobodyさん:2008/05/03(土) 13:16:04 ID:???
「見ればわかるはず論」はいらない。

理由を言え。
919nobodyさん:2008/05/03(土) 13:18:22 ID:???
php自体で書かれてるんだから見て分らないやつは使うな。
920nobodyさん:2008/05/03(土) 13:20:55 ID:???
>>919
そういう暇は無いんで、
どこを見ればよいかと、そこを教えてください。
921nobodyさん:2008/05/03(土) 13:22:46 ID:???
>>917
どの辺が?
922nobodyさん:2008/05/03(土) 13:36:47 ID:???
だから、君達は技術者じゃないだよ。単なる組み立て屋。
923nobodyさん:2008/05/03(土) 13:46:21 ID:???
>>922
だから聞いてます?どこがと聞いてんだけど。説明できないんだw
924nobodyさん:2008/05/03(土) 13:48:18 ID:???
書き方が凄く汚い。
$varへの代入とdefineの使い方が曖昧。
define使ってると思えば、弄る事の無いsmartyバージョンナンバー
$varに入れてるし。

php4で書かれてる時点でphp5からextendする気は起きないだろ。
smartyプラグインで決められたオレオレ使用にしたがってカスタマイズするか?

突っ込みどころは一杯あるけど、コード内にvimのタグ入ってる時点で、
書いてるやつが自分のためだけに作ってるオレオレエンジンだって気付けよ。
925nobodyさん:2008/05/03(土) 13:50:47 ID:???
お前ら暇だな!
926nobodyさん:2008/05/03(土) 13:52:14 ID:???
だが、これは
下らねぇ煽りあいはここに書き込みやがれ 1の序曲にすぎなかった
927nobodyさん:2008/05/03(土) 13:53:07 ID:???
>>924
書き方wwww
まぁな、書き方は目立つし突っ込みやすいからな。
928nobodyさん:2008/05/03(土) 13:55:48 ID:???
人が作ったコードを使うこと、いや使い方すらわからなくて人に聞いている状態なのに、
俺は技術者だと威張り腐っているって何?

人間として腐ってんじゃねーの?
929nobodyさん:2008/05/03(土) 14:09:44 ID:???
書き方が気に食わないっつー話かw
930924:2008/05/03(土) 14:17:25 ID:???
>>922
技術者だと威張ってる奴なんてどこにもいないだろw
ここにいるのは「パーソナルホームページ」を作ってる趣味人が大半だから
おちけつ。

彼らは、「お前は技術者じゃない」って言われても、困るだろ。
夕飯作ってる主婦にいきなり、「お前は料理人として失格だ」
って言ってるくらい暴言だ。
931nobodyさん:2008/05/03(土) 14:28:46 ID:???
技術者だからこそ人が作ったコードを使うんだけどなあ
趣味なら全部自前で書いていくら時間かけても楽しければいいけど
932873:2008/05/03(土) 14:28:52 ID:???
俺は一応技術者だけど、ほとんどライブラリは使ったことないな。
技術者としても会社の一員としても正しくないかもしれないけど、
やっぱ他の人が作ったものを心底信用することができないのと、
自分で開発するのが楽しいから。
ま、言っても全部自分でってわけにもいかないし、自分が作ったものが
完璧だとは断言できないけど、でもまぁ、そうやって成長していってるってのもある。
933nobodyさん:2008/05/03(土) 14:33:39 ID:???
       _, ,_
     <[;゚Д゚]> ア゙ー!? なんでおまいの楽しみや成長のために
      [_]     つかいづれえ心底信用できねえものを使わせられにゃならんのよ
      < > 
934nobodyさん:2008/05/03(土) 14:35:35 ID:???
ホントに会社の一員なのか?
いつも一人で開発してんのか?
935nobodyさん:2008/05/03(土) 14:43:31 ID:???
一画面いくらって感じの仕事ならともかく、もうちょっと複雑なシステムの開発になんかだと、
どれだけライブラリ化、ソースコードの再利用がされてるかは、かなり怪しい話題だと
思うけどなぁ。
936873:2008/05/03(土) 14:54:14 ID:???
>>934
一人で開発してる。ま、規模が小さいってのはかなりあると思う。
あと、もうできる限り一つ使わない理由としては、バージョン依存が怖いってのもある。
だから結局、自分でライブラリ開発してる。
937873:2008/05/03(土) 14:55:23 ID:???
スマソ、日本語かなりおかしくなってたw

×もうできる限り一つ使わない理由としては
○できる限り使わないもう一つの理由としては
938nobodyさん:2008/05/03(土) 15:01:09 ID:???
難しいことを行っても分からないようだから、
車のエンジンを開発するのがエンジニア、
車の部品を設計図に基づいて組み立てるのは組立工。

で、君達は、組立工に過ぎないということだよ。
939nobodyさん:2008/05/03(土) 15:02:36 ID:???
秋葉原で、パソコンのパーツを買ってきて組み立てて、
俺はパソコンを作れるなどと馬鹿丸出しで初心者に自慢しているのと同じだってこと。
そろそろ自覚しろよ。
940nobodyさん:2008/05/03(土) 15:16:15 ID:???
PM工程からUTくらいまでだけをやるのが組立工
PDまでとかもやるのがエンジニア
ライブラリとか関係ないから

君が煽りたいだけなのはよくわかった
GWで暇なら外に出るといいよ
941nobodyさん:2008/05/03(土) 15:23:13 ID:???
>>924
smartyのもっとワクワクするようなお話が聞けると思ったのに、
まことに残念無念。また無駄な時間を消費してしまった。
942nobodyさん:2008/05/03(土) 15:27:00 ID:???
>>940
俺が担当教官なら、お前は停学処分にするよ。
大体、PrograMing工程と、ProjectManagement工程と紛らわしいから、
通常は、PM工程とは言わずPG工程と言うところだが、
そういう無神経さも君の気質をよく体現していると思うよ。
943nobodyさん:2008/05/03(土) 15:40:44 ID:???
ProjectManagement工程って初めて聞いたわ
そうか、ProjectManagementは工程の一つだったのか
944nobodyさん:2008/05/03(土) 15:42:13 ID:???
よそでやれよ目糞鼻糞ども。
945nobodyさん:2008/05/03(土) 15:49:01 ID:???
もっと、テレビのニュースネタになるようなデカイ発言をしろよ。

↓↓↓ 明日の朝のテレビのニュースのネタをどうぞ!!!
946nobodyさん:2008/05/03(土) 15:49:33 ID:???
>>938

おーい。設計図を書いている人がいないぞwwww
947873:2008/05/03(土) 15:51:09 ID:???
みんな!アタシのために喧嘩するのはやめてーーーノシ
948nobodyさん:2008/05/03(土) 15:52:00 ID:???
車のエンジンを作る人(下請けライブラリを作ってくれる人)が
車の設計図(アプリケーションのソースコード)を書いてくれるんじゃねwww

らくだなぁ。打ち込むだけでいいんだろ? おら、早く仕事しろwww
949nobodyさん:2008/05/03(土) 16:06:55 ID:???
東郷平八郎は、命を掛けて日本を守ったのに、
ここに住民はこんな下らないことで時間つぶしですか?

どうりで、GNPで2位から18位に転落するわけだ。先祖に会わす顔がないよ。
950nobodyさん:2008/05/03(土) 16:12:20 ID:???
そこまで戻らなくていいから>>897からやり直そうよ
951nobodyさん:2008/05/03(土) 16:14:21 ID:???
いまどき命をかけて日本を守るとかあほだろw
952nobodyさん:2008/05/03(土) 16:27:42 ID:???
最低な国、日本
953nobodyさん:2008/05/03(土) 17:23:59 ID:???
>>951
OSがないとアプリケーションが動かないことを忘れるタイプですか?
954nobodyさん:2008/05/03(土) 17:30:44 ID:???
そんなときこそマルチプラットフォームだろ
955nobodyさん:2008/05/03(土) 17:33:15 ID:???
>>953
人民いてこその国ぞ。
人がいなくなった国に何の意味があろうか。
956nobodyさん:2008/05/03(土) 17:59:19 ID:???
戦争に狩り出されたのは貧乏な家の男達だ。
そして主の居なくなった家はもっと貧乏になった。
それが忘れてはいけない真実。
957nobodyさん:2008/05/03(土) 18:01:51 ID:???
ゆとり乙w
958nobodyさん:2008/05/03(土) 18:15:39 ID:???
人民について熱く語り合いたいなら
どこか別の板にいけ

でなきゃーPHPスレなんだから
語りたい奴が掲示板作って晒せw

----------------------------------------------

では気を取り直して、次の方質問ドゾー
959nobodyさん:2008/05/03(土) 18:31:39 ID:???
PHPで戦争は止められますか?
960nobodyさん:2008/05/03(土) 18:33:44 ID:Q1whB2fu
すみません。質問です。
YOMIサーチのPHP版を設置し下記URLを参考に静的URLにしたいと思いましたが
どうしても404になってしまい、うまく出来ませんでした。
tp://legendlink.com/php/url_seitekika.html

XREAのs79サーバーを使っています。
設置したいURLはhttp://aaa.example.com/bbb/です
この際、RewriteBaseはどう表現したらいいのでしょうか?

よろしくお願いします。
961nobodyさん:2008/05/03(土) 18:56:32 ID:???
>もし、表示されていなければ、サーバー事態が.htaccessに対応していなかったり、mod_rewriteが組み込まれていない可能性があ
>詳しくは各サーバー管理者にお尋ねください。
>
>なお、Yomi-Search自体をサーバーの特定フォルダ内にインストールしている方は、 RewriteBaseのパスを書き直すか、
>記述を削除して確認してみてください。
962nobodyさん:2008/05/03(土) 19:26:41 ID:???
オナニーレスを繰り返した火とって生きていて恥ずかしくないの?
少なくとも直前の答えるべき問題は>>897だよねぇ
それに答えることもしなくて、独りよがりのレスを積み重ねてる人ってw
963nobodyさん:2008/05/03(土) 19:37:06 ID:6T5yZm8J
>>959
つPHP文庫
964nobodyさん:2008/05/03(土) 19:37:12 ID:???
と自分も答えないニートが熱く語っております。
965960:2008/05/03(土) 21:25:03 ID:Q1whB2fu
考えてみればスレ違いの質問にお答えくださったありがとうございました。
サーバーさんに問い合わせてみて、駄目ならサーバー変えようと思います。
966nobodyさん:2008/05/03(土) 21:55:59 ID:???
ちょw誰も答えてなくね?
上にあるのはニートの妄想レスだからw
俺は就職してるぞーみたいなw
967nobodyさん:2008/05/03(土) 21:57:46 ID:???
>>966
その通り
論点ずれまくりのレスをしているところからして、
当たりだな
968nobodyさん:2008/05/03(土) 22:25:50 ID:???
GW中ずっとこの流れなの?
969nobodyさん:2008/05/03(土) 22:26:05 ID:???
データベースに画像を記載する場合どうすればいいんでしょうか?
CDの画像とか、本の画像とか
970nobodyさん:2008/05/03(土) 22:27:36 ID:???
1. ファイル名だけDBに保持して画像はファイルで持つ
2. BLOBを使う
3. スレ違い
971nobodyさん:2008/05/03(土) 22:28:41 ID:???
>>970
ありがとうございます。 すれ違い失礼致しました。
972nobodyさん:2008/05/03(土) 22:47:49 ID:???
>>970
スレ立てよろ
973nobodyさん:2008/05/03(土) 22:51:34 ID:???
>>970
スレ早く立てろよクズ
974nobodyさん:2008/05/03(土) 22:56:19 ID:???
975nobodyさん:2008/05/04(日) 06:34:25 ID:RevwzEgI
unixタイムって64ビットマシンになったら寿命伸びる?
その頃には間違いなく64ビットかそれ以上になってるから
気にせずunixタイム使うプログラム書いておk?
976nobodyさん:2008/05/04(日) 07:27:34 ID:???
それは誰もわからんよ
977nobodyさん:2008/05/04(日) 08:55:41 ID:z+IlApFp
phpのmicrotimeの関数ですが、
一度取得した後、再度取得しても同じにならないという保証はありますか?
microtimeの返り値をキーに利用したいと思っています。

ちなみに、私は染色体異常でバセドウ病を患っていますので、
高度なパソコン操作ができません。
ご迷惑お掛けしますが、宜しくお願いします。
978nobodyさん:2008/05/04(日) 09:08:03 ID:???
関数を呼び出した時点の値を返すから同じにはならない
979nobodyさん:2008/05/04(日) 09:39:50 ID:???
精度については、OS依存じゃないのかなぁ。

あと、自分のショボイPCでも microtime実行するのに 10マイクロ秒ぐらいだから、
連続して呼び出す場合はマイクロ秒以下になる環境もあるんじゃない。

CPUがマルチコアだと、それも影響するかもしれないし。
980USO800:2008/05/04(日) 09:59:18 ID:???
>>975
将来はRFC2550が標準の日時フォーマットになります。
981nobodyさん:2008/05/04(日) 13:22:09 ID:???
>>960
xreaはRewrite使えるよ

たぶんhttp://aaa.example.com/bbb/
bbbの部分を付け加えてないからだと思う

しかしs79は俺がガンガンcgi使ってるからこれからそこにYomiを入れてずっと運営していくなら
運営する前に新しい鯖に移った方がいいと思うw

というかs79はかなり古いよな
もし移れるならs300番台とかにいったほうがいいぞ
PHP5だし鯖の性能もいいし

俺も移れるなら移りたいがサイト詰め込みすぎて引越すのがマンドクセんだw
982nobodyさん:2008/05/04(日) 21:04:37 ID:???
ブラウザからダウンロードさせるスクリプトですが

header('Content-Disposition: attachment; filename="test.txt";');
header('Content-Length: '.filesize("./test.txt"));
header('Content-Type: application/octet-stream');
readfile("./test.txt");

こうした場合、クライアントがブラウザのダウンロードダイアログではいを選んでDLが完了するか
いいえを選ぶまでサーバー側のPHPのプロセスは存在したままになるのでしょうか
983nobodyさん:2008/05/04(日) 21:11:32 ID:???
require するファイルが存在しなければ例外を発生させたいんですが
以下のコードでは何も表示されませんでした。
どうすれば例外を起こすことができるのでしょうか?

try {
require_once 'detarame.php';
} catch (Exception $e) {
echo '例外です: ', $e->getMessage(), "\n";
}
984nobodyさん:2008/05/04(日) 21:22:53 ID:???
読み込めたか判定してthrows
985nobodyさん:2008/05/04(日) 21:39:22 ID:???
986nobodyさん:2008/05/04(日) 21:39:35 ID:???
>>983
file_existsじゃ駄目なの?
987nobodyさん:2008/05/04(日) 22:42:28 ID:???
>>985
wwwwwwww
988nobodyさん:2008/05/05(月) 02:05:16 ID:???
>>984>>986
file_exists でチェックできるんですね、ありがとうございます

できれば全体を try で囲って
どんな予期しない事が起きようとも
何かエラーメッセージを出すようにしたいのですが
そういうことは しない もしくは するべきではない ものなのでしょうか?
989nobodyさん:2008/05/05(月) 02:18:02 ID:???
別に構わないんじゃね?
990nobodyさん:2008/05/05(月) 02:28:52 ID:???
991983:2008/05/05(月) 03:48:36 ID:???
>>990
難しそうですね。。。
とりあえず色々試してみることにします。
ありがとうございました
992nobodyさん:2008/05/05(月) 05:46:31 ID:???
>>988
メッセージを出した後どうするのかが問題だろ。
予期しないことがないようにしておくのが開発だ。
適当に作ってメッセージ出して終わりじゃ素人。
993nobodyさん:2008/05/05(月) 06:50:31 ID:???
またJP1が出たか。
994nobodyさん:2008/05/05(月) 09:05:42 ID:???
JP1とかどうでもいいが基本だろ?
995nobodyさん:2008/05/05(月) 09:46:55 ID:???
JP1君いらっしゃ〜い
996nobodyさん:2008/05/05(月) 12:56:23 ID:???
ここは富士通営業マンの工作活動がひどいインターネッツですね
997nobodyさん:2008/05/05(月) 12:59:55 ID:???
>>996
富士通じゃなくて、NECソフトウェアだと思うんだが。
998nobodyさん:2008/05/05(月) 13:18:43 ID:cSW0xQhq
某スレに居たけど、俺の良さを分からないようだったので、
こっちに北。俺は、分子生物学の権威だけど、何か聞きたいことある?
999nobodyさん:2008/05/05(月) 13:23:22 ID:???
ない
1000nobodyさん:2008/05/05(月) 13:24:22 ID:???
>>998
いったい何が始まるんです?
10011001
このスレッドは1000を超えました。
もう書けないので、新しいスレッドを立ててくださいです。。。