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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

MySQL

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

1回答

2294閲覧

MySQL8の認証方式に従い、Laravelを繋げたはずだが繋がらない

tsubasa8770

総合スコア15

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

MySQL

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2019/11/23 09:59

各バージョン

  • Laravel Framework 5.8.35
  • MySQL 8.0.17
  • Vue 2.5.17
  • vue-axios 2.1.5

やったこと

MySQL8の認証方式の記事をいくつか読み、直した。ちなみにこれまでいくつかMySQLとLaravelを使ったアプリを作ったが、できていた。

// .env DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=データベース名 (確認済み) DB_USERNAME=tsubasa (確認済み) DB_PASSWORD=パスワード (確認済み)

→これはSequel proで動いているため、接続に関しては間違いはほぼ確実にないと思われる。


>SELECT user, host, plugin FROM mysql.user; +------------------+-----------+-----------------------+ | user | host | plugin | +------------------+-----------+-----------------------+ | forge | % | caching_sha2_password | | forge1 | % | caching_sha2_password | | tsubasa | % | mysql_native_password | | banana | localhost | caching_sha2_password | | mysql.infoschema | localhost | caching_sha2_password | | mysql.session | localhost | caching_sha2_password | | mysql.sys | localhost | caching_sha2_password | | root | localhost | caching_sha2_password | +------------------+-----------+-----------------------+

となっています。mysql_native_password でないとダメなことは知っているため、現在は tsubasaのユーザーでしか、使っていません。


http://127.0.0.1:8000/api/songs にアクセスすると(Vueを使っているため、/api/を使う)

SQLSTATE[HY000] [2054] The server requested authentication method unknown to the client (SQL: select * from songs)

と出てしまいます。

同様にpost関係をしても、同じく権限で引っかかっていることは間違い無いです。

原因かもしれない点

イメージ説明

画像の下の方に、

PDOException::("PDO::__construct(): The server requested authentication method unknown to the client [caching_sha2_password]") /Users/tsubanana/Downloads/program/utakan/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:70 2 PDO::__construct("mysql:host=127.0.0.1;port=3306;dbname=laravel", "root", "", []) /Users/tsubanana/Downloads/program/utakan/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:70

と出ています。

the client [caching_sha2_password]という部分も先ほど書いた通り、『mysql_native_password』にしていますし、
2ポイント目の"mysql:host=127.0.0.1;port=3306;dbname=laravel", "root" は初期設定のままのようですが、ユーザー名: tsubasaなどと設定しているつもりです。

これを直そうとエラーになっているファイルである、書いてある、Connector.php:70を見ましたが、変数になっているようで、どこに行けばいいのか検討がつきません。

つまり、別の.env的な存在がいて、それが反映されてしまっているようなのです。

どなたかご教授いただけると嬉しいです。

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

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

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

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

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

m.ts10806

2019/11/23 10:06

configのほうはどうなってますか?
tsubasa8770

2019/11/23 10:12 編集

ツイッターで同じような内容を聞いたところ、解決しました! .env を修正したため、config:cacheをしなければならないのに、忘れていました。笑
tsubasa8770

2019/11/23 10:17

マルチポストについて、注告ありがとうございました!知りませんでした。ツイッターのほうを消させてもらいます。
m.ts10806

2019/11/23 10:18 編集

何かしらレスポンスがあったのでしたら消す必要はないと思います。 あくまで「teratailでは非推奨」なので、例えば質問にそのツイートのURLを貼るとかで対処は可能ですし、 (あまり良くない考えですが)やったとして強制退会喰らうわけではないので、今回知ったから今後注意したらいいだけかなと思います。
tsubasa8770

2019/11/23 10:21

わかりました。納得です。親切にありがとうございます!
guest

回答1

0

自己解決

.env を修正したため、config:cacheをしなければならないが、忘れていた。
というか、本番環境以外では、あまりしないほうがいいらしい。詳しくは調べてください。
https://blog.capilano-fw.com/?p=3343

投稿2019/11/23 10:12

編集2019/11/23 10:25
tsubasa8770

総合スコア15

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

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

kawax

2019/11/23 10:18

そもそも開発中はconfig:cacheしなくていい。キャッシュするのは本番だけ。
tsubasa8770

2019/11/23 10:23

そうみたいですね。気をつけます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問