09/01/29 19:53:27
>>604 == >>606 だよな?
「どうしても$_SESSION['abc']を使いたい理由」ってのがわからんと、普通のPGは他の手段を考えると思うぞ。
>>606 の中で $abc に入れてるんだったら、そのまま echo $abc; すりゃ良いじゃん、的な。
つーかsession_start()しなくて良いんかな。
長ったらしくない程度に、もう少し質問の背景を含めて、かつ要領良くまとめて質問すれば回答が返って来ると思う。
608:nobodyさん
09/01/29 20:07:16
釣りだよ。
URLリンク(oshiete1.goo.ne.jp)
609:nobodyさん
09/01/29 20:25:30
スレリンク(php板:672番)
スレリンク(php板:880番)
理由はどうあれこういうマルチするアホは相手にしないほうがいい
610:nobodyさん
09/01/29 23:28:49
何回読んでも>>604のやりたいことがわからない
611:nobodyさん
09/01/29 23:37:26
前よく出没してた基地外だろ
612:nobodyさん
09/01/29 23:41:37
やりたいことは見えてる。
「ログイン・ログアウトとは別にセッションデータを引きまわしたい」ってことだろ。
で、普通は>>604みたいなソースにはならないのに、わざわざ教えてgooだか、
phpのマニュアルでセッション破壊用のソースをそれだと勘違いして質問してるだけ。
すでに回答ついてるのに、人の意見を聞けない困ったチャンか、単なる荒し
613:nobodyさん
09/01/30 10:09:33
>>607
ログインログアウトとは別に、スタイルシートをセッションで持ち歩いていて、
ログアウト>>606で書いたようにログアウトとしたときセッションに保存してあるスタイルシート変数も消えてしまいます。
なので、セッション(ログアウト)を消す前に$abc = $_SESSION['abc']; として消した後再び、$_SESSION['abc'] = $abc; などにして再度セッションにいれればなと考えていますが、
うまくいきません。
そこで何かいいほうほうは無いものかと。
614:nobodyさん
09/01/30 12:27:38
悔しいっ・・・でも・・・触っちゃう・・・っ(ビクビク
>>613
cookie使えよ。sessionなんかにそんなん入れんな。
sessionに入れるならログアウト=専用スタイルシート破棄として使え。
$_SESSION と session_*()を勉強し直して来い
615:nobodyさん
09/01/30 23:37:15 gxYTwHzL
URLリンク(epg.2ch.net)
から、別サーバー(自分のブログとか)に
スレの勢いと局、番組名だけを取得して表示させることってできますか?
616:nobodyさん
09/01/30 23:39:57
うん
617:nobodyさん
09/01/31 00:20:10 Zjr5MV5E
<form action="<?= $_SERVER['PHP_SELF']; ?>" method="POST">
<input type="text" name="textbox" value="">
<input type="submit" value="送信">
</form>
<?php
$text = htmlspecialchars( $_POST["textbox"] );
if ( get_magic_quotes_gpc() ) {
$text = stripslashes( $text );
}
print $text;
?>
これ、ゲストの人がコメント書き込むくらいならいいんだけど、自分が投稿しようと思った時に
$_SERVER['PHP_SELF'];が入っているからエディットページ(管理人専用の編集ページ)かなんかでindex.phpに書き込めないと思うんだ。
エディットページでindex.phpに反映させる方法ってない?
618:nobodyさん
09/01/31 00:28:12
エディットページで$_SERVER['PHP_SELF']にしなければいいのでは?
619:nobodyさん
09/01/31 00:41:31 Zjr5MV5E
お!というとどういう風に記述すればいいですか?
620:nobodyさん
09/01/31 00:42:37
ファイル名
621:nobodyさん
09/01/31 00:42:41
>>615 $rtn = file_get_contents( 'URLリンク(epg.2ch.net) ' );
>>617 漏れは神様でもエスパーでもないんだから、
おまいのやりたいことを補完して理解なんかできない。
質問は相手に理解できるように書こう。
でも <input type=hidden name=action value=edit>
とか場合わけしる
622:nobodyさん
09/01/31 00:43:50
なぜにhidden使う必要が?
623:nobodyさん
09/01/31 01:07:34 Zjr5MV5E
>>621 説明足らずで すまん ありがとう。要は管理人専用ページでこのスクリプトを使用した時に$_SERVER['PHP_SELF']だと現在いじってる(管理人専用ページ)でスクリプトが実行されてしまうんではないかと。
あくまで表示したいのはindex.phpなので、そこんとこどうなんかなーと思いまして。
>>620
と、いうことは$_SERVER['PHP_SELF']を$_SERVER['index.php']にしたらいいってことですか?
624:nobodyさん
09/01/31 01:09:00
お前は何を言ってるんだ?
625:615
09/01/31 01:27:06 myPf0iH/
>>621
<?php
$temp = "URLリンク(epg.2ch.net)";
$html_f=file_get_contents($temp);
$replace = "(2)";
$scriptphp = "<br />";
$word = str_replace($replace, $scriptphp, $html_f);
$hogeru = ".dat<>";
$gogeta = "<br />";
$yabai = str_replace($hogeru, $gogeta, $word);
print $yabai;
print($word1_a);
?>
から、偶数行だけ表示するにはどうしたらいいんでしょうか?
626:nobodyさん
09/01/31 01:27:12 Zjr5MV5E
すみません。ようやく分かってきました。
$_SERVER['PHP_SELF'] これ書かなきゃいいんですね。
じゃあそのかわりformのactionにはなんて書けばいいんですかね?
627:nobodyさん
09/01/31 01:28:37
actionの意味知らんの?
628:nobodyさん
09/01/31 01:30:22 Zjr5MV5E
正直なところform処理いじったことがありませんもので…。非常に申し訳ないんですが教えてくれると助かります…
629:621
09/01/31 01:35:09
>>625 最初からそれをいいたまへ
$rtn = file( 'URLリンク(epg.2ch.net) ' );
for ( $n = 0; $n < count( $rtn ); $n = $n + 2 ) echo $rtn[$n];
630:621
09/01/31 01:38:56
>>623 やっと意味がわかった。管理人は管理人ようのページを作り給え
631:nobodyさん
09/01/31 01:46:56 Zjr5MV5E
>>630ありがとうございます。じゃあ$_SERVER['PHP_SELF']はいらないってことですかね?
632:nobodyさん
09/01/31 01:55:22
>>631
<? // index.php
if ( $_POST['textbox' != '' ) { なんか処理 }
?>
<html><body>
<form action="index.php" method="post>
<input type="text" name="textbox" value=""><input type="submit"
</form>
</body></html>
と
<? // kanri_index.php
if ( $_POST['textbox' != '' ) { なんか処理 }
?>
<html><body>
<form action="kanri_index.php" method="post>
<input type="text" name="textbox" value=""><input type="submit"
</form>
</body></html>
を作れ
633:nobodyさん
09/01/31 01:59:14
いやindex.phpでいいだろ
634:nobodyさん
09/01/31 02:06:10
色んなやり方あるけど初心者だそうだからいちばん新ぷりに
635:nobodyさん
09/01/31 13:18:26 Zjr5MV5E
ありがとうございます!ようやくわかった気がします。actionって動作させたいファイル名を指定したらいいんですね。
これでなんとかなりそうです。ありがとうございました!
636:nobodyさん
09/01/31 19:25:28
prepareの使い方で質問があります。
下記のコードを実行すると
Call to a member function prepare() on a non-object
とエラーが返ってきます。
$sql = "insert into table (column2,column1) values(?,?)";
$sth = $this->db->prepare($sql);
$result = $this->db->execute($sth, array($column2_value,$column1_value));
プレースホルダを使わずqueryを発行すると問題なくdbが更新されるのですが、
どこかおかしいのでしょうか
637:nobodyさん
09/01/31 19:26:42
すみません、環境書き忘れました。
php5,postgresです
638:nobodyさん
09/01/31 19:28:26
>636
どのクラスのprepareだよこの馬鹿馬鹿まんこ!
$this->dbが接続失敗か何かで初期化されていないように思われる。
639:nobodyさん
09/01/31 20:01:51
レスどうもありがとうございます。
そのあたりを探ってみます。
640:nobodyさん
09/01/31 20:02:31
いや$dbのnewしてるとこ見れば一発だろw
641:nobodyさん
09/01/31 20:16:52
出来ました。どうもありがとうございます。
さっきのエラーは昔書いたクラスコピペして直したら出なくなったのですが、
dbが更新されなくて悩んでいたら文字コードの違いが原因でした。
mb_convert_encodingで挿入する値をdbの文字コードに直して解決しました。
お世話様でした。
642:nobodyさん
09/01/31 20:23:42 QDNvJIlq
sqlite php5 利用です。
登録メールアドレスの重複チェックをしたいのですが、うまく動きません。
if(!$db=sqlite_open("database/database.sqlite",0666,$err)){
die("データベース接続エラー".$err."<br>");
}
////////////////////////////データベース二重登録防止////////////////
$check_sql="SELECT * FROM add_table WHERE add = '$mailadd'";
if($abc = sqlite_query($db,$check_sql)){
header("Location: mail.php?miss=miss&miss_naiyou=sumi");
//登録済みの場合は飛ばす
}
sqlite_close($db); //データベースクローズ
643:nobodyさん
09/01/31 20:26:51
>>642
URLリンク(jp2.php.net)
644:nobodyさん
09/01/31 20:31:10 lgngjuqH
<?php
$temp = "URLリンク(epg.2ch.net)";
$html_f=file_get_contents($temp);
$br = "<br />";
$replace = "(2)";
$word = str_replace($replace, $br, $html_f);
$replace = ".dat<>";
$word = str_replace($replace, $br, $word);
$replace = "res/min";
$word = str_replace($replace, $br, $word);
$replace = "] ";
$word = str_replace($replace, $br, $word);
$a = explode( "<br />", $word );
$b[0]= "g";
print $a[2]; print $br; //…(1)
print $b[0]; print $br;
$strs[0] = "srename :"+ $a[2] +",";//…(2)
$strs[1] = $b[0];
print $strs[0]; print $br;//…(3)
print $strs[1];
?>
出力
[NHK総合]探検ロマン世界遺産
g
0
g
(3)の$strs[0] が0になってしまうのはなんでですか?
おねがいします。
645:nobodyさん
09/01/31 20:33:43 QDNvJIlq
>>643
マニュアル見てもさっぱりわかりません
646:nobodyさん
09/01/31 20:39:00
>>644
+を.にかえてみ
647:nobodyさん
09/01/31 20:40:47
>>645
じゃ諦めれ
648:nobodyさん
09/01/31 20:42:10
>>646
おーできました
ありがとうございます!!
649:nobodyさん
09/01/31 20:59:19 QDNvJIlq
>>642
解決しました。
if(sqlite_fetch_array(sqlite_query($db,$check_sql))){
header("Location: mailmagazine.php?miss=miss&miss_naiyou=sumi");
}
>>643
ありがとうございます
650:nobodyさん
09/02/01 21:04:08
質問です
elseif (preg_match("/^\d{8}$/", $_GET["id"])){
$id = $_GET["id"];
}
GETで8桁の数字のみ受け取るように↑のようにしましたが
if文でマッチしてても変数に代入する際はpreg_matchなりで
GET変数内を数字のみとなるように変換した方がいいものなんでしょうか
651:nobodyさん
09/02/01 21:10:26
お前は何を言ってるんだ
652:nobodyさん
09/02/01 21:11:12
>650
俺ならctype_digit($str) && strlen($str) === 8
まあそれはそれとして、別にいいんじゃね。その正規表現にマッチしてるなら間違いなく数字だけだし。
653:nobodyさん
09/02/01 21:16:32
末尾の$は改行にもマッチするから数字だけとは限らないんじゃ?
654:nobodyさん
09/02/01 22:42:37
ググってたら遅くなりました
>>652
matchに漏れがなければ問題ないように思たんですが
あげてもらった関数の方が確実 でしょうか
>>653
正規表現はまだよくはわかってないのですがググったところ
\r\nのことでしょうか。
URLリンク(scripting.cocolog-nifty.com)
ここを参考に一応"/^\d{8}\r?$/"としてみましたが
>hoge$に掛かりません
の理屈が今一わかりません。
655:650
09/02/01 22:56:05
よく考えたら\rが混じる時点で正常なデータではないので
もとの"/^\d{8}$/"で問題なしな気がしますがどうなんでしょう
656:652
09/02/01 23:22:37
重視したのは分かりやすさ。正規表現だと、何を意味しているのか分かりづらい。
パターンがよほど複雑な時以外は正規表現は避けたほうがいい。
>653-654
改行とか忘れてたわ。
if(preg_match("/^\d{8}$/", "12345678\n")){
echo 'match';
}
657:nobodyさん
09/02/03 00:43:02
半年ロムってろと言われてずっと見てきたが
もうPHP諦めることにした。さっぱり分からん。
このスレのどこが超初心者用なんだ。
658:nobodyさん
09/02/03 01:51:58
3年ROMってろ
659:nobodyさん
09/02/03 02:00:14
もう、諦めたんだ放って置いてくれw
プログラムなんて嫌いだ。
660:nobodyさん
09/02/03 09:47:26
何が分かんないんだよ
661:nobodyさん
09/02/03 10:34:27
放っておいてやれよ
662:nobodyさん
09/02/03 14:10:58
なんか残念だな...。
このスレだけ読み続けても、超初心者が分かるようにはならないと思う。
このスレは、超初心者も質問していいというだけで、来る質問が全部、
超初心者向けというわけではないから。
もう見てないかもしれないけれど、入門書を図書館とかで借りてきたほうが
いいと思うよ。
663:nobodyさん
09/02/03 14:18:03
PHPなんってググって触ってみりゃ、どうにでもなるものを、
半年もROMってわからないなんて、ネタに決まってるだろ
もしネタじゃないなら、10年はROMるべき。
そうして人生が終わるさ
664:nobodyさん
09/02/03 20:28:48
人生も諦めたらスッキリするのに
665:nobodyさん
09/02/04 06:33:54
>>664
全く原因が分からないのでお聞きしたいのですが…
$im=createimagefromjpeg(image.jpg);
imagejpeg($im);
destroy
上記の様な単純な記述で画像を開きたいのですが、
ローカルならできるのになぜかインターネット経由だと
できないのです…
実行すると半角で「リ」と表示されるだけで
print hoge;などを付け足しても何もかわりません
phpinfoでGDが使えることは確認したのですが、
他に原因が思いつきません
初心者丸出しすいませんが教えていただければ尻丸出しにしますのでどうかお願いします
666:nobodyさん
09/02/04 06:34:18
>>664
全く原因が分からないのでお聞きしたいのですが…
$im=createimagefromjpeg(image.jpg);
imagejpeg($im);
destroy
上記の様な単純な記述で画像を開きたいのですが、
ローカルならできるのになぜかインターネット経由だと
できないのです…
実行すると半角で「リ」と表示されるだけで
print hoge;などを付け足しても何もかわりません
phpinfoでGDが使えることは確認したのですが、
他に原因が思いつきません
初心者丸出しすいませんが教えていただければ尻丸出しにしますのでどうかお願いします
667:nobodyさん
09/02/04 06:50:26
image.jpgがないんでね?
668:nobodyさん
09/02/04 08:17:43
>>666
MIMEヘッダー出してる?
669:nobodyさん
09/02/04 10:03:22
ああそれだな
670:nobodyさん
09/02/04 17:18:03
>>667
確かにファイルは存在しています・・・
>>668
MIMEヘッダーは
header("content-type: image/jpeg");
で出力できてますでしょうか?
ご指摘の後にこれを追加してやってみてのですがだめでした。
ただ、文字化けのような表示から画像を表示できていないマーク?
のような表示にはかわりました・・・
671:nobodyさん
09/02/04 17:25:29
>>670
imagecreatefromjpeg
にしてみたら?
それで、$imがfalseになってないかチェック
それから、imageやheaderを出力する前に余計な出力をしないように、ソースの冒頭でob_startして、直前で破棄
672:nobodyさん
09/02/04 17:39:12
ところで皆さんPHPとMYSQLは勉強し始めて
どれくらいの期間で使えるレベルになりましたか?
673:nobodyさん
09/02/04 17:41:17
使うだけなら書籍読みつつ1日でカバーできる範囲
使いこなすまでは相当かかったが
674:nobodyさん
09/02/04 17:50:34
>>670
「image.jpg」→「"image.jpg"」
675:nobodyさん
09/02/04 18:10:51
"imagejpg"になってたりするのか
676:nobodyさん
09/02/04 18:32:32
そもそもcreateimagefromjpegなんて標準関数はないわけだが
imagecreatefromjpeg(string $filename)ならあるけど
677:nobodyさん
09/02/04 18:33:11
単純にサーバにGDライブラリがはいってないだけなんじゃね?
phpinfoみてみれ
678:nobodyさん
09/02/04 18:37:31
>>677
>>666
679:nobodyさん
09/02/04 18:37:52
>>676
>>671
680:nobodyさん
09/02/04 18:38:31
書いたとおりに載せないで情報小出しにしてる時点でもう答えようがない
681:nobodyさん
09/02/04 18:38:39
要するに釣り
682:666
09/02/04 20:04:43
お騒がせ致しました
釣りではないのです
広告自動表示のレンタルサーバーを使用していたためにうまくいかなかったようです
広告無しのサーバーでは問題なく表示できました。
ありがとうございました
683:nobodyさん
09/02/04 22:08:23
広告自動挿入のサーバーだと
ヘッダー情報ってだめなの?
684:nobodyさん
09/02/04 22:09:01
PHPの講師やりたいんだけど、
どこの学校がおすすめ?
685:nobodyさん
09/02/04 22:31:36
学校行ってまでPHP学びたいと思うか?
686:nobodyさん
09/02/04 22:37:41
>>685
だって一日で20万もらえるってよ
バカらしくてコーダーなんかやってられないよ
687:nobodyさん
09/02/04 22:41:25
SQL(SQLite)なんですが単対多のデータを取得したら
|A|a|1|
|A|a|2|
|A|b|1|
|A|b|2|
|B|c|1|
|B|d|1|
みたいになるじゃないですか。
重複した項目をまとめて(A,(a,b),(1,2)),(B,(c,d),1)な感じにする関数てあるんでしょうか。
688:nobodyさん
09/02/04 22:46:57
>>685
URLリンク(pdoj.wordpress.com)
とりあえず翻訳やってみたけど、どう?
689:nobodyさん
09/02/04 22:50:36
>>687
pdoとかMDBとかにあるよ
sqliteは知らんけど
690:nobodyさん
09/02/04 22:52:37
>>688
ドキュメントの翻訳で「~と思う」なんて普通使わない
691:nobodyさん
09/02/05 00:20:18
>>689
ありがとうございます。
探したらfetchAll(PDO::FETCH_COLUMN|PDO::FETCH_GROUP)がそれらしいです。
ただマニュアルの例で例えると
array(3) {
["apple"]=>
array(2) {
[0]=>
string(5) "apple"
[1]=>
string(5) "apple"
}
みたいな感じにカラム0の値しか取得できてないようです。
自分がどこか間違ってるのかSQLiteが対応してないのか...
もう少し試してみます。
692:nobodyさん
09/02/05 00:47:17
>>691
ほい
URLリンク(jp2.php.net)
693:nobodyさん
09/02/05 00:49:12
$str = '4,980 円';
↑みたいなフォーマットの価格データを整数値にしたいんだけど
↓よりシンプルにやる方法ってある?
$str = str_replace(array(' ', ',', '円'),array('', '', ''),$str);
694:nobodyさん
09/02/05 00:51:20
$str = (int)str_replace(',','',$str)
695:nobodyさん
09/02/05 00:54:43
ありがとうg
696:nobodyさん
09/02/06 21:22:00
>>692
MySQLでも試してみたのですが結果は同じでサンプルのような結果にならないのですが
どこか捉え違いしているのでしょうか。
PHP 5.2.6/MySQL 5.0.4
|apple|red|
|banana|yellow|
|apple|green|
という内容として、
$dbh = new PDO('mysql:~','root','root');//もしくは'sqlite:~'
$sql = "SELECT name,color FROM table1";
$sth = $dbh->prepare($sql);
$sth->execute();
$result = $sth->fetchAll(PDO::FETCH_COLUMN|PDO::FETCH_GROUP,0);
var_dump($result);
$stmt = null;
結果
array(2) {
["apple"]=>
array(2) {
[0]=>
string(5) "apple"
[1]=>
string(5) "apple"
}
["banana"]=>
array(1) {
[0]=>
string(6) "banana"
}
}
となります。
697:nobodyさん
09/02/06 21:29:26
サンプルのような結果と言われても、サンプルのような結果がどんなもんだかわからんからね。
とりあえず、FETCH_GROUPなんだし、結果が正しいように思うが?
698:nobodyさん
09/02/06 21:34:36
まぁ、試しに
PDO::FETCH_COLUMN|PDO::FETCH_GROUP
じゃなく
PDO::FETCH_ASSOC|PDO::FETCH_GROUP
にしてみたら?
699:nobodyさん
09/02/06 21:39:06
>>697
失礼、サンプルは>>692にもあるPDOStatement->fetchAllの例3です。
期待した結果は
["apple"]=>
array(2) {
[0]=>
string(5) "red"...
なんですが、>>696が正しいということはやっぱりなにか勘違いしてるのかなぁ
700:nobodyさん
09/02/06 21:43:25
あぁそれか、fetchAllの第2引数に0が入ってるじゃん、だから、カラムが制約されてる
それ、外したらどうなる?
701:nobodyさん
09/02/06 21:48:42
array(2) {
["apple"]=>
array(2) {
[0]=>
string(3) "red"
[1]=>
string(5) "green"
}
["banana"]=>
array(1) {
[0]=>
string(6) "yellow"
}
}
になったけど
702:nobodyさん
09/02/06 21:49:22
ああすまん本人じゃなくて俺の環境でやったらってことね
703:nobodyさん
09/02/06 22:07:01
>>700
あれ?どうも。0がなくてもうまく取得できなかった気がしたんですが
今0を外したらPDO::FETCH_ASSOC|PDO::FETCH_GROUP同様うまくいきました。
|PDO::FETCH_GROUPがついたときは第2引数で指定したPDO::FETCH_COLUMNを基準に
グループ化するのかと勘違いを…
実際は複数のカラムが必要なのでPDO::FETCH_NUM|PDO::FETCH_GROUPで
思った通りの結果が得られるようになりました。ありがとうございました。
>>701も確認ありがとうございます。
704:nobodyさん
09/02/06 22:11:15
fetchAll(PDO::FETCH_COLUMN|PDO::FETCH_GROUP,0); で普通に取得できたが?
後進のために原因を明らかにしといてくれ
705:nobodyさん
09/02/06 22:21:43
>>704
もし、第2引数に0が入ってても第2カラムを取得できたんならバグだと思うよ
706:nobodyさん
09/02/06 22:26:54
お前は何をいっちょるんだ?
第2引数に0を入れるということは1番目のCOLUMNを用いて残りのカラムをGROUP化するってことだぞ
707:nobodyさん
09/02/06 22:29:53
>>778
何も問題ないが
708:nobodyさん
09/02/06 22:30:55
すまん誤爆した
709:nobodyさん
09/02/06 22:57:48
>>706
デマ書いてすまん、よくわかってなかった。
そのはずだよねぇ。
710:nobodyさん
09/02/08 19:09:17
<?php
try {
function exception_error_handler($errno, $errstr, $errfile, $errline ) {
throw new ErrorException($errstr, 0, $errno, $errfile, $errline);
}
set_error_handler("exception_error_handler");
fntest();
function fntest() {echo "call function";}
} catch (ErrorException $exception){
echo "何かエラーだよ<br />";
echo $exception->getMessage()."<br />";
echo "line:".$exception->getline();
exit();
}
?>
これを実行するとFatal error: Call to undefined function fntest() in~と出ます
定義を先にするかtry~catchをなくすとエラーは出ません
何がいけないんでしょうか
711:nobodyさん
09/02/08 19:26:17
定義が後でtry~catchの中だからでは?
712:nobodyさん
09/02/08 20:00:14
>>711
まんまやん というかだめなんですか?
>次の二つの例のように、ある条件下でのみ関数が定義される場合には、その関数定義は関数がコールされる前に行われていなければなりません。
に当てはまるということでしょうか
とりあえずそういうものだということで前方で定義するようにします
713:nobodyさん
09/02/08 20:00:15
>>710
いったいどうしたらそういう書き方ができるのか知りたいわ
714:nobodyさん
09/02/08 20:35:03
Perlから入った奴なんかはそういう書き方をする事があるな。
Perlは書き方によっては、関数の宣言や定義より先に呼び出しが来てもちゃんと動く。
715:nobodyさん
09/02/08 21:05:08
PHPだって、パース対象がグローバルなら、普通にfunctionの後置定義は有効だよ。
ifやwhileやtryやfunctionの中などの節の中は後置できないだけ。
>>710なんてそんなの百も承知で釣り質問してるに決まってるだろ。
釣られてへぼい回答してんじゃねぇぞ
716:nobodyさん
09/02/08 21:07:39
ツン?
717:nobodyさん
09/02/09 00:04:48
PHPとMySQLで学習用のWEBシステムを作っているのですが
' % 等のDBにとっては迷惑な文字列が入力された場合に、それとHTML上の特殊文字に変換する
にはどうすれば良いですか?
簡単な掲示板を作ったのですが' %が入力された場合にエラーが発生し困っています。
718:nobodyさん
09/02/09 00:12:47
基礎中の基礎すぐる
719:nobodyさん
09/02/09 08:41:31
>>717
mysql_real_escape_string
addslash
720:nobodyさん
09/02/09 08:53:51
addslash ? syntax error
721:nobodyさん
09/02/09 09:16:28
データーベースにデーターをつっこむ直前に
データーベース専用のエスケープ処理をするのが普通
722:nobodyさん
09/02/09 09:20:54
データー(笑)
723:nobodyさん
09/02/09 21:42:26
>717
使える箇所ならプリペアドステートメント。これが一番安全。
URLリンク(jp2.php.net)
URLリンク(jp2.php.net)
使えない箇所ならmysql_real_escape_stringなど。
どの文字が危険かはDBによって違うので、MySQLにはMySQLの、OracleにはOracleの、SQLiteにはSQLiteの専用の関数がある。
724:nobodyさん
09/02/11 12:21:22
htmlの<base>のようにユーザのトップディレクトリを指定したいんですが、
ユーザのトップディレクトリを調べる方法はありますか?
725:nobodyさん
09/02/11 13:56:50
環境は?OSとか
726:nobodyさん
09/02/11 14:12:44
>>725
ああすみません。
開発環境はPHP5.2.6でOSXなんですがWebサーバはまだ借りてないのでどうなるかはわかりません。
PHP5でApachサーバのところを借りようとは思ってます。
なので開発環境との違いや引っ越し時のことを考えて汎用的な関数がないかと質問しました。
一応マニュアルのファイルシステム関数は目を通したんですが…
727:nobodyさん
09/02/11 14:24:23
exit()ってスクリプト終了のために多用してもいいのでしょうか?
たとえばエラーチェック時にdieの代わりに自作関数呼び出して終了みたいな場合など
function return_json($flag, $data){
if($flag == true)
$result = $data;
else
$result = "ERR:".$data;
$res = array(
"status" => $flag,
"result" => $result );
print(json_encode($res));
exit();
}
if(エラーチェック1) return_json(false,"エラー1です"); //エラーなら終了
if(エラーチェック2) return_json(false,"エラー2です"); //エラーなら終了
//最後に
return_json(true,"成功です。");
728:nobodyさん
09/02/11 14:33:34
別にいいんでは?
729:nobodyさん
09/02/11 15:13:35
関数はあくまで何かを返すだけにして、制御を握っているのは「メインのルーチン」ひとつにした方がいい。
あちこちの関数で好き勝手に処理を中断したり画面出力してたりすると、そのうち管理しきれなくなる。
同じ理由で、printするよりは文字列を返す(printは「メインのルーチン」で行なう)方がいいと思う。
俺ならreturn_json()はjsonを返すだけ(exitもprintもしない)にして
function generare_json(){
if(isError1()){
return return_json(false,"エラー1です");
}
if(isError2()){
return return_json(false,"エラー2です");
}
return return_json(true,"成功です。");
}
とし、echo generate_json()を最後に呼び出す。
exit()はスクリプトの末尾のみ、出力はこの文のみになる。
730:nobodyさん
09/02/11 15:20:37
つうか、正しいjson出力とエラー出力を別の関数にするかな。
boolを渡すより、return_error_json()の方が分かりやすい。
731:nobodyさん
09/02/11 15:23:03
>>719
ヒントをサンクス。
>>723
詳しいありがとうございます。
参考にさせて頂きます。
732:nobodyさん
09/02/11 17:07:46
>>726
ああもしかして、http://~/~user/ の部分の実ディレクトリが知りたいってこと?
733:nobodyさん
09/02/11 17:30:07
実ディレクトリでいいのかな?ローカルでいえば
/Applications/MAMP/htdocs/
となります。
実行ファイルがトップにあるわけではないので相対パスでのファイル指定より
基点からの絶対パスのほうがわかりやすいかなと。
734:724,733
09/02/11 17:31:27
>>732
アンカーわすれてたので念のため
735:nobodyさん
09/02/11 17:45:24
>>733
dirname(__FILE__) とか getcwd() とか
そういうこと?
736:nobodyさん
09/02/11 17:47:36
>>733
$_SERVER['DOCUMENT_ROOT']
737:nobodyさん
09/02/11 18:00:00
ユーザー関係ないじゃんw
738:724,733
09/02/11 19:15:46
>>735,736
$_SERVER['DOCUMENT_ROOT']で希望のパスを得ることができました。
ありがとうございました。