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

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

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

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

PHP

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

Q&A

解決済

3回答

4986閲覧

「気づけばプロ並みPHP(著:谷藤 賢一)」をMacで読了された方、教えてください!

Akirax

総合スコア20

MySQL

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

PHP

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

0グッド

2クリップ

投稿2016/04/06 11:25

編集2016/04/06 11:33

いつも質問ばかりになってしまいすみません。
タイトルの通り、当該の本を本日から初めていきなり詰まっています。

私の現在の環境は、
Mac ElCapitan 10.11.3にMAMPをインストールして実行中です。

操作がうまく行かず詰まっている状況は以下の通りです。
①該当箇所は、Chapter 2-4

②自分で打ち込んだソースでは 「ただいま障害により大変ご迷惑をおかけしております。」 しか出ない。
出版社からリリースされている改定箇所を変えた後も前もこのメッセージしか出ない。

③staff_add.php /staff_add_check.php /staff_add_done.php のここまでの全ファイルをサンプルソースコードに切り替えても、「ただいま障害により大変ご迷惑をおかけしております。」しか出ない。

④念のため、GoogleChromeでstaff_add_check.phpの画面を検証したら、
下の添付のように name と暗号化された pass が staff_add_done.php へ運ばれてました。
イメージ説明

⑤私のMySQLの起動が悪いのかと思ったのですが、
MySQL自体は起動しており、作成したshopデータベースに mst_staff テーブルも作成されています。

初日から早速挫折しそうです。
お助け下さい。よろしくお願い致します。

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

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

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

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

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

guest

回答3

0

自己解決

5時間ハマってましたが解決しました。
どうも、教科書の文章ではPHPとSQLの接続が出来無いようです。
備忘録として、こちらにまとめます。(MacでMampユーザーの場合に限定されるかもしれませんが、、、)

PDO構文を使ってPHPからSQLへデータを遷移させたい場合、
SQLで利用する特定のユーザー名対して全てのユーザー権限を付与する必要があるようです。

ユーザー権限の付与がされてない場合は、
PHPからPDO構文でSQLへの接続を行うと↓こんな感じのエラーで接続を拒絶されると思います。

イメージ説明

(*try/catch構文を使っている場合だと、catch側の命令が実行されると思います。)

そういった方は、
①ターミナルで下のコマンドを実行して、今自分のMySQLに設定されているユーザー名とホスト名を確認できます。
イメージ説明

②続いて、不要なユーザー名とホスト名は下のコマンドで削除します。
mysql> DROP USER 'root'@'%';

③さらに、これから利用するユーザー名(今回は:root) とホスト名(今回は:localhost) を下のコマンドで作成し、
2行目のコマンドでパスワードを設定してあげます。(パスワード不要なら''で構わない。)
mysql> CREATE USER 'root'@'localhost';
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('***');

④最後に、このユーザー名とホスト名に以下のコマンドで権限を与えます。
mysql> grant all on . to 'root'@'localhost';

これで、PHPからSQLへの接続が許可されます。

また、PHPからSQLへの接続に必要なコードは以下の通りです。
*このコマンドは、著書「気づけばプロ並みPHP」 に書かれたコードとは違います。
*SQLへ接続できた場合はtryの中を、できなかった場合はcatchの中が返ります。

try{
$dsn='mysql:dbname=shop;host=localhost;charset=utf8';
$dbh = new PDO('mysql:host=ホスト名;dbname=データベース名;charset=utf8',
'ユーザー名','パスワード',array(PDO::ATTR_EMULATE_PREPARES => false));

  #ここにSQLへの実行命令を記載

}catch (Exception $e){
print 'ただいま障害により大変ご迷惑をお掛けしております。';
exit();
}

投稿2016/04/06 14:45

編集2016/04/07 07:45
Akirax

総合スコア20

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

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

0

$user='root';
$password='';

このあたりあってますか?

passwordもrootとか?

投稿2016/04/06 13:41

test0001

総合スコア224

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

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

Akirax

2016/04/06 13:54 編集

連絡ありがとう御座います。 私もユーザー権限の問題の可能性があると思いググっていたところでした。 それで、ひとまずテスト用のphpフォルダを作って接続確認した結果、 SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: NO) なるコメントが出ました。コードの問題では無く、接続権限とかの問題のようです。 そこで、今SQLで登録されてるユーザー確認をした結果が以下です。 mysql> SELECT Host,User,Password FROM mysql.user; +-----------+------+-------------------------------------------+ | Host | User | Password | +-----------+------+-------------------------------------------+ | localhost | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B | | localhost | | | | % | root | | +-----------+------+-------------------------------------------+ どれもいつ入れたのか定かでは無いですが、恐らくSQL勉強期間に入れたんだと思います。気持ち悪いので、一旦3つ共 Drop構文で削除しました。 すみません、この後 grant構文でユーザー権限を与えていく必要があると思うのですが、ここからの正しいプロセスを教えて頂けませんでしょうか?
guest

0

mysqlへの接続できなくてそのページに遷移しているのでは?

投稿2016/04/06 12:56

test0001

総合スコア224

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

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

Akirax

2016/04/06 13:01

コメントありがとう御座います。 教科書のコードは以下です。 <?php try { $staff_name=$_POST['name']; $staff_pass=$_POST['pass']; $staff_name=htmlspecialchars($staff_name); $staff_pass=htmlspecialchars($staff_pass); $dsn='mysql:dbname=shop;host=localhost;charset=utf8'; $user='root'; $password=''; $dbh=new PDO($dsn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $sql='INSERT INTO mst_staff (name,password) VALUES (?,?)'; $stmt=$dbh->prepare($sql); $data[]=$staff_name; $data[]=$staff_pass; $stmt->execute($data); $dbh=null; print $staff_name; print 'さんを追加しました。<br />'; } catch (Exception $e) { print 'ただいま障害により大変ご迷惑をお掛けしております。'; exit(); } Macを使ってこのコードでやった場合、PHPはSQLへ接続できるのでしょうか? MySQLのServer Version は 5.5.42 です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問