PHP
About
PHP is an interpreted programming language most commonly used in web sites. It is the language in which the MediaWiki, WordPress, Drupal, and ZenCart web software packages, among many others, are written.
Note that much of the information on this page is somewhat outdated; PHP continues to be actively developed and improved.
subpages
- /arrays
- /CLI: using PHP from a command line interface
- /criticism: why PHP is bad
- /debugging/interactive
- /frameworks
- /interface keyword
- /type declaration
Related Articles
- Apache and PHP: getting the two of them to work together nicely
- Perl vs. PHP: comparisons between the two languages
- PHP-GTK
- register_globals
Links
Reference
- Official
- Manual
- Language Reference
- Magic constants
- parameter types: Function arguments (aka type hinting)
- Language Reference
- Manual
- Wikipedia
- PHP Wiki
Projects
- PHP The Right Way: good practices and patterns
- Hardened PHP: patches to improve PHP security
- 3v4l.org "is an online shell that allows you to run your code on my server. I compiled more than 200 different PHP versions (every version released since 4.3.0) plus HHVM for you to use."
Development Tools
- phpUnderControl - "Continuous Integration for PHP"
Users Groups
Coding Resources
Newbie Traps & Pitfalls
PHP will let you get away with a lot of syntax mistakes which are perfectly valid code (often creating unexpected variables in the process) but not what you intended. Most of the following produced no immediate error messages; the code simply wouldn't work, and it took me several edit-upload-run cycles to find each problem. Here are some mistakes I made when re-learning PHP in 2005 after not using it since 1997:
- Classes:
- Member vars and functions must always be referred to using $this->FunctionName()
- However, var members do not take a $ prefix: $this->varName
- If you pass an object to a function, the function will be operating on a copy of the object unless the function is called with the object passed as a reference: CalledFunction(&$objName);. The function declaration itself needs no modifications.
- If the function is expected to store the object for later use (e.g. it is a class constructor), the function must also use a reference when saving the object: $this->localName =& $iObjectParam;. Otherwise (again) it will be using a copy, not the original.
- In a child function (class child extends parent), if the parent has member variables declared as "private" and you attempt to access them with $this->varname, PHP will silently create new member variables for the child scope rather than referencing the old ones or generating an error. (Change the var declarations to "protected".)
- Operators:
- The "is equal to" comparison operator is "==" (as in c/c++), not "="
Notes
One of the major weaknesses of PHP as a serious programming language is its lack of any way to require variable declaration before usage -- the equivalent of "use strict;" in Perl or "Option Explicit" in Visual Basic. Here is a brief discussion of this problem, with a workaround which might be useful in some situations (but not if you need to turn off warnings for other reasons, such as needing to suppress messages about duplicate http headers).
Error Messages
some of these are not found in the PHP documentation
- REG_EMPTY: regex-related, but not sure what it means; it may reflect a difference between Perl-style regex (preg_* functions) and grep-style regex (ereg* functions). I changed the expression "('|")" to "['"]", and this seemed to solve the problem.
- REG_ERANGE: This error appears to originate in the regex library, and means "Invalid character range, e.g. ending point is earlier in the collating order than the starting point." (Documented here)
- In one case, this was caused by having a forward-slash ("/") in the bracketed list of possible characters; escaping the forward slash fixed the problem.