エス技研

WordPress、CakePHP、PHP、baserCMSなどの Web系システムを中心に情報を提供します!


ECCUBEの新規追加ページがInternal Server Error・Not Foundに

      2017/03/12

ECCUBEの新規追加ページがInternal Server Errorに

 

ECCUBEのページがInternal Server Errorはパーミッションが原因

 
ECCUBEには、オリジナルのページを追加する機能が用意されてします。
 
「デザイン」-「PC」-「ページ詳細設定」で遷移する画面から新しいページを追加することができます。
 
ECCUBEで新規追加したページがInternal Server Errorに!原因はファイルのパーミッションの場合が多くその対処方法とプログラムの修正ポイントを解説。Not Foundも解説。
 
 
ここから追加した新しいページにアクセスしてみたところ、「『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行目が追加された部分です。
 

 
作成するファイルの拡張子が「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」などに変えてみて、ファイルが生成され、エラーが解消されるかを確認してみてください。

 - PHP・Smarty・ECCUBE

GoogleAdwords

GoogleAdwords

最後までお読みいただきましてありがとうございます。
この記事が参考になったと思いましたらソーシャルメディアで共有していただけると嬉しいです!

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

下記の空欄を埋めてください。 * Time limit is exhausted. Please reload CAPTCHA.

日本語が含まれない投稿は無視されますのでご注意ください。(スパム対策)

※入力いただいたコメントは管理者の承認後に掲載されます。

  関連記事

ECCUBEの注文完了画面注文番号と商品情報を編集するCRITEO(クリテオ)タグを編集

ECCUBEの注文完了画面にクリテオのタグを編集する方法を紹介。標準機能では完了画面に注文IDや購入商品の情報を渡さないため改修が必要です。

Smartyの Syntax Errorの原因はスペースかも

Smartyのなかなか原因がつかめない Syntax Errorの原因はスペースかもしれません。

路線・駅検索をPHPで実装する方法解説。GoogleMapsの緯度経度から計算し検索
路線・駅検索をPHPで実装する方法解説。GoogleMapsの緯度経度から計算し検索

路線・駅検索の仕組みの構築は大変。登録する側も最寄り駅が多い場合は大変。なので簡易に実装するため緯度経度に基づき直線距離を計算する処理を考案して実装して、その処理を解説。

リダイレクトループが原因で「ERR_TOO_MANY_REDIRECTS」「このページを表示できません」が出たときの対策12事例+α

リダイレクトループ、自動転送設定ループの原因の解説とその対応方法を含め事例 12例を挙げて説明。

ECCUBEでテンプレートファイルのファイルサイズは10MB以下のものを使用してくださいのエラーが出た場合

テンプレートをアップロードする際にファイルサイズが大きすぎてエラーが表示される際の対処方法解説。パラメータ設定で設定する制限について解説を行っています。

ファイル変更だけ!ECCUBEの本番から開発環境をコピーする手順を解説

ECCUBEを本番から開発環境をコピーする際の手順を解説。PGMメンテに必要な開発環境を構築する手順を解説。ECCUBEの仕組みは簡単なので作業は5分ほど。

PHPのスクレイピングライブラリ「PHP Simple HTML DOM Parser」の使い方
PHPのスクレイピングライブラリ「PHP Simple HTML DOM Parser」の使い方

PHPのスクレイピングライブラリ「PHP Simple HTML DOM Parser」の使い方を解説。要素を取得する方法、そこから属性を取得する方法を解説。また、マニュアルにはない注意点なども解説。

指定した数で文字列を丸める関数substr、mb_substr、mb_strimwidthの違い
指定した数で文字列を丸める(n文字目で…にする)関数substr、mb_substr、mb_strimwidthの違い

文字列を指定された数で抜き出すPHPの関数、substr、mb_substr、mb_strimwidthについての解説。似た関数だが引数の指定方法が違ったり、文字数がバイト数か文字数かも違ったり、注意が必要だ。

SEO対策用タイトル、ディスクリプションの文字数カウントツール

SEO対策に使える文字数カウントツールで文字数の条件の説明も行っています。

PHPでスクレイピング。phpQueryとphp-simple-html-dom-parserの比較と設置方法
PHPでスクレイピング。phpQueryとphp-simple-html-dom-parserの比較と設置方法

「PHP スクレイピング」で検索すると「phpQuery」ばかりヒットするが、10年以上も放置されている。なので今も開発が続いている「PHP Simple HTML DOM Parser」をオススメする。