sqlとphpの接続がうまくいかない
Q&A
Closed
問い合わせフォームから送信されたデータをテーブルに登録できない
現在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