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

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

詳細はこちら
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

PHP

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

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Q&A

解決済

1回答

1109閲覧

herokuでデプロイしたがデーターベースに接続できない(PHP、MariaDB)

退会済みユーザー

退会済みユーザー

総合スコア0

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

PHP

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

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

0グッド

0クリップ

投稿2020/12/01 06:32

前提・実現したいこと

PHPで、ログイン・データ登録・削除などの機能を入れた物を作成し、herokuにデプロイし
WEB上で画面表示はできました。DB接続と関係のないページには問題なく遷移もできます。

発生している問題・エラーメッセージ

ログイン機能を使用すると「HTTP ERROR 500」になってしまいます。 ちなみにXAMPPを利用したローカル環境では問題なく機能しています。

該当のソースコード

ソースコード

試したこと

ローカルで作成したDBを使用したい場合、別途設定が必要なようですが、
ネット上で調べても、初心者には難しく理解できるものがありませんでした。
PHP(フレームワークなし)、MariaDBで作成した物をherokuで機能させるには、
DB設定など、どんなことが必要なのかご教授いただければ幸いです。
よろしくお願いいたします。

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

windows10
PHP 7.4.10
MariaDB 10.4.14

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

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

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

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

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

m.ts10806

2020/12/01 06:56

何を参考に構築し、デプロイしたのでしょう。エラーログなども確認されたのでしょうか
退会済みユーザー

退会済みユーザー

2020/12/01 07:50

プログラムは動画教材や書籍を参考に作成しました。デプロイ方法はherokuのcreate new appから行いました。git bashを使ってherokuに表示されたコマンド通り、git add . など打って進めました。 エラーログの確認なのですが。。。すみません、どこを確認するのかいまいちわかっていません。 herokuのview logs や git bashに吐かれた文言を確認したのですがエラーらしき文言を見つけることが出来なかったのですが。
FKM

2020/12/09 06:24

Error500なので、PHPプログラムそのものに不正が出ている可能性が高いです。 php.iniでdisplay_error=Onにしてそのエラーメッセージを確認した方がいいでしょう。
guest

回答1

0

ベストアンサー

そもそもデプロイ後も、自身のMariaDBに直接接続させる。のだと思っていました。
動画教材では、DBに接続する関数に直接パスワードなどを記述するとセキュリティ上良くないので
デプロイする場合は、
・公開ディレクトリ外のフォルダにパスワードを設置する
・rootユーザーを使わないほうがいい
などというような補足があったので、てっきりデプロイ後もローカル環境のDB(私の場合はMariDB)に
接続させるものだと思っていました。
結局、herokuでデプロイするにはclearDBを使うことで接続できるようになりました。
clearDBは環境変数を使って接続するので、「公開ディレクトリ外にパスワードを設置する」とか。。。
必要ないのでは??と思いました。

投稿2021/01/08 08:08

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問