[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 901- 2chのread.cgiへ]
Update time : 12/05 02:47 / Filesize : 235 KB / Number-of Response : 906
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

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



1 名前:nobodyさん mailto:sage [2008/09/20(土) 20:23:08 ID:???]
質問者はまず>>1を良く読むこと(必須!)
過去スレ、関連スレ、FAQなどは>>2-10辺り
次スレは>>980が立てる。10分以内に立たない場合、宣言してから立てたい人が立てること。

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

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

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

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

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

【その他諸注意】
・SQL・正規表現・PEAR・テンプレート(Smarty等)・フレームワークは各該当スレへ

836 名前:nobodyさん [2008/10/11(土) 23:29:26 ID:8WtsmSV0]
エラーメッセージを取得しましたら下記のようなエラーです。
Access denied for user: 'username@hostname' (Using password: YES)]

ポートの開閉確認とは??レンタルサーバーを使用しております。どのように
行えばよいでしょうか?お恥ずかしい質問ですが、よろしくおねがいします。

837 名前:nobodyさん [2008/10/11(土) 23:29:53 ID:4K6Y3Waq]
>>832
回答ありがとうございます。
余談ですが
delコマンドを使うと閲覧者のPCのデータを消せますか?

>>835
メモ帳二つ開けばいいよ。漢(おとこ)ならメモ帳だろ。


関係ないけど、さっきすっきりデフラグってソフト使ったら、
PHPのセッションのフォルダごと自動で削除されてセッション使えなくなった。

838 名前:nobodyさん mailto:sage [2008/10/11(土) 23:31:23 ID:???]
>>836
IDかパスが間違ってる

839 名前:nobodyさん [2008/10/11(土) 23:37:11 ID:8WtsmSV0]
ソースに記述したIDとパスでphpMyAdminはログインできるんです・・・。

840 名前:nobodyさん mailto:sage [2008/10/11(土) 23:37:45 ID:???]
じゃ接続の仕方がおかしい

841 名前:nobodyさん [2008/10/11(土) 23:41:28 ID:8WtsmSV0]
$mdb2 =& MDB2::connect("mysql://username:pass@hostname/tablename");
と記述しております。どこか間違えておりますでしょうか?

842 名前:nobodyさん [2008/10/11(土) 23:57:24 ID:8WtsmSV0]
記述ミスです。
$mdb2 =& MDB2::connect("mysql://username:pass@hostname/databasename");
です。

843 名前:nobodyさん mailto:sage [2008/10/12(日) 00:10:26 ID:???]
そのレン鯖のMySQLは外部接続を許可しているのか?
そうでないならlocalhostしか接続出来んだろ
phpMyAdminはレン鯖提供か、自スペースに置いたものだろ?(レン鯖ないで動くアプリはlocalhost接続)


844 名前:843 mailto:sage [2008/10/12(日) 00:14:23 ID:???]
ちょっと言い方が悪かったかもしれん
つまりホスト名に「localhost」以外を指定出来る設定になってるかどうか
普通は「mysql://username:pass@localhost/databasename」にする
(MySQLはユーザ名だけでなくホスト名もチェックする認証方式)




845 名前:nobodyさん [2008/10/12(日) 00:16:43 ID:cg/RVdaY]
セッションを利用するWEBページを見て回ってるときに、
そのセッションIDが自分のパソコンの中のクッキーに保存されていて、
そのクッキーを盗み出されたら、セッションIDがばれてしまって
なりすましされてしまうの?

846 名前:nobodyさん mailto:sage [2008/10/12(日) 00:40:17 ID:???]
サイトの対策次第
セッションIDと共にIPでのチェックもしてる場合は抑制されるし
サイトが未対策で、IDバレたらなりすまし可能(ヘッダーにIDを仕込むだけだし)


847 名前:nobodyさん mailto:sage [2008/10/12(日) 00:43:36 ID:???]
>>845
セッションハイジャックは都市伝説。
存在しないよ。

848 名前:nobodyさん mailto:sage [2008/10/12(日) 00:57:13 ID:???]
>>846
セッションIDが分かっても、鯖はコネクションが切れた時点でセッション内容を破棄するから
盗んだセッションでアクセスしても既に内容が無いんと違うか?

>>847
同意。セッションのフォルダは隠しフォルダだから外からアクセスできないし、外部から見るのは不可能だよな。

849 名前:nobodyさん [2008/10/12(日) 01:44:14 ID:kzFvqNLy]
おう、わいや、清原や。
お前ら、他のやつが作ったフリーのライブラリとか使う時に
自分のサイトで「○○さんのを使わせてもろたで」とか書くんか?
書かんでええやろ。どないやねん。はよ答えろや。

850 名前:nobodyさん mailto:sage [2008/10/12(日) 02:30:18 ID:???]
>>848

…こんな奴がいるからいつまでたってもPHPが馬鹿にされる

851 名前:nobodyさん [2008/10/12(日) 04:54:47 ID:kzFvqNLy]
おう、わいや、清原や。
PDF作ろうと思うとるねんけどFPDFは文字化けしてよう作られへんわ。

PHPのマニュアルに個人利用フリーで商用有料のモジュールあるんやけど
個人でアフィリエイトするサイトは商用になるんか?
そもそも商用って何やねん。
ウェブプログラマーになって他人のサイト作る事が商用?
会社で自社のサイト作るんが商用?
どないやねん。はよ教えろや。
というか外部の奴からは関数なんて分からんから商用やってもバレへんのちゃうか?

852 名前:nobodyさん [2008/10/12(日) 04:59:49 ID:LpzkFgnx]
     ____
   /__.))ノヽ
   .|ミ.l _  ._ i.)  
  (^'ミ/.´・ .〈・ リ   そんなこと知らんわ
  .しi   r、_) |  
    |  `ニニ' /   
   ノ `ー―i


853 名前:nobodyさん mailto:sage [2008/10/12(日) 05:14:04 ID:???]
>>851
ちんちん舐めて

854 名前:nobodyさん mailto:sage [2008/10/12(日) 06:31:27 ID:???]
>>852
星野に似てるな。



855 名前:nobodyさん [2008/10/12(日) 09:01:37 ID:B7DkksYv]
すいませんopenlab.ring.gr.jp/k16/htmllint/tagslist.cgi?HTMLVersion=XHTML11
タグ名とそのタグの属性名を正規表現で抜き出したいのですがうまくいきません
どなたかご教授おねがいします

$file = file_get_contents("openlab.ring.gr.jp/k16/htmllint/tagslist.cgi?HTMLVersion=XHTML11");

preg_match_all("/<dl>.*</dl>/",$file, $ary);

856 名前:845 mailto:age [2008/10/12(日) 09:50:14 ID:???]
うぜえ回答者はだまってろ!
わかるかた回答おね

857 名前:nobodyさん mailto:sage [2008/10/12(日) 10:20:47 ID:???]
>>855
正規表現で/使う場合はエスケープ
オプションで改行も全て含むやりかたがあるからやってみろ(mだかUだか忘れたけど)
.*を(.*?)にしてみろ、.*は最長マッチだが.*?は最短マッチだ

858 名前:nobodyさん mailto:sage [2008/10/12(日) 10:30:37 ID:???]
>>845
なりすましはセッションではなくSSLで使う言葉じゃね。
Session Fixationでググれ。

859 名前:nobodyさん mailto:sage [2008/10/12(日) 12:57:38 ID:???]
>>856
俺のチンコなめ回したら教えてやる。

860 名前:nobodyさん mailto:sage [2008/10/12(日) 13:30:21 ID:???]
>855
もうDOM使っちまえよ

861 名前:nobodyさん [2008/10/12(日) 13:53:51 ID:UTQYH/CT]
php.ini の以下の設定のコメントを外してもociドライバが認識されません(phpinfo()で確認)
extension=php_oracle.dll
extension=php_oci8.dll
extension=php_pdo_oci.dll

Oracle Database 10g Express Editionを使用してます。
どうしたら、認識されるのでしょうか?

862 名前:211 [2008/10/12(日) 13:59:14 ID:fXLt5ZTj]
>>861
Oracleのクライアントを入れていないんじゃない?

863 名前:211 [2008/10/12(日) 14:06:40 ID:fXLt5ZTj]
おっと。うっかり想像で書いてしまったぜ。

>>861
エラーログみたらなんか出てるんじゃない?
ロードに失敗しているなら、DLLをロードする時必要なファイルに
パスが通ってないとかそもそも必要なものがインストールされてないとか、、、

www.php.net/manual/ja/book.oci8.php


864 名前:nobodyさん [2008/10/12(日) 15:12:01 ID:kzFvqNLy]
おう、清原やけど、
数字を16進数や2進数にするんわ分かってんけど
文字を16進数や2進数にするんわどうしたらええの?
文字かて2進数にできるんちゃうか?
教えろや。はよしてや。急いでるねん。



865 名前:nobodyさん mailto:sage [2008/10/12(日) 15:15:31 ID:???]
asciiコードってこと?
全角だと文字コードによって変わっちゃうんだけど

866 名前:211 [2008/10/12(日) 15:20:51 ID:fXLt5ZTj]
要するに… 「文字」を「数字」にできればいいんだよね。
この変見ればやりたいこと書いてあるんじゃない?
www.php.net/manual/ja/language.types.type-juggling.php


867 名前:nobodyさん mailto:sage [2008/10/12(日) 15:32:26 ID:???]
>>864
急いでるなら、俺のチンチンを今すぐ舐めろ!

868 名前:nobodyさん [2008/10/12(日) 16:32:51 ID:ZWInd4bd]
変数展開をその場でなく任意の場所で行う
標準的な関数か方法はないでしょうか?

通常の変数展開は
$foo = 'bar';
echo "foo: {$foo}"; // => foo: bar

ですが
$hoge = 'foo: {$foo}'; // ここでは展開しない
$foo = 'bar';
echo func($hoge); // ここで展開する
// または echo func($hoge, array('foo' => $foo)); など

のような形にしたいです。
sprintf()の%sに名前を指定できる感じのものと言えばいいでしょうか。
よろしくお願いします。

869 名前:nobodyさん mailto:sage [2008/10/12(日) 16:36:35 ID:???]
そういうときのためにsprintfがあると思うんだが
もしくはeval

870 名前:861 mailto:sage [2008/10/12(日) 16:56:09 ID:???]
>>863
Oracle Instant Clientを落としてきて、中身をsystem32フォルダに入れたらうまくいきました。
ありがとうございました。たすかりました。

871 名前:nobodyさん mailto:sage [2008/10/12(日) 17:14:38 ID:???]
>>869
ありがとうございます。
sprintfは展開する順序が固定なのが少し困るところです。
evalは思いつかなかったので
初心者なりにevalを使って期待する関数をつくってみました。
こういった感じの標準的な関数・方法はないでしょうか?

function interpolate($str, $args) {
extract($args);
return eval('return "' . $str . '";');
}

$hoge = 'foo: {$foo}';
$foo = 'bar';
echo interpolate($hoge, array('foo' => $foo)); // foo: bar

872 名前:868 [2008/10/12(日) 17:16:11 ID:ZWInd4bd]
すみません。>>871は868です。

873 名前:211 [2008/10/12(日) 17:19:51 ID:fXLt5ZTj]
標準的かどうかはよくわからないけど、変数を展開させることに拘らなければ
str_replace かその関係の関数が簡単なんじゃないかな?
echo str_replace(array('$foo'),array('bar'),$hoge);
みたいな。
jp2.php.net/manual/ja/function.str-replace.php


874 名前:868 [2008/10/12(日) 18:18:51 ID:ZWInd4bd]
>>873
ありがとうございます。
str_replace()やpreg_replace()はすべての引数で配列を指定できるのですね。
1つずつの文字列しか引数に取れないと思い込んでいたので
勉強になりました。

配列の中身の展開("{$baz[0]}"など)が必要にならない限り
これを使っていきたいと思います。
皆さんありがとうございました。



875 名前:nobodyさん mailto:sage [2008/10/12(日) 20:15:22 ID:???]
トーシロなんだけど
このページの
www.phppro.jp/school/phpschool/vol12/2


if (isset($_POST["title"]) && $_POST["title"])
って入力確認だけど、なんでissetで事足りるように見えるのに後ろに余計な物付け足してるん?
念のため聞くけど、後ろのは入力されてたらTRUEを返すんだよね?

なんか見苦しくてすまない、回答いただけるとウレシス

876 名前:nobodyさん [2008/10/12(日) 20:19:57 ID:qbuV3HNr]
ごめんID出し忘れた

877 名前:nobodyさん mailto:sage [2008/10/12(日) 20:20:37 ID:???]
>>875
0

878 名前:nobodyさん mailto:sage [2008/10/12(日) 20:28:59 ID:???]
つかissetだけでいいわな

879 名前:211 [2008/10/12(日) 20:29:53 ID:fXLt5ZTj]
「入力されてたらTRUE」の認識は正しいと思います。
何でよけいだと思ったのかな。

880 名前:211 [2008/10/12(日) 20:36:51 ID:fXLt5ZTj]
あ。ごめん。俺間違ってる。
875の書き方も、877の事を考慮すると間違ってる。

881 名前:nobodyさん [2008/10/12(日) 20:37:46 ID:qbuV3HNr]
回答どうもです。
これってissetだけじゃ駄目なんですかね?

882 名前:nobodyさん [2008/10/12(日) 20:38:52 ID:qbuV3HNr]
あ、そういう事か
0だと入っててもFALSEかなんかになるんですよね
回答どうもです

883 名前:nobodyさん mailto:sage [2008/10/12(日) 20:46:54 ID:???]
なんねーよissetは

884 名前:nobodyさん mailto:sage [2008/10/12(日) 20:49:37 ID:???]
0だとisset通るけど後方で引っかかる
array()も同じく



885 名前:nobodyさん [2008/10/12(日) 21:05:30 ID:cg/RVdaY]
WEB系ってある程度きわめると
勉強することなくなるの?

886 名前:nobodyさん mailto:sage [2008/10/12(日) 21:08:42 ID:???]
んなわけねーだろ。

887 名前:nobodyさん [2008/10/12(日) 21:12:53 ID:cg/RVdaY]
wiki.bit-hive.com/tomizoo/pg/PHP%20CLI%2FCGI%20SAPI

ここに、PHPのCGI版は、実行時に
HTTPヘッダを自動で送信している、って
書いてあるけど、
自分はPHPのモジュール版を使っているのだが、
この場合はHTTPヘッダを自動で送信しているのかな?
それともしていないのかな?

888 名前:211 [2008/10/12(日) 21:32:59 ID:fXLt5ZTj]
使っているのなら自分で確認できませんか?

889 名前:nobodyさん mailto:sage [2008/10/13(月) 01:00:05 ID:???]
>>875
そのURLは面倒なので見てないが、変数定義があるかどうかを調べた後にその変数の正当性を調べるのは、
何らおかしい事ではないというかむしろ普通。

PHPはそこら辺いい加減な言語だから別に好きにすりゃいいが、変数が定義されているかどうか分からないケースの場合、
先にisset()で調べた方が、実行速度は上がるケースがある。未定義の変数の参照は遅い。

if (isset($_POST["title"]) && $_POST["title"]) だと、$_POST["title"]が未定義ならその後の処理は実行されない。
if ($_POST["title"]) だと、$_POST["title"]が未定義の時に遅い。まぁマイクロ秒単位の世界だがw

890 名前:nobodyさん mailto:sage [2008/10/13(月) 01:02:20 ID:???]
なんで isset($_POST["title"] だけではだめなの?

891 名前:nobodyさん mailto:sage [2008/10/13(月) 01:48:34 ID:???]
みんな回答ありがとう

892 名前:211 [2008/10/13(月) 07:30:16 ID:2R92n/wD]
>>890
だめかどうかは知らないけど、
isset($_POST["title"])

$_POST["title"]!=""
は意味(結果)が違うからね。
必要に応じて使えばいいと思う。

893 名前:nobodyさん mailto:sage [2008/10/13(月) 07:38:41 ID:???]
じゃstrlenにすれば一発でできんじゃん

894 名前:nobodyさん [2008/10/13(月) 07:46:42 ID:CGfh2V74]
phpファイルで
<html>
<head><title>PHP TEST</title></head>
<body>
<?php
require_once(DB.php);

?>
</body>
</html>
というのを作ってapacheで実行したら
エラーが出ました

Warning: require_once(DB.php) [function.require-once]: failed to open stream: No such file or directory in C:\Program Files\Apache Group\Apache2\htdocs\atest.php on line 7

Fatal error: require_once() [function.require]: Failed opening required DB.php (include_path=.;c:\php\includes;c:\smarty\libs) in C:\Program Files\Apache Group\Apache2\htdocs\atest.php on line 7

と書かれていたのでC:\WINDOWS\php.iniの
include_path = .;c:\php\includes;c:\smarty\libs
を確認したのですが違いはなかったようです

どうすればよろしいでしょうか?



895 名前:nobodyさん mailto:sage [2008/10/13(月) 07:50:19 ID:???]
PEAR入れれ

896 名前:nobodyさん [2008/10/13(月) 08:05:13 ID:CGfh2V74]
>>895
え?入ってないってことですか?
入れたはずなんですが

897 名前:nobodyさん mailto:sage [2008/10/13(月) 08:07:59 ID:???]
include_pathがそれでいいのか良く見て考えれ。終了。

898 名前:nobodyさん [2008/10/13(月) 08:20:52 ID:CGfh2V74]
>>895>>897のどっち?
pearは入れたはず
include_pathはとりあえず言われたのをやったんですけども
pear導入のときから少し変えた
なにを入れたらいいの?

899 名前:211 [2008/10/13(月) 08:51:11 ID:2R92n/wD]
>>898
警告メッセージってコピペですか?
require_once の引数はそれで正しいですか?

900 名前:894 [2008/10/13(月) 09:13:10 ID:CGfh2V74]
レスありがとうございます

コピペです
require_onceの引数ですが
c:\php\pear\DBなので間違いではないと思います

901 名前:211 [2008/10/13(月) 09:26:59 ID:2R92n/wD]
>>900
> コピペです
私の理解では、DBとphpが定数定義されていない限り、
require_once(DB.php);

require_once("DB"."php"); つまり require_once("DBphp");
という動きをします。

しかしそうだとすると、894の警告と食い違うので聞きました。
手で打ち直してないですか?

二つめの質問もつまりそういうことです。

もし私の理解が正しくなくて、require_once が DB.php を
開こうとしているなら、DB.phpが include_pathで指定されている
ディレクトリのどこかにあるかどうか確認すればよいと思います。

あるいは、require_onceの引数にパスを含めて指定することも
できると思います。


902 名前:894 [2008/10/13(月) 10:38:31 ID:CGfh2V74]
ありがとうございます
一度帰宅してやってみます
詳しく書いて頂き大変感謝してます

いつもここのスレは丁寧な方が多くて嬉しい限りです

903 名前:nobodyさん mailto:sage [2008/10/13(月) 12:24:01 ID:???]
>>892
もしかすると
gettypeでstringの場合とstrlenで1文字以上をチェックすれば完璧じゃね?

または(string)で強制的にstringに置き換えてstrlenでチェック


904 名前:211 [2008/10/13(月) 12:37:29 ID:2R92n/wD]
>>903

>>889 で書かれていることは知らなかったけど、そういうこともあると思う。
自分で isset($_POST["title"]) && $_POST["title"]!="" とか書くときの
isset は Notice が出ないようにするためだな。



905 名前:nobodyさん mailto:sage [2008/10/13(月) 12:40:44 ID:???]
>>903
>>893






[ 新着レスの取得/表示 (agate) ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<235KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef