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

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

詳細はこちら
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

2回答

786閲覧

MYSQL:データベースへ値が保存されない

fukutaro

総合スコア8

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

0クリップ

投稿2019/11/18 04:02

編集2019/11/18 04:15

PHPで入会画面、ログインログアウトのシステムを作成したいのですがうまくいきません。

1エラーメッセージが出てない為 MYSQLデータベースへの接続はできてると思うんですが 2会員情報の値が保存されていません。 3色々試してみたんですが、何も進展がない為質問をさせていただきました。 4よろしくお願いします。 5 6 7□□□□□□□発生している問題・エラーメッセージ□□□□□□□□□ 8WEBブラウザからデータベースへの会員情報の保存ができない 9 10エラーメッセージ 11なし
dbconnect.php(データベース用) <?php try { $db = new PDO('mysql:dbname=mini_bbs;host=localhost;charset=utf8','root','root'); } catch(PDOException $e) { print('DB接続エラー:'.$e->getMessage()); exit(); }
check.php(確認ページ) <?php session_start(); require('../dbconnect.php'); if (!isset($_SESSION['join'])) { header('Location:index.php'); exit(); } if (!empty($_POST)){ $statement = $db->prepare('INSERT INTO members SET name=?, email=?,picture=?,created=NOW()'); $statement->execute(array( $_SESSION['join']['name'], $_SESSION['join']['email'], sha1($_SESSION['join']['password']), $_SESSION['join']['image'] )); unset($_SESSION['join']); header('Location:thanks.php'); exit(); } ?>
ファイル名: index.php(登録ページ) <?php session_start(); 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'; } if (empty($error)){ $_SESSION['join'] = $_POST; header('Location: check.php'); exit(); } } ?> <!DOCTYPE html> <html lang="ja"> <head> <meta charset= "utf-8"> <meta name = "description" content=""> <title>登録画面</title> <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.6.3/css/all.css"> <meta name="viewport" content="width=device-width, initial-scale=1" > <link href="https://fonts.googleapis.com/css?family=Kosugi+Maru&display=swap" rel="stylesheet"> <link rel="shortcut icon" href="img/favicon.ico" /> <link rel="stylesheet" href="../css/login.css"> </head> <body> <h1 class="text-center title">会員登録</h1> <div class="formouter container" id="content"> <form action="" method="post" enctype="multipart/form-data"> <dl> <dt>名前<span class="required">必須</span></dt> <dd> <input type="textarea" placeholder="田中 太郎" name="name" value="<?php print(htmlspecialchars($_POST['name'],ENT_QUOTES)); ?>" /> <?php if ($error['name'] === 'blank'): ?> <p class="error">名前を入力してください。</p> <?php endif; ?> </dd> <dt>メールアドレス<span class="required">必須</span></dt> <dd> <input type="textarea" placeholder="exampla@example.com" name="email" value="<?php print(htmlspecialchars($_POST['email'],ENT_QUOTES)); ?>" /> <?php if($error['email'] === 'blank'): ?> <p class="error">メールアドレスを入力してください。</p>  <?php endif; ?> </dd> <dt>写真など</dt> <dd> <input type ="file" name="image" size="35"> <?php if ($error['image'] === 'type'): ?> <p class="error">写真などは[.gif]または[.jpg]または[.png] の画像を指定してください。</p>  <?php endif; ?> <?php if(!empty($error)): ?> <p class="error">恐れ入りますが、画像を改めて指定してください</p> <?php endif; ?> </dd> <dt>パスワード<span class="required">必須</span></dt> <dd> <input type="password" placeholder="パスワードを入力してください" size="10" maxlength="20" name="password" value="<?php print(htmlspecialchars($_POST['password'],ENT_QUOTES)); ?>" /> <?php if ($error['password'] === 'length'): ?> <p class="error">パスワードは4文字以上で入力してください。</p> <?php endif; ?> </dd> </dl> <div> <input type="submit" class="btn test" value="確認する"> </div> </form> </div> </body> </html>

試したこと

パスの確認
MYSQLのID passwordの確認
コードの確認

補足情報(FW/ツールのバージョンなど)

PHP 5.6.30

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

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

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

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

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

fukutaro

2019/11/18 04:19

コードの修正のご指導、ありがとうございます。 CREATE TABLE追記 早速やってみます。
guest

回答2

0

メンテを考えたらこっちを参考にした方が良さげ。PHPでPDOを使ってMySQLに接続、INSERT, UPDATE, DELETE, COUNT, SUM

投稿2019/11/18 04:45

Orlofsky

総合スコア16417

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

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

0

ベストアンサー

$db = new PDO('mysql:dbname=mini_bbs;host=localhost;charset=utf8','root','root');

をしたらエラーモード設定をするようにしてください

PHP

1 $db = new PDO('mysql:dbname=mini_bbs;host=localhost;charset=utf8','root','root'); 2 $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

投稿2019/11/18 04:05

yambejp

総合スコア116694

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問