くだすれPHP(超初心者用)6
レス数が900を超えています。1000を超えると表示できなくなるよ。
0001nobodyさん
2009/04/05(日) 22:04:26ID:???もしくは質問者自身何が何だが分からない質問を勇気を持って書き込むスレッドです。
PHP使いが優しくコメントを返しますが、
お礼はPHPの布教と初心者の救済をお願いします。
PHP Home Page
ttp://www.php.net/
ttp://jp.php.net/
前スレ
くだすれPHP(超初心者用)5
http://pc11.2ch.net/test/read.cgi/php/1227303362/
関連スレ
PHP総合雑談スレ
http://pc11.2ch.net/test/read.cgi/php/1200314111/
PHP初心者勉強会やらんかね!
http://pc11.2ch.net/test/read.cgi/php/1209137730/
0813nobodyさん
NGNG0815nobodyさん
2009/08/10(月) 00:13:28ID:???閉じタグについてはここ
http://www.php.net/manual/ja/language.basic-syntax.instruction-separation.php
returnについてはお好きにどうぞ
0816nobodyさん
NGNG0818nobodyさん
NGNG0819nobodyさん
2009/08/10(月) 19:16:57ID:???0820nobodyさん
NGNG0822nobodyさん
NGNG0823nobodyさん
2009/08/11(火) 01:16:38ID:???ありがとうございます。
因みに自分でアップローダを作ってみたのですが、
どうもクラックされたっぽいです。
(クラックっていうか侵入されたかも)
現在、自分の運営しているサイトのアップローダは何かファイルがアップロードされた場合
ファイルの種類や投稿者の情報とか色々と記憶しているのですが、
昨夜(2:00過ぎ)にそのアップロードされたファイルの一覧ページを見てみたところ
確かに「Explorer.php」というファイルがアップロードされていました。
一番気がかりなのは、もう一度ページをリロードすると消えていました。
DBへのアクセス権ものっとられていたりするのでしょうか?
非常に心配です。
0824823
2009/08/11(火) 01:29:03ID:???アップロードされた場合に弾くべきファイルとして、
*.php *.en *.ja
を禁止していたのですが perl(触った事が無いですが)とかも
アップロードされると外部から実行されてしまいますよね?
その場合にperlのアップロードを弾く場合にはどうすればよいでしょか?
perlの拡張子は *.pl なので
*.pl.ja 等を弾けば良いでしょうか?
0826nobodyさん
2009/08/11(火) 01:35:28ID:???おおぉー。。。。
そうですね。。。
ご名答です。
因みに一時的にphpスクリプトをアップロードされ、次の瞬間にそのファイルが無くなったということは
侵入された可能性はありますか?
0827nobodyさん
2009/08/11(火) 01:51:51ID:???0829nobodyさん
2009/08/11(火) 02:13:40ID:???0830nobodyさん
2009/08/11(火) 02:15:46ID:???あと、Torとか使ってくる奴もいてうざくてしょうがないです。
0831nobodyさん
2009/08/11(火) 02:37:13ID:???アップロードディレクトリでスクリプト実行できないようにしなよ
今のセキュリティホール全開な仕様が異常だと認識したほうがいい
>侵入された可能性はありますか?
スクリプト実行と侵入は違う気がするが
suexecが有効ならサーバ内のファイル構成を見られたりファイル消されたりする可能性はある
とにかくPHP周りを強化するよりサーバ周りの設定を強化したほうがいい
0832nobodyさん
2009/08/11(火) 02:44:24ID:???>アップロードディレクトリでスクリプト実行できないようにしなよ
ディレクトリに設定する権限は755に設定していますが、
これでは駄目なのでしょうか?
因みにファイル構成を見られる分には別にいいのですが
phpスクリプトのコードまで見られた可能性はありますか?
あと、ちょっと原始的かもしれませんが *.php *.PHP *.pl *.PL *.cgi *.CGI を
全てアップロード付加にしました。
取り合えずこれでアップローダからの侵入は防げるかなと思ってますが、
ベテランの方もし穴があるとすればご指摘願います。
0833nobodyさん
2009/08/11(火) 02:46:09ID:???ちっとはてめえで調べろよ、横着野郎。
0835nobodyさん
2009/08/11(火) 02:56:58ID:???755じゃ実行されるでしょ
ていうか権限の問題じゃない
一番簡単なのはAddTypeハンドラでtextとして実行するようにする
他にもルール作って特定拡張子へのアクセス防いだりなど
htaccessを用いていろいろ対策は可能
0836nobodyさん
2009/08/11(火) 03:14:49ID:???今日帰って来たら色々とapacheがらみを勉強してみようと思います。
※上でも書いた様に *.php *.pl 等の実行形式のファイル自体はアップロードさせない様に判定ロジックを
組み込みました。
取合えずこれで少しは穴は塞げた(???)と思いましたのでもう寝ます。
ご回答くださった方々ありがとうございました。
0837nobodyさん
2009/08/11(火) 14:47:02ID:???とかって本を読めば?
0839nobodyさん
2009/08/12(水) 18:14:55ID:XtZqM+tg同じくフォームで受け取った$idをファイル名に含んだファイルの二行目をfile()で読み込んで
$data[1](値はhoge)に代入して
if($pass==$data[1]){
print"値は同じです".$pass"==".$data[1];
}
else{
print"値は違います".$pass"==".$data[1];
}
を実行すると
「値は違います hoge==hoge」
と表示されるのですが「値は同じです」と表示させるにはどうしたらいいですか?
0840nobodyさん
2009/08/12(水) 18:24:11ID:???0841nobodyさん
2009/08/12(水) 18:43:49ID:XtZqM+tgファイルを見てみると
hoge
hoge
hoge
で半角スペースなんてないんだけどこれって別のところに原因がある?
代入は$data=file("$filepath");ってやってるんだけど。
0842nobodyさん
2009/08/12(水) 18:59:57ID:???print"値は違います" . $pass . "==" . $data[1];
ではないのか?
0843nobodyさん
2009/08/12(水) 19:03:38ID:???0844nobodyさん
2009/08/12(水) 19:14:53ID:???0845nobodyさん
2009/08/12(水) 22:39:56ID:???が正解。trim()かrtrim()する必要がある
0846nobodyさん
2009/08/12(水) 23:23:53ID:???、、、だった。
0847nobodyさん
2009/08/12(水) 23:30:30ID:???ttp://www.php.net/manual/ja/function.file.php
>改行記号はついたままとなります。 失敗すると file() は FALSE を返します。
0849nobodyさん
2009/08/13(木) 00:35:56ID:???どうすればPDOドライバが使えるようになりますか?
0850nobodyさん
2009/08/13(木) 00:44:24ID:???0851nobodyさん
2009/08/13(木) 00:45:29ID:???php.iniのPDOの行がコメントアウトされてるから、
コメントアウト;をはずして、
上書き保存して、
アパッチ再起動かな?
0853nobodyさん
2009/08/13(木) 01:18:14ID:???0854nobodyさん
2009/08/13(木) 01:26:14ID:???httpd.confとか。
0855nobodyさん
2009/08/13(木) 03:23:23ID:???その状態で自画面(TestAction)のPHP部分に引き渡したす
為に、次のコードを書いたのですが、エラーが発生してしまいます。
いずれも、*.submit();の実行時にエラーが発生してしまうのですが
どうすればよいでしょか?
function TestSelect(iSelect)
{
document.getElementById("id_value_set").value = iSelect;
//■方法@
document.name_select_page.submit();
//■方法A
obj = document.forms["name_select_page"];
obj.action="TestAction.php"
obj.submit();
}
<form name="name_select_page" action="TestAction.php" method="POST">
<input id="id_value_set" type="hidden" value=""/>
<select onchange="TestSelect(this.options[this.selectedIndex].value)">
<option selected >1</option>
<option>2</option>
<option>3</option>
</select>
</form>
0856nobodyさん
2009/08/13(木) 04:25:57ID:???0857nobodyさん
2009/08/13(木) 05:01:57ID:???すごくスレ違いな気がするけど・・
とりあえずIE8でsubmit()の箇所に関してはどちらの方法も動作する。
省略している部分に問題があると思われる。
続きは
+ JavaScript の質問用スレッド vol.72 +
http://pc11.2ch.net/test/read.cgi/hp/1247911761/l50
0858nobodyさん
2009/08/13(木) 14:58:14ID:???$s = explode( "=", $a[0] );
こうやると $a[0]の最後の = も消えちゃうけど、
消さずに分離するにはどうしたらよい?
0860nobodyさん
2009/08/13(木) 15:14:40ID:???0861nobodyさん
2009/08/13(木) 15:15:27ID:???0863nobodyさん
2009/08/13(木) 15:58:40ID:???/^password=(.+)$/
0864nobodyさん
2009/08/13(木) 16:07:02ID:???0865858
2009/08/13(木) 16:52:21ID:???↓これでいけた。
$s = preg_split( "/=/", $a[0], 2 );
0866nobodyさん
2009/08/13(木) 19:07:28ID:???受け側でGETすると "France+%5C%2740" とかバックスラッシュが
入ってるのはなぜ?
0867nobodyさん
2009/08/13(木) 20:11:40ID:???0868nobodyさん
2009/08/13(木) 21:59:50ID:???自分もそうだったけど、ハマるとなかなか難しいよね。
0869nobodyさん
2009/08/13(木) 22:29:31ID:???6ではもう削除されるし
0870nobodyさん
2009/08/14(金) 00:21:29ID:???( ´,_ゝ`)プッ
0871nobodyさん
2009/08/14(金) 20:37:22ID:WKlKHJBl0872nobodyさん
2009/08/14(金) 20:41:09ID:???0874nobodyさん
2009/08/14(金) 22:17:30ID:???$aa=2;
こんなとき、もし
print $aaa;
とかってあったら、PHP君は、
「これって、$aなのかなぁ?$aaなのかなあ?$aaaなのかなぁ?」
って、わけわかんなくなって、
「下半身のクスリなので見せられない」
とかってふぁびょって、逃亡してしまうのです。
それを防ぐための{}です。
0875nobodyさん
2009/08/14(金) 22:44:12ID:???0876nobodyさん
2009/08/14(金) 23:26:44ID:???どんだけ脳味噌腐ってるんだ
機械なんだから、最終的には1通りに決定するに決まってんだろ
0877nobodyさん
2009/08/14(金) 23:48:55ID:???if ( mb_ereg( "/ア/", $a . $b ) )
こんな風に書いたら正常に動作しないんだけど、なぜ?
0878nobodyさん
2009/08/15(土) 00:09:31ID:???0882nobodyさん
2009/08/15(土) 01:13:14ID:???>>876
>どんだけ脳味噌腐ってるんだ
つまり>>874と>>876は脳味噌腐ってる、そういうことです
0883nobodyさん
2009/08/15(土) 01:34:00ID:???$aaaしか解釈されない話を書いておいて、
>それじゃあ$aや$aaを使いたいときにはどうすんだよ
という話に結びつくわけねーだろアホが
結びつけたいなら例示が誤り
0885nobodyさん
2009/08/15(土) 19:39:15ID:???date("y/m/d H:i:sZ32400",time())
とかやったらダメだった…
0886nobodyさん
2009/08/15(土) 19:44:38ID:???0887nobodyさん
2009/08/15(土) 19:50:31ID:???ごめん、聞き方が悪かったというか勘違いしていた。
西海岸の鯖を借りていて、time()で取った時間を記録しているんだけど、
それを日本時間で表示したかったの。
夏時間なんかもあるし、他の鯖に引っ越したときのことも考えると
単純に時差を足すのもダメなんで悩んでます。
0888nobodyさん
2009/08/15(土) 19:54:23ID:???0889nobodyさん
2009/08/15(土) 21:50:12ID:lF+0GJeWやるとしたらどうやるんでしょうか?
0890nobodyさん
2009/08/15(土) 22:14:56ID:???ちなみにPHPコアはロクなテストをしていない気がする
ハーネスは普通にPHPUnitがある
0891nobodyさん
2009/08/15(土) 22:16:04ID:lF+0GJeW0893nobodyさん
2009/08/15(土) 23:22:02ID:???0894nobodyさん
2009/08/15(土) 23:50:25ID:???0895nobodyさん
2009/08/16(日) 00:06:27ID:???0896nobodyさん
2009/08/16(日) 17:03:40ID:???0897nobodyさん
2009/08/16(日) 17:09:30ID:???0898nobodyさん
2009/08/16(日) 17:42:34ID:???Perlだとユーザー定義関数内でユーザー定義関数外の変数が使えたような気がするんだけど
PHPだとできない?ファイルごとにかいてrequireするしかないのかな?
0900nobodyさん
2009/08/16(日) 17:48:09ID:r7x0SQCa0901nobodyさん
2009/08/16(日) 18:26:29ID:???現状レベルの設定項目ならXML化など必要ない。
XMLが必須になるような複雑な設定が必要ならば、それは環境依存バグの温床でしかない。
「設定が原因」って問題が、現状ですらこのスレの質問の何割ってレベルに達してる。複雑化させようとか脳味噌涌いてる。
むしろphp.iniっていつになったら削除するの?と言いたい。
0902nobodyさん
2009/08/16(日) 22:09:37ID:???と思ってしまう。
0903nobodyさん
2009/08/17(月) 04:25:59ID:???察してやれ
0904nobodyさん
2009/08/17(月) 06:31:09ID:???0905nobodyさん
2009/08/17(月) 14:56:46ID:???うちのPCは容量不足でした。
で、ネカフェで一度試そうと思うんですけど、
環境整えるのに30分もかかりませんか?
0906nobodyさん
2009/08/17(月) 14:59:27ID:???0907nobodyさん
2009/08/17(月) 15:01:29ID:???0908nobodyさん
2009/08/17(月) 15:15:54ID:???で、30分はかかりませんかね?
0909nobodyさん
2009/08/17(月) 15:17:34ID:???0910nobodyさん
2009/08/17(月) 15:24:55ID:???ありがとうございました。
0911nobodyさん
2009/08/17(月) 15:33:23ID:???0912nobodyさん
2009/08/17(月) 15:36:04ID:???レス数が900を超えています。1000を超えると表示できなくなるよ。