くだすれPHP(超初心者用)5
■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん
2008/11/22(土) 06:36:02ID:???もしくは質問者自身何が何だが分からない質問を勇気を持って書き込むスレッドです。
PHP使いが優しくコメントを返しますが、
お礼はPHPの布教と初心者の救済をお願いします。
PHP Home Page
http://www.php.net/
http://jp.php.net/
くだすれPHP(超初心者用)4
http://pc11.2ch.net/test/read.cgi/php/1213356756/
適当に関連スレ(マルチはだめぽ)
【PHP】下らねぇ質問はここに書き込みやがれ 69
http://pc11.2ch.net/test/read.cgi/php/1211879073/
0002nobodyさん
2008/11/22(土) 08:10:59ID:NVQ67oh42GET
0003nobodyさん
2008/11/22(土) 12:53:51ID:???0004nobodyさん
2008/11/22(土) 12:55:45ID:???0005nobodyさん
2008/11/22(土) 16:02:02ID:???0006nobodyさん
2008/11/23(日) 02:46:28ID:KQeB2dd8『500年ROMってろ!!』
と言われた者です。
あれから500年、ひたすらROMに徹してきました。
来る日も、来る日も。
そして今、
やっと2をget出来るだなんて………
感動で……胸が一杯です。
人間、辛抱すれば良いことって有るんですね!
こんな私ですが、
僭越ながらとらせて貰います…!
念願の2ゲットはもちろんこの書き込みです。
では・・
「6get!!!!」
0007nobodyさん
2008/11/23(日) 02:49:23ID:/R5EIGzeお礼書く前にスレ落ちてしまったので。とても参考になりました。ありがとうございましたm(_ _)m
0008nobodyさん
2008/11/23(日) 08:57:21ID:???日付が変わる前に毎日ログをとりたいんですが どのようにすればいいでしょうか
0010nobodyさん
2008/11/23(日) 12:15:51ID:???0012nobodyさん
2008/11/23(日) 14:46:21ID:???1行目は意味不明。2行目についてはログ取るなら
fopen($path, 'a');
あたりか。
$pathとしてファイル名に日付でユニークな名前付ければ良い。(例:yyyy_mm_dd.csv)
$pathのあるディレクトリのパーミッションにさえ気をつけておけば、
あとは日付が変わるたびに新しいファイルが出来てそこに追記処理が行われる。
0013nobodyさん
2008/11/23(日) 16:19:53ID:/R5EIGze0015nobodyさん
2008/11/23(日) 19:17:52ID:???俺も1行目の意味がよくわからないけど、
たぶんヒントとして「cron」で検索したら思ってる情報が出るんじゃないかな?
0016nobodyさん
2008/11/24(月) 00:29:44ID:???0017nobodyさん
2008/11/24(月) 11:38:04ID:???それ以外はエラー、という条件を作りたいのですが、どうすればいいでしょうか、教えてください。
0018nobodyさん
2008/11/24(月) 11:50:36ID:???Aとはなんぞ?意味分からんがこういう事かな?
$A = 0;
$fuge = 'xyz12345';
if ($A === 0 && preg_match('/[0-9a-zA-Z]{8}/D', $fuge)) {
// 実行処理
} else {
// エラー処理
}
001918
2008/11/24(月) 11:51:43ID:???×preg_match('/[0-9a-zA-Z]{8}/D', $fuge)
○preg_match('/^[0-9a-zA-Z]{8}$/D', $fuge)
0020nobodyさん
2008/11/24(月) 14:21:44ID:???$A = 0;
$fuge = 'xyz12345';
if ($A !== 0) {
// エラー処理
}
if (!preg_match('/^[0-9a-zA-Z]{8}$/D', $fuge)) {
// エラー処理
}
//処理続行
にする。
じゃないと条件が増えたり実行処理の中でインデントがたくさん出てきたら読みにくくなる。
どっちの条件にマッチしなかったのかも判定しやすいし。
0021nobodyさん
2008/11/24(月) 14:38:36ID:???0022nobodyさん
2008/11/24(月) 14:42:35ID:???0023nobodyさん
2008/11/24(月) 14:44:07ID:???0024nobodyさん
2008/11/24(月) 14:49:07ID:iKPzd1uP$this->xxx
のように参照しなければいけませんよね。
しかし、関数内で変数を参照したりいじったりする機会が多いせいで
this->の部分が非常に邪魔なのですが、
この部分を略して記述する方法ってありませんか?
0025nobodyさん
2008/11/24(月) 14:52:52ID:???0026nobodyさん
2008/11/24(月) 14:58:21ID:???$fuge =& $this->var;
0027nobodyさん
2008/11/24(月) 15:07:27ID:iKPzd1uPありがとうございます。
0029nobodyさん
2008/11/24(月) 15:54:29ID:???0031nobodyさん
2008/11/24(月) 16:22:57ID:???$this->users[] = new User(ほげほげ)
とかやらね?
見通しについては、いちいちローカル変数に代入するほうが悪くなると思うが
003213
2008/11/24(月) 16:42:34ID:E3B5gNBMありがとうございます。
すいませんもうちょっと分かりやすく教えて頂けると・・
とりあえずインライン関数っていう概念はないってことででしょうか?
0034nobodyさん
2008/11/24(月) 17:45:35ID:???インライン関数がどういう概念なのかを教えてくれれば答える
PHPを知らないあなたと、C++を知らない僕とで対等ではないか。
0035nobodyさん
2008/11/24(月) 17:54:32ID:???コンパイラがないPHPには関係ない話じゃないの?
0037nobodyさん
2008/11/24(月) 22:52:12ID:???このページに
$threat "'OR '='";
$threat = mysql_real_escape_string($treat);
SELECT account_number, name, address FROM account_data WHERE account_number = $threat
は、mysql_real_escape_string で、$threatが
''or''=''
とエスケープされるので、SQLインジェクションになるというように書いてあるのですが、
自分の環境
Windows XP
PHP 5.2.0
MySQL 5.0.27
では、mysql_real_escape_string($treat) は
\'OR \'=\'
とエスケープされ、SQLインジェクションになりませんでした。
この記事は合っているのでしょうか??
どなたか教えてくださいm(_ _)m
0038nobodyさん
2008/11/24(月) 23:27:44ID:???その上、○○の本のインジェクションが動かないとか
攻撃して書いちゃってるのがかなり痛い人だな。
0039nobodyさん
2008/11/25(火) 03:38:24ID:???どうしたらよいですか?
ブラウザを使ってアクセスするとできるのですが、PHPだとできません。
0040nobodyさん
2008/11/25(火) 04:01:15ID:???0042nobodyさん
2008/11/25(火) 21:18:12ID:qzrO9YC/phpで書かれたサーバ設置型を探しています。
0043nobodyさん
2008/11/25(火) 21:24:20ID:???そりゃ誰かが作りゃあるだろバカか?
0044nobodyさん
2008/11/25(火) 22:14:09ID:???普通そういう事はPHP単体ではやらないかな…。
Namazuなんかはperl版はあった気がするが。
要望そのものには応えられないが「Namazu PHP」でググるといい。
>>39
具体的にコード載せては?
PHP5でphp.iniでallow_url_fopenがONになっていたら、
取ってくるだけならfile_get_contents()1行で終わりだけどね。
まぁ実際は2chの鯖と行儀よくおしゃべりしないと駄目なので
ttp://age.s22.xrea.com/talk2ch/
ttp://www.monazilla.org/
辺り読んで理解できないなら、もう少し勉強してからにした方がいい。
既に既存のスクリプトもあるみたいなので「PHP 2ch Viewer」とかでググルといい。
>>37
そもそも、Prepared Statement使ったほうがいいと思う。
PHPならPDO使えば簡単楽ちん。
0046nobodyさん
2008/11/26(水) 17:34:56ID:???phpのなかでjavascript使いたいんですが書き方がわからないです・・・
どなたか教えてください
0047nobodyさん
2008/11/26(水) 17:37:01ID:???<?php
echo "<script type=\"text/javascript\" src=\"hoge.js\"></script>\n";
?>
あるいは一回PHPモードから抜ける
<?php
//php script
?>
<script type="text/javascript" src="hoge.js"></script>
<?php
//php script
?>
004837
2008/11/26(水) 18:03:51ID:???>その人のは他のも動かないのあるね。
む、そうなんですか。
>>44
pdo->prepare 既に使ってたんですが、プリペアードステートメントってこれのことだったんですね。
名前だけ知ってたんですが、何のことかよく分かっていませんでした汗
ありがとうございましたm(_ _)m
004946
2008/11/26(水) 18:41:54ID:???早いレスありがとうございます。
print("<table border=\"1\">");
print("<tr><td>ISBNコード</td><td>題名</td><td>著者</td><td>出版社</td><td>出版年</td><td>更新</td><td>削除</td></tr>");
while($row=mysql_fetch_array($res)){
print("<tr>");
print("<td>".$row["bisbn"]."</td>");
print("<td>".$row["btitle"]."</td>");
print("<td>".$row["bauth"]."</td>");
print("<td>".$row["bpub"]."</td>");
print("<td>".$row["bpubyear"]."</td>");
print("<td><a href=\"update_form.php?bid=".$row["bid"]."\">更新</a></td>");
print("<td><a href=\"library_delete.php?bid=".$row[bid]."\">削除</a></td>");
print("</tr>");
}
さっきボタンと書きましたが実際ボタンじゃなかったです。すいません。
MySQLに接続した図書検索のページなんですが、更新をクリックしたときに確認画面を出したいです。
出力するのとPHPモードから抜けるの試したのですが、
前者は"更新"が表示されなくなってしまいました。
後者はページ自体表示できなくなってしまいました。。
0050nobodyさん
2008/11/26(水) 19:06:12ID:???0052nobodyさん
2008/11/26(水) 19:14:40ID:???0053nobodyさん
2008/11/26(水) 19:16:47ID:???だとまずいんでしょうか。。
0054初心者です
2008/11/26(水) 19:52:25ID:51PdxGfYどうしたらいいのでしょうか?
データベースはMySQLで、文字コードはUTF−8に揃えてるはずなんですが^^;
いきずまってます。色々なサイト見てますが、出来ません><
0055nobodyさん
2008/11/26(水) 19:53:27ID:???更新ボタンをjavascriptで制御したいなら
<input type="button" onclick="javascript:event" value="更新">
onclickあたりでイベント発生させないと
ボタンじゃなくてアンカーだとしても同じこと
<a onclick="javascript:event">更新</a>
■ このスレッドは過去ログ倉庫に格納されています