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

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

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

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

CakePHP

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

パーミッション

パーミッション(許可)は、ファイルシステム、データベース、そして他のコンピュータシステムに対するユーザーのアクセス権のことを指します。

Q&A

解決済

2回答

8148閲覧

cakephp: Permission denied に関するエラー (cakephp超入門:cakephp4.0)

YuhiUsui

総合スコア11

PHP

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

CakePHP

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

パーミッション

パーミッション(許可)は、ファイルシステム、データベース、そして他のコンピュータシステムに対するユーザーのアクセス権のことを指します。

0グッド

0クリップ

投稿2020/11/10 08:28

編集2020/11/11 04:01

前提・実現したいこと

php超入門という書籍を用いて勉強始めました。
XAMPP環境でcakephp3.xを使用した前提となっていますが,当方4.0をダウンロードして進めています。

表示されてるエラーの修正
デバッグキットの表示:右下にアイコンが出てきません

この2点が現状の課題です

まだ始めたてなもので、十分な情報量でない場合お知らせいただけると幸いです。

イメージ説明

イメージ説明

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

Warning(512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/models/myapp_cake_model_debug_kit_requests): failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/models/myapp_cake_model_debug_kit_requests) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/models/myapp_cake_model_debug_kit_panels) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/models/myapp_cake_model_debug_kit_panels) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/persistent/myapp_cake_core_translations.debug_kit.en_US) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/persistent/myapp_cake_core_translations.default.en_US) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/persistent/myapp_cake_core_translations.default.en_US) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/persistent/myapp_cake_core_translations.debug_kit.en_US) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/persistent/myapp_cake_core_translations.cake.en_US) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): SplFileInfo::openFile(/opt/lampp/htdocs/mycakeapp/tmp/cache/persistent/myapp_cake_core_translations.cake.en_US) [<a href='https://secure.php.net/splfileinfo.openfile'>splfileinfo.openfile</a>]: failed to open stream: Permission denied [CORE/src/Cache/Engine/FileEngine.php, line 372] Warning (512): Unable to emit headers. Headers sent in file=/opt/lampp/htdocs/mycakeapp/vendor/cakephp/cakephp/src/Error/Debugger.php line=954 [CORE/src/Http/ResponseEmitter.php, line 71] Warning (2): Cannot modify header information - headers already sent by (output started at /opt/lampp/htdocs/mycakeapp/vendor/cakephp/cakephp/src/Error/Debugger.php:954) [CORE/src/Http/ResponseEmitter.php, line 168] Warning (2): Cannot modify header information - headers already sent by (output started at /opt/lampp/htdocs/mycakeapp/vendor/cakephp/cakephp/src/Error/Debugger.php:954) [CORE/src/Http/ResponseEmitter.php, line 197]

ソースコード

php

1<?php 2namespace App\Controller; 3 4use App\Controller\AppController; 5 6class HelloController extends AppController { 7 8 public $autoRender = false; 9 10 public function index() { 11 echo "<html><body><h1>Hello!</h1>"; 12 echo "<p>This is sample page.</p></body></html>"; 13 } 14}

試したこと

以下二つを参考にしてみましたが解決に至っていません
デバッグキットに関して

if (Configure::read('debug')) { Configure::write('Cache._cake_model_.duration', '+2 minutes'); Configure::write('Cache._cake_core_.duration', '+2 minutes'); // disable router cache during development Configure::write('Cache._cake_routes_.duration', '+2 seconds'); // Configure::write('DebugKit.panels', ['DebugKit.Packages' => true]); // Configure::write('DebugKit.safeTld', ['com']); Configure::write('DebugKit.forceEnable', true); }

パーミッションに関して
対象と思われるファイルの権限は777にしてみました

(base) perrymb:persistent a0000$ ls -l total 24 -rwxrwxrwx 1 a0000 staff 526 11 9 18:48 myapp_cake_core_translations.cake.en_US -rwxrwxrwx 1 a0000 staff 526 11 9 18:48 myapp_cake_core_translations.debug_kit.en_US -rwxrwxrwx 1 a0000 staff 284 11 9 18:48 myapp_cake_core_translations.default.en_US (base) perrymb:persistent a0000$ cd ../ (base) perrymb:cache a0000$ cd models/ (base) perrymb:models a0000$ ls -l total 16 -rwxrwxrwx 1 a0000 staff 2049 11 9 18:48 myapp_cake_model_debug_kit_panels -rwxrwxrwx 1 a0000 staff 1565 11 9 18:48 myapp_cake_model_debug_kit_requests

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

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

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

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

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

guest

回答2

0

ベストアンサー

CakePHPの動作に必要なパーミッションの設定については、ドキュメントを参照してください。

パーミッション - インストール - 3.9

CakePHP 3で書き込み権限が必要となるのは、 tmp/logs/ ディレクトリとその中のファイルです。
chmod に -R オプション(配下のディレクトリへも再帰的にパーミッションをセットする)を付けて、

sh

1cd /opt/lampp/htdocs/mycakeapp 2chmod -R go+w tmp/ logs/

とするのが良いかなと思います。

なお、composer install を実行すると書き込みパーミッションが必要なディレクトリにパーミッションをセットしますか?(Set Folder Permissions ?)と聞かれますのでそこで「Y」とするとセットしてくれる機能があります。

投稿2020/11/11 00:19

nojimage

総合スコア957

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

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

YuhiUsui

2020/11/11 04:14

ご回答ありがとうございます(非常にわかりやすかったです) 早速試してみたのですが対象ディレクトリにターミナルで移動する際に 下記のように(opt)から入れませんでした。 この時点ですでに私の的外れかとも思ったのですが念のため(pwd)で直接パスをとってその後のアドバイスを実行した結果が以下です。 解答者様の意図と違っている点をお教えいただけますでしょうか? #追加情報として該当ディレクトリの場所スクショを追加しました ``` (base) perrymb:~ a0000$ cd /opt/lampp/htdocs/mycakeapp -bash: cd: /opt/lampp/htdocs/mycakeapp: No such file or directory (base) perrymb:desktop a0000$ cd /Users/a0000/.bitnami/stackman/machines/xampp/volumes/root/htdocs/mycakeapp (base) perrymb:mycakeapp a0000$ chmod -R go+w tmp/ logs/ chmod: Unable to change file mode on logs//error.log: Operation not permitted ```
nojimage

2020/11/11 04:30

ディレクトリの指定はそれで大丈夫です。(XAMPPだとchrootされるのを忘れていました。 chmodコマンドの実行エラーはユーザーが書き込み権限を持たないファイルが既に作成されているためです。sudo chmod 〜のように管理者権限でchmodコマンドを実行してください
nojimage

2020/11/11 04:35

開発環境であれば、logs, tmpディレクトリ配下のファイルを削除してしまってもよいです。
YuhiUsui

2020/11/11 06:54

実行後以下のようになりました (base) perrymb:mycakeapp a0000$ sudo chmod -R go+w tmp/ logs/ chmod: Unable to change file mode on tmp//cache/models/myapp_cake_model_default_people: Operation not permitted chmod: Unable to change file mode on logs//error.log: Operation not permitted 権限確認したところ上の2ファイル以外はうまくいってるようで 画面の動作はうまくいっています。 drwxrwxrwx 2 1000 1000 4096 11 9 16:14 logs -rw-r--r-- 1 daemon daemon 2458634 11 11 15:38 error.log drwxrwxrwx 5 1000 1000 4096 11 9 13:47 cache -rwxrwxrwx 1 1000 1000 2049 11 11 15:46 myapp_cake_model_debug_kit_panels -rwxrwxrwx 1 1000 1000 1565 11 11 15:46 myapp_cake_model_debug_kit_requests -rw-rw-r-- 1 daemon daemon 1244 11 11 15:46 myapp_cake_model_default_people
YuhiUsui

2020/11/11 06:58

関連質問として2点あります。 解決にする前にお答えいただければ幸いです 1,(XAMPPだとchrootされるのを忘れていました。 =>>というのは他のローカル開発環境なら/opt/htdocs/にcakephpのアプリがいるはずということでしょうか? 2.上記の通り2ファイルは権限変更できないようなのですがこのままで良いのでしょうか?
nojimage

2020/11/11 23:49

xamppは使わないので詳しくはないのですが、xammpはVM版と通常版がありVM版はmacOSの上で別の仮想マシンが起動している状態です。示されたパスからVM版を使っていると思います。 で、仮想マシン上でApache httpdやらMySQLが動いているのですがファイルシステムもmacOSからは分離されたものとなります。 xammp内のファイルを正しく扱うにはxammp-VM内に入って作業しないといけません。そのためには、xammpの「Open Terminal」でVMへssh接続して操作してください。 参考)XAMPP for OS Xからかなり変わったXAMPP-VM for OS X のメモ - uzullaがブログ https://uzulla.hateblo.jp/entry/2017/10/26/001132
YuhiUsui

2020/11/12 04:42

ご丁寧に教えていただいてありがとうございました!! またお願いします♪
guest

0

キャッシュディレクトリについては、動作させるユーザ(例えばhttpdで公開していてapacheユーザ)をオーナー、グループに設定し、読み書きできるパーミッションを設定してください。

Bash

1chmod -R 777 /対象ディレクトリ/ 2chown -R apache:apache /対象ディレクトリ/ 3/opt/lampp/htdocs/mycakeapp/tmp/cache/models/ 4/opt/lampp/htdocs/mycakeapp/tmp/cache/persistent/

投稿2020/11/10 13:40

yodel

総合スコア508

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

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

YuhiUsui

2020/11/11 04:12

ご回答ありがとうございます 早速試してみたのですが対象ディレクトリにターミナルで移動する際に 下記のように(opt)から入れませんでした。 この時点ですでに私の的外れかとも思ったのですが念のため(pwd)で直接パスをとってその後のアドバイスを実行した結果が以下です。 解答者様の意図と違っている点をお教えいただけますでしょうか? #追加情報として該当ディレクトリの場所スクショを追加しました ``` (base) perrymb:~ a0000$ chmod -R 777 /opt/lampp/htdocs/mycakeapp/tmp/cache/models/ chmod: /opt/lampp/htdocs/mycakeapp/tmp/cache/models/: No such file or directory (base) perrymb:~ a0000$ chmod -R 777 /Users/a0000/.bitnami/stackman/machines/xampp/volumes/root/htdocs/mycakeapp/tmp/cache/models/ (base) perrymb:~ a0000$ chmod -R 777 /Users/a0000/.bitnami/stackman/machines/xampp/volumes/root/htdocs/mycakeapp/tmp/cache/persistent/ (base) perrymb:~ a0000$ chown -R apache:apache /Users/a0000/.bitnami/stackman/machines/xampp/volumes/root/htdocs/mycakeapp/tmp/cache/models/ chown: apache: illegal group name ```
YuhiUsui

2020/11/11 04:35

追記いたします 回答者様のアドバイスのうち グループ設定のコマンドはうまくいっていないのですが ブラウザの大量のエラーログが消え、右下にデバックキットが出てきました chmod -R 777の結果したのようになったのでうまくいってるとは思うのですが、 1.なぜchmod -R 777 /opt/ディレクトリが実行できなかったのか? 2.グループ設定の不具合について 少し理解が追いついていないのでご教授いただけますと幸いです ーーーーーーーーーーーーーーーーーーーー (base) perrymb:cache a0000$ ls -l total 24 drwxrwxrwx 2 1000 1000 4096 11 9 15:56 models drwxrwxrwx 2 1000 1000 4096 11 9 15:56 persistent drwxrwxrwx 2 1000 1000 4096 11 9 13:47 views (base) perrymb:cache a0000$ ls -l models total 9 -rwxrwxrwx 1 1000 1000 2049 11 11 13:20 myapp_cake_model_debug_kit_panels -rwxrwxrwx 1 1000 1000 1565 11 11 13:20 myapp_cake_model_debug_kit_requests (base) perrymb:cache a0000$ ls -l persistent/ total 5 -rwxrwxrwx 1 1000 1000 526 11 11 13:20 myapp_cake_core_translations.cake.en_US -rwxrwxrwx 1 1000 1000 526 11 11 13:20 myapp_cake_core_translations.debug_kit.en_US -rwxrwxrwx 1 1000 1000 284 11 11 13:20 myapp_cake_core_translations.default.en_US ーーーーーーーーーーーーーーーーーーーーーーーーーーー
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問