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

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

ただいまの
回答率

87.49%

PHP データを取得できない

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 304
退会済みユーザー

退会済みユーザー

MAMP環境でデータベースはphpmyadmin(mysql)を使用しています。
データベース名はshopとして以下のようにファイルの中身を記載しています。
staff_add_check.phpではPOSTされたデータを取得できているように見えますが、staff_add_done.phpではPOSTされたデータを受け取れていないためにパスワード、名前の入力エラーが出てしまいます。
データベースの設定方法で間違っていないか確認したのですが、以下のDB接続設定で間違いありますでしょうか?

<!doctype html>
<html>
<head>
<meta charset='UTF-8'>
<title>ろくまる農園</title>
</head>
<body>
スタッフ追加<br/>
<br/>
<form method = "post" action="staff_add_check.php">
スタッフ名を入力して下さい。<br/>
<input type="text" name="name" style="width:200px"><br/>
パスワードを入力して下さい。<br/>
<input type="password" name="pass" style="width:100px"><br/>
パスワードをもう一度入力して下さい。<br/>
<input type="password" name="pass2" style="width:100px"><br/>
<br/>
<input type="button" onclick="history.back()" value="戻る">
<input type="submit" value="OK">
</form>
</body>
</html>
<!doctype html>
<html>
<head>
<meta charset='UTF-8'>
<title>ろくまる農園</title>
</head>
<body>
<?php

$staff_name=$_POST['name'];
$staff_pass=$_POST['pass'];
$staff_pass2=$_POST['pass2'];

//htmlspecialcharsで特殊文字をHTMLエンティティに変換する。
//第二引数の『変換パターン』には『ENT_QUOTES』という定数を与えています。 
//ENT_QUOTESはPHPが定数としてもっているint型の値であり、ENT_QUOTESを指定すると、特殊文字のうちシングルクォーテーションとダブルクォーテーションも変換対象に含めるようになります
$staff_name=htmlspecialchars($staff_name,ENT_QUOTES,'UTF-8');
$staff_pass=htmlspecialchars($staff_pass,ENT_QUOTES,'UTF-8');
$staff_pass2=htmlspecialchars($staff_pass2,ENT_QUOTES,'UTF-8');


if($staff_name=='')
{
  print 'スタッフ名が入力されていません。<br/>';
}
else{
  print'スタッフ名:';
  print $staff_name;
  print'<br/>';
}

if($staff_pass=='')
{
  print 'パスワードが入力されていません。<br/>';
}

if($staff_pass!=$staff_pass2)
{
print 'パスワードが一致しません。<br/>';
}

if($staff_name=='' || $staff_pass=='' || $staff_pass!=$staff_pass2)
{
  print '<form>';
  //history.back() …… 一つ前のページへ戻る
  print '<input type="button" onclick="history.back()" value="戻る">';
  print '</form>';
}
else
{
  //md5で暗号化
$staff_pass = md5($staff_pass);
print '<form method="post action="staff_add_done.php">';
print '<input type="hidden" name="name" value="'.$staff_name.'">';
print '<input type="hidden" name="pass" value="'.$staff_pass.'">';
print '<br/>';
print '<input type="button" onclick="history.back()" value="戻る">';
print '<input type="submit" value="OK">';
print '</form>';
}

?>
</body>
</html>
<!doctype html>
<html>
<head>
<meta charset='UTF-8'>
<title>ろくまる農園</title>
</head>
<body>
<?php

//以下でデータベースの障害対策を行う。
try
{

  $staff_name=$_POST['name'];
  $staff_pass=$_POST['pass'];

  $staff_name=htmlspecialchars($staff_name,ENT_QUOTES,'UTF-8');
  $staff_pass=htmlspecialchars($staff_pass,ENT_QUOTES,'UTF-8'); 

  $dsn='mysql:dbname=shop;host=localhost;charset=utf8';
  $user='root';
  $password='root';
  $dbh=new PDO($dsn,$user,$password);
  //setAttributeでデータベースハンドルの属性を設定。以下でエラーモードと例外モードを設定。
  $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
  //VALUES (?,?)でSQLインジェクションと呼ばれるWebサイトの攻撃対策。?のところに、あとで数値を入れます。
  $sql='INSERT INTO mst_staff(name,password) VALUES (?,?)';
  $stmt=$dbh->prepare($sql);
  $data[]=$staff_name;
  $data[]=$staff_pass;
  $stmt->execute($data);
//データベースから切断。
  $dbh=null;

  print $staff_name;
  print 'さんを追加しました。<br/>';
}
catch(Exception $e)
{
  print'ただいま障害により大変ご迷惑をおかけしております。';
  exit();
}
?>

<a href ="staff_list.php">戻る</a>
</body>
</html>

![イメージ説明

イメージ説明

イメージ説明

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2021/01/24 16:40

    参考書籍をかえたほうが良いです。
    その書籍使った質問よく出てくるんですが、参考にしていい実装ではないです。

    キャンセル

  • kei344

    2021/01/24 23:16

    まだ質問が「受付中」になっていますが、「ベストアンサー」を選び「解決済」にされてはいかがでしょうか。

    キャンセル

回答 1

checkベストアンサー

+1

... method="post action="...

post の後のダブルクォート抜けですかね。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2021/01/24 16:45

    post の後のダブルクォート抜けでした。無事修正できました。

    キャンセル

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

  • ただいまの回答率 87.49%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る