「/config.php」を含めて構成ファイルをインポートする前に気づいたかどうかはわかりません。
急いで答えずに、次の 2 つの質問をすることができます:
1. このパスの下に config.php が存在しない場合はどうなりますか?
2. PHP などの設定ファイルを xml などの設定ファイルに変更するとどうなりますか?
まず、ファイルが存在しない場合、PHP は警告をスローしますが、設定ファイルが xml になった後も、プログラムは実行を続けます。xml を読み取るための対応するコードをエントリ ファイルに記述する必要があります。および前の include '/config.php' コードを変更します。
それでは、設定ファイルのシームレスな切り替えを実現する方法はあるのでしょうか?
これらを詳しく説明する前に、まず工場モデルについて説明します。A は赤い車を購入する必要があり、その需要を B (車を生産する工場) に直接提案します。 Aの要求に従い、倉庫から適切な車を選択してAに渡します。全体のプロセスにおいて、A は需要を提示するだけで、具体的な車両の選択は工場 B によって決定されます。この方法がファクトリーモデルです。
例:
01 |
02 | public class Factory { |
03 | public static function factory($whichOneToChoose) { |
04 | $returnVal = 'Red'; |
02
05 | switch($whichOneToChoose) { |
06 | case1 : |
07 | $returnVal = 'Blue'; |
08 | break |
09 | case 2 : |
10 | $returnVal = 'Green'; |
11 | break; |
12 | default : |
13 | break; |
14 | } |
15 | return $returnVal; |
16 | } |
17 | } |
ファクトリ パターンは通常、静的メソッドを持ちます。ファクトリはロジック処理を担当します。
これで、構成ファイルを処理するための新しいクラス Config.php
を作成できるようになりました。
01 |
02 | class Config { |
03 | const XML = 1; |
04 | const INI = 2; |
05 | const PHP = 3; |
06 | public static function factory($which) { |
07 | switch($which) { |
08 | caseConfig::XML : |
09 | return XmlConfig::parse(CONFIGS_PATH . '/config.xml'); |
10 | break; |
11 | case Config::INI : |
12 | return IniConfig::parse(CONFIGS_PATH . '/config.ini'); |
13 | break; |
14 | case Config::PHP : |
15 | //此处没有做文件是否存在的判定,你可以自己判定一下,我只是做一个例子 |
16 | return include CONFIGS_PATH . '/config.php'; |
17 | break; |
18 | default: |
19 | return array(); |
20 | break; |
21 | } |
22 | } |
23 | } |
設定ファイルを xml に変更したい場合は、XmlConfig.php に実装するだけで済みます。もちろん、簡単のため、ここでは ini 設定ファイルと xml 設定ファイルを記述するだけです。特定の実装を確認したい場合は、Toper の /Library/Toper/Config/XmlConfig.class.php で特定のコードを表示できます。
01 |
02 | class XmlConfig { |
03 | public static function parse($file) { |
04 | if(!is_file($file)) { |
05 | throw new Exception('none exists xml config file'); |
06 | } else { |
07 | return parse_ini_file($file,true); |
08 | } |
09 | } |
10 | } |
このファイルのコードは私が適当に書いたものであり、コードの正確性を保証するものではありません。