質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

2961閲覧

Notice: Undefined index: xxxx in をissetで回避できる理由と設定について

yukina00235

総合スコア63

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2020/05/05 01:24

フォームからPOSTでデータを受け取る際に必ずと言って「Notice: Undefined index: xxxx in」のエラーが表示されてしまいます。何も操作なしに、単純にそのページにアクセスした際です。

恐らく、何も選択がされていないから?だと思いますのですが、これを回避するために調べてみるとisset を使うという事が色々な記事で書かれていました。
試してみると確かにエラーは消えるのですが、記述内容の意味がいまいち理解できないのです…。
以下の記述を…、

PHP

1$signal = htmlspecialchars($_POST["signal"], ENT_QUOTES, 'UTF-8'); 2 3if($signal === "red" ){ 4 print "赤信号"; 5} elseif (){ 678}

こちらに変えるとエラーは出なくなりました。

php

1if (isset($_POST["signal"])) { 2 3$signal = htmlspecialchars($_POST["signal"], ENT_QUOTES, 'UTF-8'); 4 5if($signal === "red" ){ 6 print "赤信号"; 7} elseif (){ 8910} 11 12} // ←issetでさらに全体を囲むのですか?? 13

参考通りにただ記述はしたものの、issetでエラーが無くなる仕組みがいまいちわかりません。
$signal判定のIFの更に上でIFで全体を囲んでいるのも??

また、POSTの内容が10個20個と沢山ある場合には、1つ1つにこのような処理を行わないといけないのでしょうか?
とても初歩的な質問で恐縮ですが、よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/05/05 01:52

言語仕様を学ぼう、としかいえない
yukina00235

2020/05/07 03:01

有難うございます、もう少し調べてみたいと思います。
guest

回答1

0

ベストアンサー

言語仕様の話なのでPHPマニュアルを確認しましょう。

isset

isset — 変数が宣言されていること、そして NULL とは異なることを検査する

配列のキーも「宣言」にあたるので適用されます。

なお。

何も操作なしに、単純にそのページにアクセスした際です。

「単にURLでアクセスしたとき」はリクエストメソッド的には「GET」です。POSTは定義されていません。$_SERVERのREQUEST_METHODをチェックするやり方のほうが1つ1つ$_POST内部をチェックしなくてよくなり、ブロックも明確になるのでコードの見通しも良くなります。

ただ、$_POSTなどリクエストについてはfilter_input()のほうが同時に検査もできるのでベターです。

蛇足:
htmlspecialchars()は画面出力時に行ってください。
サニタイズ/入力値検証/エスケープの考え方

投稿2020/05/05 01:36

編集2020/05/05 01:39
m.ts10806

総合スコア80875

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yukina00235

2020/05/07 03:00

有難うございます。 その後いろいろと試してみたのですが、いまいち理解が出来ておりません…。 フォームを設定したときや、$_COOKIEなどなどPOSTとかを扱うときに毎回出てきてしまいます…。 一括で設定することはできないものなのでしょうか? 色々と参考サイトを見ましても、issetとかで大量に設定されていたりするので無理でしょうか? 個々に設定してもいいのですが、いまいち何の時に発生して、何場合にこれらの処理が必要かという根本的な部分が理解できていないです…。
m.ts10806

2020/05/07 05:16

issetよりarray_key_existsのほうが適切ではありますが、チェックボックスなどはチェックされてないとそもそも送信すらされないので個別対応は必要ですね。 ただ、回答に書いたようにREQUEST_METHODで確認されればPOSTであることは保証されるので、$_POSTをforeachで回すのもありといえばあり。 まあ、filter_inputで取得するのがundefineのチェック気にせずnullか否かで見れるのでロジックの実装に集中しやすいですけどね。
yukina00235

2020/05/07 06:57

有難うございます、1つ1つ試して考えてみたいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問