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

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

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

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

PHP

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

Q&A

解決済

1回答

3157閲覧

ログイン機能を実装するため、新規登録画面をつくり、その情報をデータベースに格納したい

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

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

PHP

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

0グッド

0クリップ

投稿2015/12/19 16:18

編集2015/12/19 16:43

会員登録があるECサイトのようなログイン機能を実装するため、
新規登録から入力してもらい、そのデータをデータベースに格納することをしたいと考えています。
しかし、このソースコードのページで新規登録しようとすると、Duplicate Email!というものが出てしまいます。
この表示はメールアドレスが、他のユーザと重複した時に表示させるためのものですが
重複している時以外にも表示されてしまします。どのようにソースコードを変えたら
データベースに情報が渡せるのでしょうか?
データベースに格納したい情報はemailアドレス、パスワード、名前、住所、電話番号です。
名前、住所、電話番号のところの記述が足りないことは予測できますが、どのように書き加えたら
解決できるかわかりません。
問題がありそうなソースコードの一部を記載致します。

php-vはphp5.6,フレームワークはcakephpだと思います。(プログラミングドットインストールからアレンジしたため
ドットインストール#19ユーザ情報を格納しよう
)ここに載っているユーザ情報にプラスして、住所や電話番号、名前を追加したいです。

/lib/Signup.php

php

1<?php 2中略 3namespace MyApp\Controller; 4 5 6 7 protected function postProcess() { 8 // validate 9 try { 10 $this->_validate(); 11 } catch (\MyApp\Exception\InvalidEmail $e) { 12 $this->setErrors('email', $e->getMessage()); 13 } catch (\MyApp\Exception\InvalidPassword $e) { 14 $this->setErrors('password', $e->getMessage()); 15 }$this->setValues('email', $_POST['email']); 16 17 if ($this->hasError()) { 18 return; 19 } else { 20 // create user 21 try { 22 $userModel = new \MyApp\Model\User(); 23 $userModel->create([ 24 'email' => $_POST['email'], 25 'password' => $_POST['password'], 26 'address' => $_POST['address'], 27 'name' => $_POST['name'], 28 'phonenumber' => $_POST['phonenumber'], 29 ]); 30 } catch (\MyApp\Exception\DuplicateEmail $e) { 31 $this->setErrors('email', $e->getMessage()); 32 return; 33 } 34

Model/User.php

php

1<?php 2中略 3class User extends \MyApp\Model { 4 5 public function create($values) { 6 $stmt = $this->db->prepare("insert into users (email, password, address, phonenumber, name, created, modified) values (:email, :password, :address, :phonenumber, :name,now(), now())"); 7 $res = $stmt->execute([ 8 ':email' => $values['email'], 9 ':password' => password_hash($values['password'], PASSWORD_DEFAULT) 10 ]); 11 if ($res === false) { 12 throw new \MyApp\Exception\DuplicateEmail(); 13 } 14 }

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2015/12/19 16:29

何か特定のフレームワークを利用していそうな記述ですが、フレームワークの名前、バージョンを明記してください。
退会済みユーザー

退会済みユーザー

2015/12/19 16:47

質問を修正致しました。プログラミング学習サイトドットインストールの応用なのですがフレームワークを利用しているのでしょうか? http://dotinstall.com/lessons/sns_php_v3/35819 #19ユーザー情報を格納しよう phpのバージョンはphp5.6なのはわかっています。
退会済みユーザー

退会済みユーザー

2015/12/19 17:00 編集

もしかしていきなり応用からやってませんか? 基礎知識が不足しているように見受けられます。 回答するためにわざわざ動画みろというのでしょうか…???
退会済みユーザー

退会済みユーザー

2015/12/19 17:05

申し訳ございません。早くできるようになり、webサービスを世に出したいという焦りから、基礎をおろそかにしてしまいました。基礎からやってみようと思います。
退会済みユーザー

退会済みユーザー

2015/12/19 17:09 編集

やはりそうですよね。基礎知識がないとさすがに技術的な情報のやり取りにおいて会話が成立しませんので。ある程度のサービスを立ち上げるということなら、最低でも1年以上の学習は必要だと覚悟してください。
guest

回答1

0

ベストアンサー

この表示はメールアドレスが、他のユーザと重複した時に表示させるためのものですが
重複している時以外にも表示されてしまします。

エラーメッセージ的にはそうですが、ソースを見ると「$res === false」だったら表示されるので、
インサートが失敗したら出ます。

で、SQL文を見ると、
insert into users (email, password, address, phonenumber, name, created, modified) values (:email, :password, :address, :phonenumber, :name,now(), now())
とあり、
':email'と':password'に入力値を入れています。
しかし、:addressと:phonenumberと:nameには何も入れていません。
だからエラーになっているのではないでしょうか。

単純に考えると、
':address' => $values['address'],
':phonenumber' => $values['phonenumber'],
':name' => $values['name'],
を加えればよさそうなものですが、

エラーメッセージが不適切ですし、
address, phonenumber, nameにもバリデーションかけた方がいいですし、
問題は残ります。

投稿2015/12/20 13:28

lightwill

総合スコア962

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

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

退会済みユーザー

退会済みユーザー

2015/12/20 16:58

上記を記述し、バリエーションも追加でかけたところクリアできました。 もう少し基本を学ぶようにします。助かりました。本当にありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問