yopisan
@yopisan (kota)

Are you sure you want to delete the question?

Leaving a resolved question undeleted may help others!

sqlとphpの接続がうまくいかない

問い合わせフォームから送信されたデータをテーブルに登録できない

現在dbについて取り組んでいる最中で、sqlとphpの接続がうまくいかないのでどこがいけないのかご教授お願いしたいです。

発生している問題・エラー

接続失敗SQLSTATE[HY000] [1045] Access denied for user 'cafe/contacts'@'localhost' (using password: YES)

該当するソースコード

db_connection.php
<?php

const DB_HOST = 'mysql:dbname=cafe;host=127.0.0.1;charset=utf8';
const DB_USER = 'cafe/contacts';
const DB_PASSWORD = 'ykb02566';
// 例外処理 Exception
try{
  $pdo = new PDO(DB_HOST, DB_USER, DB_PASSWORD);
    echo '接続成功';
} catch(PDOException $e){
  echo '接続失敗'.$e->getMessage()."<br>";
  exit();
}
contact.php
 <?php include 'layouts/header.php'; ?>
    <?php  session_start() ?>
    <div class="form-wrapper">
      <div class="error">
        <h1>
          <?php 
            if(isset($_SESSION["texts"])){
            foreach($_SESSION["texts"] as $error){
              echo $error."<br>";
              }
            }?>
        </h1>
      </div>        
      <div class="form">
        <div class="form-title">
          <h1 style="text-align:center;">お問い合わせ </h1>
        </div>
        <div class="form-main">
          <div class="back">  
            <h2>下記の項目をご記入の上送信ボタンを押してください</h2>
          </div>  
            <p>送信頂いた件につきましては、当社より折り返しご連絡を差し上げます。<br>
               なお、ご連絡までに、お時間を頂く場合もございますので予めご了承ください。<br>
            <span>*</span>は必須項目となります。</p>
            <form action="" method="POST">
              <div class="form-contents">
                <div class="form-content">
                  <h3>氏名<span>*</span></h3>
                  <input type="text" name="name" 
                    value="<?php 
                      if(!empty($_SESSION["name"])){
                        echo $_SESSION["name"];
                      }
                      ?>" placeholder="山田太郎" class="inputName">
                </div>
                <div class="form-content">
                  <h3>フリガナ<span>*</span></h3>
                  <input type="text" name="kana" 
                    value="<?php 
                      if(!empty($_SESSION["kana"])){
                        echo $_SESSION["kana"];
                      }
                      ?>" placeholder="ヤマダタロウ" class="inputKana">
                </div>
                <div class="form-content">
                  <h3>電話番号</h3>
                  <input type="text" name="phone" 
                  value="<?php 
                   if(!empty($_SESSION["phone"])){
                    echo $_SESSION["phone"];
                  }
                  ?>" placeholder="09012345678" class="inputPhone">
                </div>
                <div class="form-content">
                  <h3>メールアドレス<span>*</span></h3>
                  <input type="text" name="address"
                    value="<?php 
                    if(!empty($_SESSION["address"])){
                      echo $_SESSION["address"];
                    }
                    ?>" placeholder="test@test.co.jp" class="inputAddress">
                </div>
              </div>
              <div class="back">  
                <h2>お問い合わせ内容をご記入ください<span>*</span></h2>
              </div>  
              <textarea name="question" class="inputQuestion"><?php 
                if(!empty($_SESSION["question"])){
                  echo $_SESSION["question"];
                }?></textarea><br>
              <input type="submit" value="送    信" class="form-submit" formaction="validate.php" >
            </form>
          </div>
        </div>

comfirm.php
<?php
  session_start();
  $referer = $_SERVER['HTTP_REFERER']; 
  $url = "contact.php"; 
  if(!strstr($referer,$url)){
    header("Location: contact.php");
    exit;
  }
  unset($_SESSION["texts"]);
    $_POST = &$_SESSION;
?>


    <?php include 'layouts/header.php'; ?>

    <div class="form-wrapper">
      <div class="form">
        <div class="form-title">
          <h1 style="text-align:center;">お問い合わせ</h1>
        </div>
      <div class="confirm-group">
        <form>
          <p class=confirm-text>
            下記の内容をご確認の上送信ボタンを押してください<br>
            内容を訂正する場合は戻るを押してください。
          </p>

          <div class="confirm-contents">
            <div class="confirm-content">
              <h1>氏名</h1>
              <h2><?php echo htmlspecialchars($_POST["name"], ENT_QUOTES, 'UTF-8'); ?></h2>
            </div>
            <div class="confirm-content">
              <h1>フリガナ</h1>
              <h2><?php echo htmlspecialchars($_POST["kana"], ENT_QUOTES, 'UTF-8');  ?></h2>
            </div>
            <div class="confirm-content">
              <h1>電話番号</h1>
              <h2><?php echo htmlspecialchars($_POST["phone"], ENT_QUOTES, 'UTF-8'); ?></h2>
            </div>
            <div class="confirm-content">
              <h1>メールアドレス</h1>
              <h2><?php echo htmlspecialchars($_POST["address"], ENT_QUOTES, 'UTF-8'); ?></h2>
            </div>
            <div class="confirm-content">
              <h1>お問い合わせ内容</h1>
              <h2><?php echo nl2br(htmlspecialchars($_POST["question"], ENT_QUOTES, 'UTF-8')); ?></h2>
            </div>
          </div>
          <div class="buttons">
            <input type="submit" value="送   信" class="confirm-submit" formaction="complete.php">
            <input type="submit" value="戻   る" class="confirm-return" formaction="contact.php">
          </div>
        </form>
      </div>
    </div>
  </div>
    <?php include 'layouts/footer.php'; ?>
complete.php
<?php
  session_start(); 
  $_SESSION = array();
  session_destroy();
  $referer = $_SERVER['HTTP_REFERER']; 
  $url = "confirm.php";
  if(!strstr($referer,$url)){
    header("Location: contact.php");
  exit;
  }
  $_POST = $_SESSION;
?>
  <?php include 'layouts/header.php'; ?>

  <section>
    <div class="form" style= "margin-top:50px; margin-bottom:50px;">
      <div class="form-title">
        <h1 style="text-align:center;">お問い合わせ</h1>
      </div>
      <div class="complete-main">
          <p class=complete-text>
            お問い合わせ頂きありがとうございます。<br>
            送信頂いた件につきましては、当社より折り返しご連絡を差し上げます。<br>
            なお、ご連絡までに、お時間を頂く場合もございますので予めご了承ください。
          </p>
        <div class="top">
          <a href="index.php">トップへ戻る</a>
        </div>
      </form>
    </div>
  </div>
  </section>

<?php include 'layouts/footer.php'; ?>

自分で試したこと

phpとsqlがうまく接続できていないため
下記より参考資料をもとに真似てみたが、結果変わらなかったので、わからない。
またphpmyadminやmysqlでの学習方法などアドバイスなどもあればお願いいたします。
https://teratail.com/questions/330015

0

2Answer

よくあるパターンとして「DB_HOST」の「127.0.0.1」を「localhost」に変更すれば行けそうな気もします。

0Like

Your answer might help someone💌