ECCUBEの新規追加ページがInternal Server Error・Not Foundに
2017/03/12
ECCUBEの新規追加ページがInternal Server Errorに
ECCUBEのページがInternal Server Errorはパーミッションが原因
ECCUBEには、オリジナルのページを追加する機能が用意されてします。
「デザイン」-「PC」-「ページ詳細設定」で遷移する画面から新しいページを追加することができます。
ここから追加した新しいページにアクセスしてみたところ、「『Internal Server Error』が出て動かない!」ということがありました。
原因を調べて見るとファイルのパーミッション(ファイルの属性)が適切でないことが原因でした。
Internal Server Errorにはパーミッションを変更
下記の中に生成される PHPファイルのパーミッションを確認しましょう。
{ECCUBEのルート}/user_data/******.php
PHPのファイルのパーミッションが「644」であれば「666」に、「666」であれば「644」などに変更して見ましょう。「604」「606」などの可能性もあります。
ここの設定はサーバによって正しい設定が違いますので、一概に「“666”にしましょう!」と言えないのが心苦しいところですが、正しく表示されているページのパーミッションにあわせるとエラーが解消されて正しく表示されることでしょう。
私が遭遇した場合の「Internal Server Error」は、上記のとおり管理画面からのファイルの作成の際に発生したものでしたが、FTPでファイルをアップロードした場合も「Internal Server Error」が出る場合は、ファイルのパーミッションを変更して見ましょう。
パーミッションを変更する処理を追加
前項の通りパーミッションを変更することで正しく表示されるようになった場合は、今後作成されるファイルのパーミッションが正しいものになるようにプログラムの修正も行っておく方がいいでしょう。
対応するファイルは下記になります。
{ECCUBEのルート}/data/class/helper/SC_Helper_FileManager.php
※「data」フォルダはドキュメントルートより上位にある場合もあります。
322行目辺りからのソースコードです。
14行目~16行目が追加された部分です。
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
public function sfWriteFile($filename, $value) { if (!is_dir(dirname($filename))) { SC_Utils_Ex::recursiveMkdir(dirname($filename), 0777); } $fp = fopen($filename, 'w'); if ($fp === false) { return false; } if (fwrite($fp, $value) === false) { return false; } if ( ( pathinfo ( $filename, PATHINFO_EXTENSION) ) == "php" ) { chmod($filename, 0644); } return fclose($fp);; } |
作成するファイルの拡張子が「php」の場合は、ファイルのパーミッションを「644」に設定します。
という処理を追加しています。
これで今後新しく作成されるページも「Internal Server Error」にならずに生成されるようになります。
ファイルに設定するパーミッションは、サーバに合わせて変更してください。
※ECCUBE 2.13.3、2.13.4で検証をしています。
ECCUBEの新規追加ページが Not Foundに
新規作成したページが「Internal Server Error」になる場合はファイルが作成されるものの、ファイルのパーミッションが違う場合に起こる現象でした。
ですが、新規作成したページが「Not Found」のエラーになる場合もあります。
これは、ファイルが生成されるフォルダのパーミッションが正しくなく、ファイルが生成されない場合に起こる不具合の一つです。
新規追加ページが Not Foundの場合はフォルダのパーミッション
管理画面からページを新規追加した場合は、下記のフォルダにファイルが生成されます。
{ECCUBEのルート}/user_data/
{ECCUBEのルート}/data/Smarty/templates/{テーマ}/user_data/
※「data」フォルダはドキュメントルートより上位にある場合もあります。
これらのフォルダに書き込み権限が付与されていない場合は、ファイルを生成することができないため、「Not Found」の原因になります。
上記のフォルダのパーミッションを「777」「755」などに変えてみて、ファイルが生成され、エラーが解消されるかを確認してみてください。
GoogleAdwords
GoogleAdwords
この記事が参考になったと思いましたらソーシャルメディアで共有していただけると嬉しいです!
関連記事
-
-
AdminerはphpMyAdmin代替のデータベース管理ツール
AdminerはphpMyAdminとほぼ同機能のデータベース管理ツール。PHP 1ファイルのため設置が非常に簡単で軽快に動作し、phpMyAdminの置き換えで使うのも問題なし。
-
-
PHPのソースで見慣れない記号が出てきた・アロー演算子(->)、ダブルアロー演算子(=>)
PHPのプログラムソースには見慣れない記号が出てきます。その意味や調べ方です。
-
-
cURLを利用する際の注意点「
&」があるURLは「”」で囲むcURLでURLはダブルクォーテーションで囲む。LinuxでもWindowsでもコマンドでは「&」は意味を持つ文字のためエラー原因になる。クォーテーションは常につけておく方が無難。
-
-
数値文字参照コード変換ツール(HTML特殊文字コード変換ツール)
テキストを数値文字参照コード(特殊文字コード)に変換するツール。テキストを数値文字参照コードに簡単変換。数値文字参照、文字実体参照、特殊文字などの違いも解説。
-
-
Smartyの修飾子regex_replaceで正規表現の後方参照・PHPではpreg_replace
ECCUBEで使われているSmartyで文字列を正規表現で置換し後方参照で値を利用する装飾子regex_replaceの解説です。細かな条件がありますので注意が必要です。
-
-
GMOペイメントゲートウェイのjava.io.IOExceptionのエラー
ECCUBEの決済でGMOペイメントゲートウェイのモジュールを使ってテスト決済を行った場合の不具合、java.io.IOExceptionと言うエラーの原因と対策方法の解説です。
-
-
Smartyの Syntax Errorの原因はスペースかも
Smartyのなかなか原因がつかめない Syntax Errorの原因はスペースかもしれません。
-
-
PHPのスクレイピングライブラリ「PHP Simple HTML DOM Parser」の使い方
PHPのスクレイピングライブラリ「PHP Simple HTML DOM Parser」の使い方を解説。要素を取得する方法、そこから属性を取得する方法を解説。また、マニュアルにはない注意点なども解説。
-
-
PHPのデバッグで使う print_r、var_dump、var_exportの動作の違い
PHPのデバッグ等で変数や配列の中身を確認するために使用する関数print_r、var_dump、var_exportの動作の違い、仕様の違いについて確認した。var_exportがオススメ。
-
-
ECCUBEでアップロードできない。upload_max_filesizeを設定する場所
テンプレートをアップロードする際に発生するエラー「テンプレートファイルがアップロードされていません」の対処方法。これはファイル容量の制限に引っかかっています。
