ebook img

PHP: The "right" way PDF

76 Pages·2016·0.559 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview PHP: The "right" way

PHP: The “Right” Way Your guide to PHP best practices, coding standards, and authoritative tutorials. Phil Sturgeon and Josh Lockhart Thisbookisforsaleathttp://leanpub.com/phptherightway Thisversionwaspublishedon2016-11-14 ThisisaLeanpubbook.LeanpubempowersauthorsandpublisherswiththeLeanPublishingprocess.Lean Publishingistheactofpublishinganin-progressebookusinglightweighttoolsandmanyiterationstoget readerfeedback,pivotuntilyouhavetherightbookandbuildtractiononceyoudo. ThisworkislicensedunderaCreativeCommonsAttribution-NonCommercial-ShareAlike3.0Unported License Tweet This Book! PleasehelpPhilSturgeonandJoshLockhartbyspreadingthewordaboutthisbookonTwitter! Thesuggestedhashtagforthisbookis#phptherightway. Findoutwhatotherpeoplearesayingaboutthebookbyclickingonthislinktosearchforthishashtagon Twitter: https://twitter.com/search?q=#phptherightway ThisbookisbuiltentirelyfromthehardworkputinfromthePHPcommunityviaGitHub.Therearetoo manytoname,butyouknowwhoyouare.Withoutallthepullrequestsandsuggestionsfromyoufolks, peoplewouldstillbedurp-clickingaroundoutdatedtutorialswithPHP4codeexampleslikeit’s2003. Contents 1. GettingStarted . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.1 UsetheCurrentStableVersion(7.0) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.2 Built-inwebserver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.3 MacSetup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.4 WindowsSetup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 2. CodeStyleGuide . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 3. LanguageHighlights . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 3.1 ProgrammingParadigms . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 3.2 Namespaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 3.3 StandardPHPLibrary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 3.4 CommandLineInterface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 3.5 Xdebug . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 4. DependencyManagement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 4.1 ComposerandPackagist . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 4.2 PEAR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 5. CodingPractices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 5.1 TheBasics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 5.2 DateandTime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 5.3 DesignPatterns . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 5.4 WorkingwithUTF-8 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 6. DependencyInjection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 6.1 BasicConcept . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 6.2 ComplexProblem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 6.3 Containers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 6.4 FurtherReading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 7. Databases . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 7.1 MySQLExtension. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 7.2 PDOExtension . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 7.3 InteractingwithDatabases . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 7.4 AbstractionLayers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 CONTENTS 8. Templating . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 8.1 Benefits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 8.2 PlainPHPTemplates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 8.3 CompiledTemplates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 8.4 FurtherReading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 9. ErrorsandExceptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 9.1 Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 9.2 Exceptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 10. Security . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 10.1 WebApplicationSecurity . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 10.2 PasswordHashing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 10.3 DataFiltering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 10.4 ConfigurationFiles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 10.5 RegisterGlobals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 10.6 ErrorReporting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 11. Testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 11.1 TestDrivenDevelopment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 11.2 BehaviorDrivenDevelopment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 11.3 ComplementaryTestingTools . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 12. ServersandDeployment. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 12.1 PlatformasaService(PaaS) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 12.2 VirtualorDedicatedServers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 12.3 SharedServers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 12.4 BuildingandDeployingyourApplication . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 13. Virtualization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 13.1 Vagrant . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 13.2 Docker . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 14. Caching . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 14.1 OpcodeCache . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 14.2 ObjectCaching . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 15. DocumentingyourCode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 15.1 PHPDoc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 16. Resources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 16.1 FromtheSource . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 16.2 PeopletoFollow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 16.3 Mentoring . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 16.4 PHPPaaSProviders . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 16.5 Frameworks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 16.6 Components . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 CONTENTS 16.7 OtherUsefulResources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 16.8 VideoTutorials . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 16.9 Books . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 17. Community . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 17.1 PHPUserGroups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 17.2 PHPConferences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 17.3 ElePHPants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 1. Getting Started 1.1 Use the Current Stable Version (7.0) If you are getting started with PHP, start with the current stable release of PHP 7.0¹. PHP 7.0 is very new, andaddsmanyamazingnewfeaturesovertheolder5.xversions.Theenginehasbeenlargelyre-written,and PHPisnowevenquickerthanolderversions. MostcommonlyinthenearfutureyouwillfindPHP5.xbeingused,andthelatest5.xversionis5.6.Thisis notabadoption,butyoushouldtrytoupgradetothelateststablequickly-PHP5.6willnotreceivesecurity updatesbeyond2018².Upgradingisreallyquiteeasy,astherearenotmanybackwardscompatibilitybreaks³. If you are not sure which version a function or feature is in, you can check the PHP documentation on the php.net⁴website. 1.2 Built-in web server With PHP 5.4 or newer, you can start learning PHP without installing and configuring a full-fledged web server.Tostarttheserver,runthefollowingcommandfromyourterminalinyourproject’swebroot: 1 > php -S localhost:8000 • Learnaboutthebuilt-in,commandlinewebserver⁵ 1.3 Mac Setup OS X comes prepackaged with PHP but it is normally a little behind the latest stable. Mavericks has 5.4.17, Yosemite5.5.9,ElCapitan5.5.29andSierra5.6.24,butwithPHP7.0outthatisoftennotgoodenough. TherearemultiplewaystoinstallPHPonOSX. Install PHP via Homebrew Homebrew⁶isapowerfulpackagemanagerforOSX,whichcanhelpyouinstallPHPandvariousextensions easily.HomebrewPHP⁷isarepositorythatcontainsPHP-related“formulae”forHomebrew,andwillletyou installPHP. ¹http://php.net/downloads.php ²http://php.net/supported-versions.php ³http://php.net/manual/migration70.incompatible.php ⁴http://php.net/manual/ ⁵http://php.net/features.commandline.webserver ⁶http://brew.sh/ ⁷https://github.com/Homebrew/homebrew-php#installation GettingStarted 2 At this point, you can install php53, php54, php55, php56 or php70 using the brew install command, and switchbetweenthembymodifyingyourPATHvariable.Alternativelyyoucanusebrew-php-switcher⁸which willswitchautomaticallyforyou. Install PHP via Macports TheMacPorts⁹Projectisanopen-sourcecommunityinitiativetodesignaneasy-to-usesystemforcompiling, installing, and upgrading either command-line, X11 or Aqua based open-source software on the OS X operatingsystem. MacPortssupportspre-compiledbinaries,soyoudon’tneedtorecompileeverydependencyfromthesource tarballfiles,itsavesyourlifeifyoudon’thaveanypackageinstalledonyoursystem. Atthispoint,youcaninstallphp54,php55,php56orphp70usingtheport installcommand,forexample: 1 sudo port install php56 2 sudo port install php70 AndyoucanrunselectcommandtoswitchyouractivePHP: 1 sudo port select --set php php70 Install PHP via phpbrew phpbrew¹⁰isatoolforinstallingandmanagingmultiplePHPversions.Thiscanbereallyusefuliftwodifferent applications/projectsrequiredifferentversionsofPHP,andyouarenotusingvirtualmachines. Install PHP via Liip’s binary installer Another popular option is php-osx.liip.ch¹¹ which provides one liner installation methods for versions 5.3 through 7.0. It doesn’t overwrite the PHP binaries installed by Apple, but installs everything in a separate location(/usr/local/php5). Compile from Source Another option that gives you control over the version of PHP you install, is to compile it yourself¹². In that case be sure to have installed either Xcode¹³ or Apple’s substitute “Command Line Tools for XCode”¹⁴ downloadablefromApple’sMacDeveloperCenter. ⁸https://github.com/philcook/brew-php-switcher ⁹https://www.macports.org/install.php ¹⁰https://github.com/phpbrew/phpbrew ¹¹http://php-osx.liip.ch/ ¹²http://php.net/install.macosx.compile ¹³https://github.com/kennethreitz/osx-gcc-installer ¹⁴https://developer.apple.com/downloads GettingStarted 3 All-in-One Installers The solutions listed above mainly handle PHP itself, and do not supply things like Apache, Nginx or a SQL server.“All-in-one”solutionssuchasMAMP¹⁵andXAMPP¹⁶willinstalltheseotherbitsofsoftwareforyou andtiethemalltogether,buteaseofsetupcomeswithatrade-offofflexibility. 1.4 Windows Setup You can download the binaries from windows.php.net/download¹⁷. After the extraction of PHP, it is recommendedtosetthePATH¹⁸totherootofyourPHPfolder(wherephp.exeislocated)soyoucanexecute PHPfromanywhere. For learning and local development, you can use the built in webserver with PHP 5.4+ so you don’t need to worry about configuring it. If you would like an “all-in-one” which includes a full-blown webserver and MySQLtoothentoolssuchastheWebPlatformInstaller¹⁹,XAMPP²⁰,EasyPHP²¹,OpenServer²²andWAMP²³ will help get a Windows development environment up and running fast. That said, these tools will be a littledifferentfromproductionsobecarefulofenvironmentdifferencesifyouareworkingonWindowsand deployingtoLinux. If you need to run your production system on Windows, then IIS7 will give you the most stable and best performance. You can use phpmanager²⁴ (a GUI plugin for IIS7) to make configuring and managing PHP simple. IIS7 comes with FastCGI built in and ready to go, you just need to configure PHP as a handler. For supportandadditionalresourcesthereisadedicatedareaoniis.net²⁵forPHP. Generally running your application on different environment in development and production can lead to strange bugs popping up when you go live. If you are developing on Windows and deploying to Linux (or anythingnon-Windows)thenyoushouldconsiderusingaVirtualMachine²⁶. ChrisTankersleyhasaveryhelpfulblogpostonwhattoolsheusestodoPHPdevelopmentusingWindows²⁷. ¹⁵http://www.mamp.info/en/downloads/ ¹⁶http://www.apachefriends.org/en/xampp.html ¹⁷http://windows.php.net/download/ ¹⁸http://www.windows-commandline.com/set-path-command-line/ ¹⁹http://www.microsoft.com/web/downloads/platform.aspx ²⁰http://www.apachefriends.org/en/xampp.html ²¹http://www.easyphp.org/ ²²http://open-server.ru/ ²³http://www.wampserver.com/en/ ²⁴http://phpmanager.codeplex.com/ ²⁵http://php.iis.net/ ²⁶/#virtualization_title ²⁷http://ctankersley.com/2015/07/01/developing-on-windows/

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.