How should I store settings for project?
Which is better - to use a $settings
array with all my settings:
$settings['max_photos'] = 30;
//...
or create a singleton Config
class with all the settings in it?
Class Config {
private $max_photos = 30;
//...
}
Any good examples?
I think it is best to use constants for configuration. For example using class constants:
If you have PHP 5.3 you could also define them as global constants:
But I think this is far less clean and straightforward.
Obviously this will only work as long as you are only storing constants, i.e. scalar, non-expression values. If your configuration contains arrays for example, this won't work anymore. In this case I would use a Config class with public static properties:
The latter is very similar to the
$config
array approach, but has the benefit (or may this be a drawback?) that the class is accessible from everywhere including functions and classes, whereas the array is accessible only in the global space unless you import it into functions/classes usingglobal $config;
.My two cents: Use both. Most application configuration settings belong in a global array variable. Config data needs to be accessible from diverse application parts, and this is what global variables are for. And keeping everything together in a an array is most sensible. An array can be extended, e.g. some options set in a config.php and the rest read from a config.ini for example.
But there is also a place for CONSTANTS. The fine line to draw is, if an option is really something that MIGHT change during the application runtime, or if it is more a of fixed/magic value. If once set up, you should not change an application setting (or rendering might fail), then this option shouldn't be in the array, but sementically fixed as constant. (That's an interpretative rule of thumb, but served me well.)
If the project settings is too heavy, then file(xml is better) is good and a dedicated class for settings is also good.
If the project settings is small, then array is best, its very fast and no I/O related issue will arise.
Even you can use database (slower and auth issue).
If you go for the array approach, you could use array literals for slightly more readable code:
Either will work nicely, do whichever you feel most comfortable with.
The best way is to store your setting in a file . and to manipulate this file declare a class which does operations on file