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

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

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

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

CakePHP

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

Q&A

解決済

1回答

4436閲覧

cakePHPでfailed to open stream: Permission denied というエラーを解消したい

mizo777

総合スコア28

PHP

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

CakePHP

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

0グッド

0クリップ

投稿2020/01/26 07:16

cakePHPを書籍で独学しています。
loclalhost:8765の内臓サーバで実行するとcakePHPのトップページへアクセスできるのですが、
XAMPPのhtdocsにアプリをコピーしてApacthで起動すると下記のようなエラーが出ます。
イメージ説明
権限に関するエラーという認識なのですが、どうなのでしょうか?
ご回答よろしくおねがい致します。

試みたこと
・エラー表示のある下記に読み書き実行の権限を全ユーザーに与えたが解消されなかった。
/Applications/XAMPP/xamppfiles/htdocs/cake3app/vendor/cakephp/cakephp/src/Log/Engine/FileLog.php

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

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

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

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

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

kyoya0819

2020/01/26 08:07

エラーをコピペしていただけませんか?
mizo777

2020/01/26 22:38

よろしくおねがい致します! Warning: file_put_contents(/Applications/XAMPP/xamppfiles/htdocs/cake3app/logs/error.log) [function.file-put-contents]: failed to open stream: Permission denied in /Applications/XAMPP/xamppfiles/htdocs/cake3app/vendor/cakephp/cakephp/src/Log/Engine/FileLog.php on line 129 Warning (512): SplFileInfo::openFile(/Applications/XAMPP/xamppfiles/htdocs/cake3app/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]
guest

回答1

0

ベストアンサー

エラーメッセージをよく読んでください。

Warning: file_put_contents(/Applications/XAMPP/xamppfiles/htdocs/cake3app/logs/error.log) [function.file-put-contents]: failed to open stream: Permission denied in /Applications/XAMPP/xamppfiles/htdocs/cake3app/vendor/cakephp/cakephp/src/Log/Engine/FileLog.php on line 129

failed open stream になったファイルは、
** /Application/XAMPP/xamppfiles/htdocs/cake3app/logs/error.log **
です。
ここに対して書き込もうとしているのが /Applications/XAMPP/xamppfiles/htdocs/cake3app/vendor/cakephp/cakephp/src/Log/Engine/FileLog.php のソースコードなので、このソースコードのパーミッションを変更しても何の意味もありません。

この場合色々可能性があって、

  1. /Application/XAMPP/xamppfiles/htdocs/cake3app/logs のグループが、Apache の動作するグループではないため、グループで書き込みできない
  2. /Application/XAMPP/xamppfiles/htdocs/cake3app/logs に、グループの書き込み権限がない
  3. /Application/XAMPP/xamppfiles/htdocs/cake3app/logs/error.log が存在しているが、所有者が Apache ではない
  4. /Application/XAMPP/xamppfiles/htdocs/cake3app/logs/error.log が存在しているが、グループが Apache でない
  5. /Application/XAMPP/xamppfiles/htdocs/cake3app/logs/error.log が存在していてグループが Apache だが、グループの書き込み権限がない

一度内蔵サーバで動かしたと言うことは、その時点で logs/error.log が作られていて、所有者とグループが内蔵サーバになっているはずです。そこに Apache で動かし直すと、所有者もグループも異なるので書き込みできなくなります。
other にも書き込み権限を与える(logs に o+rwx、logs/error.log に o+rw)手もありますが、誰でも書き込めてしまうのはあまりよろしくないですね。

すべてチェックしてみてください。

投稿2020/01/27 02:52

編集2020/01/27 02:57
tacsheaven

総合スコア13703

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

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

mizo777

2020/01/27 12:13

グループの権限変更だけでは解消されなかったため、otherにも権限を与えると解消はできました。 あまりよろしくないとのことなのでアプリを新規作成で大丈夫なんですかね?試してみます★ ありがとうございます! /Applications/XAMPP/xamppfiles/htdocs/cake3app/tmp/cache total 0 drwxrwxrwx 5 mizo admin 160 1 24 15:22 models drwxrwxrwx 6 mizo admin 192 1 24 15:22 persistent drwxr-xr-x 2 mizo admin 64 1 24 15:22 views /Applications/XAMPP/xamppfiles/htdocs/cake3app/tmp/cache/models/ total 16 -rw-rw-rw- 1 mizo admin 2049 1 27 21:01 myapp_cake_model_debug_kit_panels -rw-rw-rw- 1 mizo admin 1565 1 27 21:01 myapp_cake_model_debug_kit_requests /Applications/XAMPP/xamppfiles/htdocs/cake3app/tmp/cache/persistent/ total 24 -rw-rw-rw- 1 mizo admin 526 1 27 21:01 myapp_cake_core_translations.cake.en_US -rw-rw-rw- 1 mizo admin 526 1 27 21:01 myapp_cake_core_translations.debug_kit.en_US -rw-rw-rw- 1 mizo admin 284 1 27 21:01 myapp_cake_core_translations.default.en_US /Applications/XAMPP//xamppfiles/htdocs/cake3app/tmp/ total 2024 -rwxrwxrwx 1 mizo admin 1019904 1 27 21:02 debug_kit.sqlite
tacsheaven

2020/01/27 12:55

group を Apache の実行時の group と同じにする(chgrp)のが常道です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問