user root2
db test3
table test3
(id int, name varchar(10))
のmysqlに
<div> <!DOCTYPE html> <html> <head> <title>フォーム画面</title> <meta charset="utf-8"> </head> <body> <h1>フォーム画面</h1></html> </div><form action="insert1.php" method="post"> 名前を入力:<input type="text" name="yourname"> <input type="submit" value="登録する"> </form> </body>
の画面から
<?php header("Content-type: text/html; charset=utf-8"); if(empty($_POST)) { header("Location: form1.html"); exit(); }else{ //名前入力判定 $yourname=filter_input(INPUT_POST,"yourname"); if ($yourname === "" ){ $errors['name'] = "名前が入力されていません。"; } $dsn = 'mysql:host=localhost;dbname=test3;charset=utf8'; $user = 'root2'; $password = 'pass'; try{ $dbh = new PDO($dsn, $user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $statement = $dbh->prepare("INSERT INTO test3 (name) VALUES (:name)"); $statement->bindValue(':name', $yourname, PDO::PARAM_STR); $statement->execute(); }catch (PDOException $e){ print('Error:'.$e->getMessage()); $errors['error'] = "データベース接続失敗しました。"; } } ?> <!DOCTYPE html> <html> <head> <title>登録画面</title> <meta charset="utf-8"> </head> <body></html><?php if (count($errors) === 0): ?> <p><?=htmlspecialchars($yourname, ENT_QUOTES, 'UTF-8')."さんで登録いたしました。"?></p> <?php elseif(count($errors) > 0): ?> <?php foreach($errors as $value){ echo "<p>".$value."</p>"; } ?> <?php endif; ?> </body>
のコードでinsertしたいのですが
Error:SQLSTATE[HY000] [1045] Access denied for user 'root2'@'localhost' (using password: YES)
データベース接続失敗しました。
というエラーコードが出ます
環境はmac os10.15 phpは7.4 mysqlは5.7なのですが どこがちがうでしょうか?