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

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

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

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

PHP

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

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

1098閲覧

cakePHPを表示したい (An Internal Server Error Occurred)

paccuman

総合スコア13

MySQL

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

PHP

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

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2022/07/10 11:58

編集2022/07/11 17:15

環境

  • XSERVER
  • PHP 7.4.28 / cakephp4.2.8(XSERVERの環境)

実現したいこと

ローカルで開発したサービスをXSERVERで表示したい

エラー内容

画面に「An Internal Server Error Occurred」だけが表示される

経緯

  1. リリース手順としてこちらの通りに、ディレクトリ構成とパスを変更しました

  2. 「Parse error: syntax error, unexpected 'require' (T_REQUIRE)」エラーが出ましたが、解消できず、一旦こちらを参考に「dirname(DIR) . $cakeDir」の記述を「/home/{xserverのID}/{ドメイン}/cakephp」に置き換えました

  3. 画面に「An Internal Server Error Occurred」だけが表示されました

試したこと

DBの設定を確認しました。
DBの設定が正しいか確認するため、このドメインのpublic_html下にcakephp4をインストールし、DB情報を編集し、初期画面でDBが正常に接続されていることを確認しました。

その他に、検索で出てくるいくつかのやりかやでディレクトリ構成を変えてサービスをアップしてみましたが同じように最後には「An Internal Server Error Occurred」でつまずき先に進めませんでした。。
ググってもあまり情報がヒットせず全くわからなくなってしまいました。。

ディレクトリ構成

ドメイン名のフォルダ  ├ public_html/ ・・・webrootの中身  │ ├index.php  │ ├ img  │ ├ css/  │  ...  │ └ .htaccess  ├cakephp/    ・・・webroot以外のcakephp4ファイル群  │ ├ bin/  │ ├ config/  │ ├ src/  │  ...  │ └ vender  ├xserver_php/  │ └

cakephp/config/app.php

'App' => [ 'namespace' => 'App', 'encoding' => env('APP_ENCODING', 'UTF-8'), 'defaultLocale' => env('APP_DEFAULT_LOCALE', 'en_US'), 'defaultTimezone' => env('APP_DEFAULT_TIMEZONE', 'UTC'), 'base' => false, 'dir' => 'src', //'webroot' => 'webroot', 'webroot' => 'public_html', // エックスサーバーの公開ディレクトリに修正 'wwwRoot' => WWW_ROOT, ..... 'Datasources' => [ 'default' => [ 'className' => Connection::class, 'driver' => Mysql::class, 'persistent' => false, 'host' => 'mysql****.xserver.jp', 'username' => 'xs****_ユーザー名', 'password' => 'ユーザー名に対するユーザーパスワード', 'database' => 'xs****_DB名', 'encoding' => 'utf8', 'timezone' => 'UTC', .....

cakephp/config/paths.php

//define('WWW_ROOT', ROOT . DS . 'webroot' . DS); define('WWW_ROOT', 'home/xs*****/ドメイン' . DS . 'public_html' . DS); //エックスサーバーの公開 ディレクトリに修正

public_html/index.php

// Check platform requirements //require dirname(__DIR__) . '/config/requirements.php'; require '/home/xs*****/ドメイン/cakephp/config/requirements.php'; // 修正 // For built-in server if (PHP_SAPI === 'cli-server') { $_SERVER['PHP_SELF'] = '/' . basename(__FILE__); $url = parse_url(urldecode($_SERVER['REQUEST_URI'])); $file = __DIR__ . $url['path']; if (strpos($url['path'], '..') === false && strpos($url['path'], '.') !== false && is_file($file)) { return false; } } //require dirname(__DIR__) . '/vendor/autoload.php'; require '/home/xs*****/ドメイン/cakephp/vendor/autoload.php'; // 修正 use App\Application; use Cake\Http\Server; // Bind your application to the server. //$server = new Server(new Application(dirname(__DIR__) . '/config')); $server = new Server(new Application('/home/xs*****/ドメイン/cakephp/config')); // 修正 // Run the request/response through the application and emit the response. $server->emit($server->run());

public_html/.htaccess

<IfModule mod_rewrite.c> RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^ index.php [L] </IfModule>

cakephp/.htaccess

<IfModule mod_rewrite.c> RewriteEngine on RewriteRule ^$ ../public_html/ [L] RewriteRule (.*) ../public_html/$1 [L] </IfModule>

XSERVERの管理画面からダウンロードしたerror_log

[Sun Jul 10 19:33:00.468068 2022] [proxy_fcgi:error] [pid 3836:tid 3919] [client 153.214.78.6:34470] AH01071: Got error 'PHP message: PHP Warning: file_put_contents(/home/xs*****/ドメイン/cakephp/logs/error.log) [<a href='https://secure.php.net/function.file-put-contents'>function.file-put-contents</a>]: failed to open stream: No such file or directory in /home/xs*****/ドメイン/cakephp/vendor/cakephp/cakephp/src/Log/Engine/FileLog.php on line 131PHP message: PHP Warning: file_put_contents(/home/xs*****/ドメイン/cakephp/logs/error.log) [<a href='https://secure.php.net/function.file-put-contents'>function.file-put-contents</a>]: failed to open stream: No such file or directory in /home/xs*****/ドメイン/cakephp/vendor/cakephp/cakephp/src/Log/Engine/FileLog.php on line 131'

エラーログも見ましたが分からず、ブラウザに表示されているエラーとは別問題かと思い、DB周りの方を確認してました(もしかしたらここが原因かもしれないですがすみません、わかりませんでした。。)

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

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

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

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

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

guest

回答1

0

ベストアンサー

cakephp/logsディレクトリの中にerror.logというファイルが無いって言ってるんじゃないでしょうか。
あるいはパーミッションがおかしいのかもしれません。

投稿2022/07/10 21:05

RiaFeed

総合スコア2701

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

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

paccuman

2022/07/11 08:15

ありがとうございます! logs/が存在していなかったため、logsディレクトリを作成し777にしてからアクセスしたところ、無事、error.logファイルが作成されました。 実行内容 ``` mkdir ../cakephp/logs chmod 777 ../cakephp/logs ls -al ../cakephp/logs //結果 drwxrwxrwx 2 xs293869 members 31 7月 11 16:44 . drwxr-xr-x 14 xs293869 members 4096 7月 11 16:20 .. -rw-r--r-- 1 xs293869 members 19220 7月 11 16:44 error.log ``` また、error.logが確認できたことにより、先にこのerror.logの内容の確認を進めようと思います。 (このページで質問させていただいております主題の質問と内容が異なりますので解決とさせていただきます、ありがとうございました。)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問