🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
PHP

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

Q&A

解決済

2回答

846閲覧

表示はされるのですが、 少しおかしいような気がします。

退会済みユーザー

退会済みユーザー

総合スコア0

PHP

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

0グッド

0クリップ

投稿2019/12/31 08:30

編集2020/01/01 03:31

「よくわかるPHPの教科書」の参考書を利用して勉強しています。表示はされるのですが、
少しおかしいような気がします。
「check_step5_1.php」の</form>のすぐ上の

<div><a href="index.php?action=rewrite">&laquo;&nbsp;書き直す</a> | <input type="submit" value="登録する" /></div> の箇所の「index.php」は「index_step5_2.php」にして <div><a href="index_step5_2.php?action=rewrite">&laquo;&nbsp;書き直す</a> | <input type="submit" value="登録する" /></div> とすべきなのですが、「index_step5_2.php」にすると、なにも表示されません。 <div><a href="index.php?action=rewrite">&laquo;&nbsp;書き直す</a> | <input type="submit" value="登録する" /></div> とすると今打ち込んだデータが再現されます。

どこか間違っていると思い検討したのですが、探し出せません。
よろしくお願いいたします。

実行した後のURLは「php_sample/part5_2_sample/join/step5/index_step5_5.php?action=rewrite」です。
実行後の画面です。

イメージ説明
頂きましたネットは既に拝見済みですが、まだよく消化できていません。

php

1//index_step5_2.php 2 3<?php 4 require('../dbconnect.php'); 5 6 session_start(); 7 $input_name = filter_input(INPUT_POST, 'name'); 8 9 $input_email = filter_input(INPUT_POST, 'email'); 10 11 $input_password = filter_input(INPUT_POST, 'password'); 12 13 $input_image = filter_input(INPUT_POST, 'image'); 14 15 if (!empty($_POST)) { 16 17 // エラー項目の確認 18 if ($_POST['name'] == '') { 19 $error['name'] = 'blank'; 20 } 21 if ($_POST['email'] == '') { 22 $error['email'] = 'blank'; 23 } 24 if (strlen($_POST['password']) < 4) { 25 $error['password'] = 'length'; 26 } 27 if ($_POST['password'] == '') { 28 $error['password'] = 'blank'; 29 } 30 31 $fileName = $_FILES['image']['name']; 32 33 if (!empty($fileName)) { 34 35 $ext = substr($fileName, -3); 36 37 if ($ext != 'jpg' && $ext != 'gif') { 38 $error['image'] = 'type'; 39 } 40 } 41 42 // 重複アカウントのチェック 43 if (empty($error)) { 44 $sql = sprintf('SELECT COUNT(*) AS cnt FROM members WHERE email="%s"', 45 mysqli_real_escape_string($db, $input_email) 46 ); 47 $record = mysqli_query($db, $sql) or die(mysqli_error($db)); 48 49 $table = mysqli_fetch_assoc($record); 50 51 if ($table['cnt'] > 0) { 52 $error['email'] = 'duplicate'; 53 } 54 } 55 56 if (empty($error)) { 57 58 // 画像をアップロードする  59 $image = date('YmdHis') . $_FILES['image']['name']; 60 61 move_uploaded_file($_FILES['image']['tmp_name'], '../member_picture/' . $image); 62 63 $_SESSION['join'] = $_POST; 64 65 $_SESSION['join']['image'] = $image; 66 67 header('Location: check_step5_1.php'); 68 exit(); 69 } 70 } 71 72 // 書き直し 73 // 書き直し 74 if (isset($_REQUEST['action']) && $_REQUEST['action'] == 'rewrite'){ 75 $_POST = $_SESSION['join']; 76 $error['rewrite'] = true; 77 } 78?> 79 80<!DOCTYPE> 81<html> 82<head> 83 <meta charset="UTF-8" /> 84 <link rel="stylesheet" type="text/css" href="../style.css" /> 85 <title>会員登録</title> 86</head> 87 88<body> 89<div id="wrap"> 90 <div id="head"> 91 <h1>会員登録</h1> 92 </div> 93 94 <div id="content"> 95 96 <p>次のフォームに必要事項をご記入ください。</p> 97 98 <form action="" method="post" enctype="multipart/form-data"> 99 <dl> 100 <dt>ニックネーム<span class="required">必須</span></dt> 101 <dd> 102 <input type="text" name="name" size="35" maxlength="255" 103 value="<?php echo htmlspecialchars($input_name, 104 ENT_QUOTES, 'UTF-8'); ?>" /> 105 <?php if ($input_name == 'blank'): ?> 106 <p class="error">* ニックネームを入力してください</p> 107 <?php endif; ?> 108 </dd> 109 110 <dt>メールアドレス<span class="required">必須</span></dt> 111 <dd> 112 <input type="text" name="email" size="35" maxlength="255" 113 value="<?php echo htmlspecialchars($input_email, 114 ENT_QUOTES, 'UTF-8'); ?>" /> 115 <?php if ($input_email == 'blank'): ?> 116 <p class="error">* メールアドレスを入力してください</p> 117 <?php endif; ?> 118 119 <?php if ($input_email == 'duplicate'): ?> 120 <p class="error">* 指定されたメールアドレスはすでに登録されています</p> 121 <?php endif; ?> 122 </dd> 123 124 <dt>パスワード<span class="required">必須</span></dt> 125 <dd> 126 <input type="password" name="password" size="10" maxlength="20" 127 value="<?php echo htmlspecialchars($input_password, 128 ENT_QUOTES, 'UTF-8'); ?>" /> 129 <?php if ($input_password == 'blank'): ?> 130 <p class="error">* パスワードを入力してください</p> 131 <?php endif; ?> 132 133 <?php if ($input_password == 'length'): ?> 134 <p class="error">* パスワードは4文字以上で入力してください</p> 135 <?php endif; ?> 136 </dd> 137 138 <dt>写真など</dt> 139 <dd> 140 <input type="file" name="image" size="35" value="test" /> 141 142 <?php if ($input_image == 'type'):?> 143 <p class="error">* 写真などは「.gif」または「.jpg」の画像を指定してください</p> 144 <?php endif; ?> 145 146 <?php if (!empty($error)): ?> 147 <p class="error">* 恐れ入りますが、画像を改めて指定してください</p> 148 <?php endif; ?> 149 </dd> 150 </dl> 151 <div><input type="submit" value="入力内容を確認する" /></div> 152 </form> 153 </div> 154 155 <div id="foot"> 156 <p><img src="../images/txt_copyright.png" width="136" height="15" alt="(C) H2O SPACE, Mynavi" /></p> 157 </div> 158 159</div> 160</body> 161</html> 162

php

1//check_step5_1.php -->check_step5_2.phpに変更 2 3<?php 4session_start(); 5require('../dbconnect.php'); 6 7if (!isset($_SESSION['join'])) { 8 header('Location: index_step5_2.php'); 9 exit(); 10} 11 12 13?> 14 15<!DOCTYPE> 16<html> 17<head> 18 <meta charset="UTF-8" /> 19 <link rel="stylesheet" type="text/css" href="../style.css" /> 20 <title>会員登録</title> 21</head> 22 23<body> 24<div id="wrap"> 25<div id="head"> 26<h1>会員登録</h1> 27</div> 28 29<div id="content"> 30<p>記入した内容を確認して、「登録する」ボタンをクリックしてください</p> 31<form action="" method="post"> 32 <input type="hidden" name="action" value="submit" /> 33 <dl> 34 <dt>ニックネーム</dt> 35 <dd> 36 <?php echo htmlspecialchars($_SESSION['join']['name'], ENT_QUOTES, 'UTF-8'); ?> 37 </dd> 38 <dt>メールアドレス</dt> 39 <dd> 40 <?php echo htmlspecialchars($_SESSION['join']['email'], ENT_QUOTES, 'UTF-8'); ?> 41 </dd> 42 <dt>パスワード</dt> 43 <dd> 44 【表示されません】 45 </dd> 46 <dt>写真など</dt> 47 <dd> 48 <img src="../member_picture/<?php echo htmlspecialchars($_SESSION['join']['image'], ENT_QUOTES, 'UTF-8'); ?>" width="100" height="100" alt="" /> 49 </dd> 50 </dl> 51 <div><a href="index_step5_2.php?action=rewrite">&laquo;&nbsp;書き直す</a> | <input type="submit" value="登録する" /></div> 52</form> 53</div> 54 55<div id="foot"> 56<p><img src="../images/txt_copyright.png" width="136" height="15" alt="(C) H2O Space. MYCOM" /></p> 57</div> 58 59</div> 60</body> 61</html> 62

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

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

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

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

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

m.ts10806

2019/12/31 08:41

ちなみに「なにも表示されません」とはどうなってるのでしょうか。
退会済みユーザー

退会済みユーザー

2019/12/31 09:01

実行した後のURLは「php_sample/part5_2_sample/join/step5/index_step5_5.php?action=rewrite」です。
m.ts10806

2019/12/31 09:05

どういう操作をした時ですか? submitボタンを押した時?それともリンクやURLでアクセスしたとき?
退会済みユーザー

退会済みユーザー

2019/12/31 09:13

会員登録画面の打ち込みをして、正常に表示された後、登録する前に書き直し画面に戻った時の表示です。 index_step5_2.phpのphp部分の「if (!empty($_POST)) {}」はいらないのかなと思って、 削除しようとしたのですが、よくわからないので後から検討するつもりです。
m.ts10806

2019/12/31 09:16

「画面遷移」ならREQUEST METHODはGETなのでPOSTで参照できる情報はありません。 filter_input()の結果もNULLでしょう。
退会済みユーザー

退会済みユーザー

2019/12/31 09:17

<div><a href="index.php?action=rewrite">&laquo;&nbsp;書き直す</a> とすると 登録画面の書き込み、書き直し、登録、完了画面は正常に動いています。
m.ts10806

2019/12/31 09:18 編集

「とすると」と言われても、そのあとどういう操作したのか書かれないと誰も再現できませんので。 要は他者が再現できるコード、その後の操作手順まで具体的に提示していただく必要があります。
退会済みユーザー

退会済みユーザー

2019/12/31 09:46

XAMPPを使って登録画面「index_step5_2.php」実行します。次に登録画面が表示されるので、テキスト画面に「ニックネーム」「メールアドレス」「パスワード」を記入して「image画像を選択」で画像を選択したのちにクリックすると、入力テキスト、画像が表示されます。ここで「書き直しボタン」をクリックしたときに、表示がうまくいきません。上の書き込みのように、「check_step5_1.php」を変更すると 「書き直しボタン」を押したときにもとの打ち込みが再現できます。
退会済みユーザー

退会済みユーザー

2019/12/31 10:25

index.phpからindex_step5_2.phpを導いているので、index_step5_2.phpのどこかがも違っていると思われます。check_step5_1.phpから遷移するindex.phpは正常動作をしているので、index_step5_2.phpを精査してみます。
guest

回答2

0

ベストアンサー

「画面遷移」なのでREQUEST METHODはGETなのでPOSTで参照できる情報はありません。
filter_input()の結果もNULLでしょう。

$_SESSIONに入れてたとしてもその$_SESSIONを参照している実装になってませんし。

投稿2019/12/31 09:56

m.ts10806

総合スコア80875

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

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

退会済みユーザー

退会済みユーザー

2020/01/01 03:49

自分で修正をして書き換えのとき、打ち込みデータが再現できるようになりましたが、@$_POST['name']を 使ったので、間違いがあるか心配です。コードについて直したほうがいい箇所があったら教えてください。 お願いいたします。
guest

0

コードの変更修正をしました
//index_step5_2.php

<?php require('../dbconnect.php'); session_start(); $input_action = ""; if(array_key_exists('action',$_GET)){ $input_action = $_GET['action']; } if (!empty($_POST)) { // エラー項目の確認 if ($_POST['name'] == '') { $error['name'] = 'blank'; } if ($_POST['email'] == '') { $error['email'] = 'blank'; } if (strlen($_POST['password']) < 4) { $error['password'] = 'length'; } if ($_POST['password'] == '') { $error['password'] = 'blank'; } $fileName = $_FILES['image']['name']; if (!empty($fileName)) { $ext = substr($fileName, -3); if ($ext != 'jpg' && $ext != 'gif') { $error['image'] = 'type'; } } // 重複アカウントのチェック if (empty($error)) { $sql = sprintf('SELECT COUNT(*) AS cnt FROM members WHERE email="%s"', mysqli_real_escape_string($db, $_POST['email']) ); $record = mysqli_query($db, $sql) or die(mysqli_error($db)); $table = mysqli_fetch_assoc($record); if ($table['cnt'] > 0) { $error['email'] = 'duplicate'; } } if (empty($error)) { // 画像をアップロードする  $image = date('YmdHis') . $_FILES['image']['name']; move_uploaded_file($_FILES['image']['tmp_name'], '../member_picture/' . $image); $_SESSION['join'] = $_POST; $_SESSION['join']['image'] = $image; header('Location: check_step5_2.php'); exit(); } } // 書き直し if ($input_action == 'rewrite') { $_POST = $_SESSION['join']; } ?> <!DOCTYPE> <html> <head> <meta charset="UTF-8" /> <link rel="stylesheet" type="text/css" href="../style.css" /> <title>会員登録</title> </head> <body> <div id="wrap"> <div id="head"> <h1>会員登録</h1> </div> <div id="content"> <p>次のフォームに必要事項をご記入ください。</p> <form action="" method="post" enctype="multipart/form-data"> <dl> <dt>ニックネーム<span class="required">必須</span></dt> <dd> <input type="text" name="name" size="35" maxlength="255" value="<?php echo htmlspecialchars(@$_POST['name'], ENT_QUOTES, 'UTF-8'); ?>" /> <?php if(!empty($error['name']) && $error['name'] == 'blank'): ?> <p class="error">* ニックネームを入力してください</p> <?php endif; ?> </dd> <dt>メールアドレス<span class="required">必須</span></dt> <dd> <input type="text" name="email" size="35" maxlength="255" value="<?php echo htmlspecialchars(@$_POST['email'], ENT_QUOTES, 'UTF-8'); ?>" /> <?php if(!empty($error['email']) && $error['email'] == 'blank'): ?> <p class="error">* メールアドレスを入力してください</p> <?php endif; ?> <?php if(!empty($error['email']) && $error['email'] == 'duplicate'): ?> <p class="error">* 指定されたメールアドレスはすでに登録されています</p> <?php endif; ?> </dd> <dt>パスワード<span class="required">必須</span></dt> <dd> <input type="password" name="password" size="10" maxlength="20" value="<?php echo htmlspecialchars(@$_POST['password'], ENT_QUOTES, 'UTF-8'); ?>" />
<?php if(!empty($error['password']) && $error['password'] == 'blank'): ?> <p class="error">* パスワードを入力してください</p> <?php endif; ?> <?php if(!empty($error['password']) && $error['password'] == 'length'): ?> <p class="error">* パスワードは4文字以上で入力してください</p> <?php endif; ?> </dd> <dt>写真など</dt> <dd><input type="file" name="image" size="35" value="test" /> <?php if(!empty($error['image']) && $error['image'] == 'type'): ?> <p class="error">* 写真などは「.gif」または「.jpg」の画像を指定してください</p> <?php endif; ?> <?php if (!empty($error)): ?> <p class="error">* 恐れ入りますが、画像を改めて指定してください</p> <?php endif; ?> </dd> </dl> <div><input type="submit" value="入力内容を確認する" /></div>
</form> </div> <div id="foot"> <p><img src="../images/txt_copyright.png" width="136" height="15" alt="(C) H2O SPACE, Mynavi" /></p> </div> </div> </body> </html>

//check_step5_1.php --->check_step5_2.php に変更修正しました。

投稿2020/01/01 03:33

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

退会済みユーザー

退会済みユーザー

2020/01/01 03:44

<input type="text" name="name" size="35" maxlength="255" 『value="<?php echo htmlspecialchars(@$_POST['name'], ENT_QUOTES, 'UTF-8'); ?>" /> <?php if(!empty($error['name']) && $error['name'] == 'blank'): ?> <p class="error">* ニックネームを入力してください</p>』 のように変更しました。あとのメールアドレス、パスワードも同じように変更しています。 書き換えの時にどうしても打ち込んだデータが消えるので『@$_POST['name']』にしたのですが、 これでいいのかしっくりいきません。 とりあえず書き込み、書き換えが出来るようになりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問