PHP Programming: Difference between revisions
												
				Jump to navigation
				Jump to search
				
| Lsokolowski1 (talk | contribs) m →PHP can | Lsokolowski1 (talk | contribs) | ||
| (28 intermediate revisions by the same user not shown) | |||
| Line 10: | Line 10: | ||
| == Intro == | == Intro == | ||
| '''PHP''' | |||
| * general-purpose '''scripting''' language   | * general-purpose '''scripting''' language   | ||
| * especially suited to '''web''' development | * especially suited to '''web''' development | ||
| Line 30: | Line 31: | ||
| ** whats needed? - the '''PHP parser''' (CGI or server module), a '''web server''', and a '''web browser''' | ** whats needed? - the '''PHP parser''' (CGI or server module), a '''web server''', and a '''web browser''' | ||
| * be used on all major operating systems | * be used on all major operating systems | ||
| * support most of the web servers (Apache, IIS, lighttpd, nginx | * '''support''' most of the '''web servers''' (Apache, IIS, lighttpd, nginx, etc) | ||
| * support talking to other services - LDAP, IMAP, SNMP, NNTP, POP3, HTTP, COM (on Windows) | * support '''talking to''' other '''services''' - ''LDAP, IMAP, SNMP, NNTP, POP3, HTTP, COM (on Windows)'' | ||
| * work as either a module, or as a CGI processor | * work as either a '''module''', or as a '''CGI processor''' | ||
| * do procedural programming or object-oriented programming (OOP), or a mixture of them both | * do '''procedural''' programming or '''object-oriented''' programming (OOP), or a mixture of them '''both''' | ||
| === PHP can con't === | === PHP can con't === | ||
| * also command line scripting | * also do '''command line''' scripting | ||
| **  | ** '''run without''' any server or browser - only the PHP '''parser''' is needed | ||
| ** ideal for scripts regularly executed using cron (on Unix or macOS) or Task Scheduler (on Windows) | ** ideal for scripts regularly executed using '''cron''' (on ''Unix'' or ''macOS'') or '''Task Scheduler''' (on ''Windows'') | ||
| * so ie. do simple/stronger text processing tasks - Perl regexps (PCRE), etc | * so ie. do simple/stronger '''text processing''' tasks - ''Perl'' regexps (''PCRE''), etc | ||
| * output HTML, images, PDF, encrypted data, emails, JSON, XML (libxml2, SimpleXML, XMLReader, XMLWriter; XDebug) | * output '''HTML''', images, '''PDF''', '''encrypted''' data, emails, '''JSON''', XML (''libxml2, SimpleXML, XMLReader, XMLWriter; XDebug'') | ||
| **  | ** '''auto generate''' these files, and '''save''' them in the file system, instead of printing it out, forming a '''server-side cache''' for dynamic content | ||
| * support a wide range of databases | * support a wide range of '''databases''' | ||
| ** via db specific ext, or abstraction layers (like PDO), or ODBC, cURL, sockets (CouchDB) | ** via db specific ext, or abstraction layers (like ''PDO''), or ODBC, cURL, '''sockets''' (''CouchDB'') | ||
| * support the WDDX complex data exchange   | * support the '''WDDX''' complex '''data exchange'''  | ||
| * instantiate Java objects and use them transparently as own objects | * '''instantiate Java''' objects and use them '''transparently''' as own objects | ||
| == Data Structures (refresher only) == | == Data Structures (refresher only) == | ||
| * Associative arrays | * Associative arrays | ||
| * Session variables, global variables, cookies | * Session variables, global variables, cookies | ||
| Line 60: | Line 58: | ||
| * Exceptions Handling | * Exceptions Handling | ||
| * PHP Filter | * PHP Filter | ||
| * '''Helpers''' | |||
| ** <small>https://phpcheatsheets.com/</small> | |||
| ** <small>https://phptherightway.com/pages/The-Basics.html</small> | |||
| '''Examples and exercises''' | |||
| * ''localhost/phpWay'' | |||
| == PHP XML == | == PHP XML == | ||
| * SimpleXML | * SimpleXML | ||
| * '''Expat''' Parser - event-based | * '''Expat''' Parser - event-based | ||
| Line 77: | Line 71: | ||
| * '''XML Reader''' | * '''XML Reader''' | ||
| ** https://www.php.net/XMLReader | ** https://www.php.net/XMLReader | ||
| ** '''iterators''' helper - https:// | ** '''iterators''' helper - https://github.com/hakre/XMLReaderIterator | ||
| '''Examples and exercises''' | '''Examples and exercises''' | ||
| * ''localhost/ws_'' | * ''localhost/ws_'' | ||
| == Using Databases == | == Using Databases == | ||
| * Methods of data storing | |||
| * Methods of data storing  | |||
| * PDO extension | * PDO extension | ||
| * Connecting to a database using PDO | * Connecting to a database using PDO | ||
| Line 110: | Line 91: | ||
| * modifying and removing data | * modifying and removing data | ||
| * binding form to records in the database | * binding form to records in the database | ||
| * '''Helpers''' | |||
| ** <small>https://phptherightway.com/#databases</small> | |||
| '''Examples and exercises''' | |||
| * ''localhost/phpWay'' | |||
| * ''localhost/ws_'' | |||
| * ''localhost/wordpress'' | |||
| == Programming interfaces == | == Programming interfaces == | ||
| * Architecture services | * Architecture services | ||
| * Adding to the system API | * Adding to the system API | ||
| Line 122: | Line 108: | ||
| * ''localhost/ws_'' | * ''localhost/ws_'' | ||
| ==  | == Object-Oriented Programming == | ||
| * Terminology Object | |||
| * Declaring classes and constructors | |||
| * Creating and Using Objects | |||
| * Properties and methods | |||
| * Inheritance | |||
| * Access modifiers | |||
| * Magic methods | |||
| * Declaring and using interfaces | |||
| * exception Handling | |||
| * '''Helpers''' | |||
| ** <small>https://phptherightway.com/#programming_paradigms</small> | |||
| '''Examples and exercises''' | |||
| * ''localhost/ws_'' | |||
| * ''localhost/wordpress'' | |||
| == Dealing with Images == | |||
| * GD Library and alternatives | |||
| ** '''GD''' - <small>https://www.php.net/manual/en/book.image.php</small> | |||
| ** '''ImageMagick''' - <small>https://www.php.net/manual/en/book.imagick.php</small> | |||
| ** '''Gmagic''' - <small>https://www.php.net/manual/en/book.gmagick.php</small> | |||
| * '''Exif''' - image meta data only | |||
| ** <small>https://www.php.net/manual/en/book.exif.php</small> | |||
| '''Examples and Exercises''' | |||
| * ''localhost/mw'' - enable GD and check how mw uses Image thumbnailing | |||
| == Design Patterns, PSRs == | |||
| * What are design patterns | * What are design patterns | ||
| * Singleton Pattern | * Singleton Pattern | ||
| * Factory Pattern | * Factory Pattern | ||
| * MVC model-view-controller | * MVC model-view-controller | ||
| * '''Helpers''' | |||
| ** <small>https://www.php-fig.org/psr/</small> | |||
| ** <small>https://phptherightway.com/#design_patterns</small> | |||
| '''Examples and exercises''' | |||
| * ''localhost/ws_'' | |||
| * ''localhost/wordpress'' | |||
| <!-- TODO: prep the OOP example with tdd, unit tests and docker; DAY2 --> | |||
| == Efficiency == | == Efficiency == | ||
| * Research applications performance | * Research applications performance | ||
| * Code cache | * Code cache | ||
| ** built-in '''opcache''' (since ver 5)  | |||
| ** '''APCu''', Memcached, Redis, WinCache | |||
| * '''Helpers''' | |||
| ** <small>https://phptherightway.com/#opcode_cache</small> | |||
| '''Examples and exercises''' | |||
| * ''localhost/wm'' - install '''wm''' and enable APCu | |||
| == Safety == | == Safety == | ||
| * Filtering input | * Filtering input | ||
| * Session fixation | * Session fixation | ||
| Line 143: | Line 165: | ||
| * SSL | * SSL | ||
| == Stacks - lamp, wamp, etc == | == Security == | ||
| * wordpress | * authorization and authentication | ||
| ** https://developer.wordpress.org/advanced-administration/before-install/development/ | * using cookies and sessions | ||
| * drupal | * '''OAUTH''' - <small>https://oauth.net/2/</small> | ||
| ** https://www.drupal.org/docs/official_docs/local-development-guide | ** ''openid'' - <small>https://openid.net/developers/how-connect-works/</small> | ||
| * symfony | * '''JWT''' - <small>https://www.rfc-editor.org/info/rfc7519</small> | ||
| ** https://symfony.com/doc/current/setup.html | ** ''Demo'' - <small>https://jwt.io/</small> | ||
| * Laravel: A PHP framework known for its clean architecture and robust features, including database agnostic migrations, ORM, routing, and authentication tools. | ** ''Popular lib'' - <small>https://github.com/firebase/php-jwt</small> | ||
| ** https://laravel.com/docs/12.x#installing-php | |||
| * Zend Framework: An open-source framework for developing web applications and services using PHP. | == Stacks and Frameworks - lamp, wamp, etc == | ||
| ** https://docs.laminas.dev/laminas-mvc/ | * '''wordpress''' | ||
| * CakePHP: A PHP framework that offers a robust set of tools for web application development. | ** <small>https://developer.wordpress.org/advanced-administration/before-install/development/</small> | ||
| * '''drupal''' | |||
| ** <small>https://www.drupal.org/docs/official_docs/local-development-guide</small> | |||
| * '''symfony''' | |||
| ** <small>https://symfony.com/doc/current/setup.html</small> | |||
| * '''Laravel''': A PHP framework known for its clean architecture and robust features, including database agnostic migrations, ORM, routing, and authentication tools. | |||
| ** <small>https://laravel.com/docs/12.x#installing-php</small> | |||
| * '''Zend Framework''': An open-source framework for developing web applications and services using PHP. | |||
| ** <small>https://docs.laminas.dev/laminas-mvc/</small> | |||
| <!-- | |||
| * '''CakePHP''': A PHP framework that offers a robust set of tools for web application development. | |||
| ** todo | ** todo | ||
| * PSX: A PHP framework dedicated to building fully typed REST APIs, offering a new approach to API development and challenging existing frameworks like Laravel and Symfony. | * '''PSX''': A PHP framework dedicated to building fully typed REST APIs, offering a new approach to API development and challenging existing frameworks like Laravel and Symfony. | ||
| ** todo | ** todo | ||
| * yannoff/console: A lightweight, simple alternative to symfony/console designed for easy PHP applications development. | * '''yannoff/console''': A lightweight, simple alternative to symfony/console designed for easy PHP applications development. | ||
| ** todo | ** todo | ||
| --> | |||
| === wp === | === wp === | ||
| * wp-env | * '''wp-env''' | ||
| ** https://developer.wordpress.org/block-editor/reference-guides/packages/packages-env/ | ** <small>https://developer.wordpress.org/block-editor/reference-guides/packages/packages-env/</small> | ||
| * ddev | * '''ddev''' | ||
| ** https://ddev.readthedocs.io/en/stable/users/quickstart/#wordpress | ** <small>https://ddev.readthedocs.io/en/stable/users/quickstart/#wordpress</small> | ||
| * vvv | * '''vvv''' | ||
| ** https://varyingvagrantvagrants.org/ | ** <small>https://varyingvagrantvagrants.org/</small> | ||
| * xampp | * '''xampp''' | ||
| ** http://apachefriends.org/ | ** <small>http://apachefriends.org/</small> | ||
| * mamp | * '''mamp''' | ||
| ** https://documentation.mamp.info/en/MAMP-Windows/index.html | ** <small>https://documentation.mamp.info/en/MAMP-Windows/index.html</small> | ||
| * local | * '''local''' | ||
| ** https://localwp.com/ | ** <small>https://localwp.com/</small> | ||
| === wp con't === | === wp con't === | ||
| wp  | wp '''API''' refs | ||
| * https://developer.wordpress.org/reference/ | * <small>https://developer.wordpress.org/reference/</small> | ||
| === mw === | |||
| * Docs | |||
| ** Main <small>https://www.mediawiki.org/wiki/Manual:Contents</small> | |||
| ** Code <small>https://doc.wikimedia.org/mediawiki-core/master/php/</small> | |||
| * Stacks <small>https://www.mediawiki.org/wiki/Software_bundles</small> | |||
Latest revision as of 13:31, 18 March 2025
THIS IS A DRAFT
This text may not be complete.
PHP Programming Training Materials
IMPORTANT NOTE for trainers only: Please DO NOT change these materials, especially the EXERCISES, without direct permission from: LUKASZ SOKOLOWSKI.
Copyright Notice
Copyright © 2004-2025 by NobleProg Limited All rights reserved.
This publication is protected by copyright, and permission must be obtained from the publisher prior to any prohibited reproduction, storage in a retrieval system, or transmission in any form or by any means, electronic, mechanical, photocopying, recording, or likewise.
Intro
PHP
- general-purpose scripting language
- especially suited to web development
- fast, flexible and pragmatic
- powers everything from simple blog to the corporate organisations
Intro con't
PHP - recursive acronym for PHP: Hypertext Preprocessor
- widely-used open source language
- can be embedded into HTML
- code is executed on the server, generating HTML which is then sent to the client
- extremely simple, yet offers many advanced features
PHP can
- collect form data
- generate dynamic page content
- send and receive cookies
- so in general - server-side scripting
- whats needed? - the PHP parser (CGI or server module), a web server, and a web browser
 
- be used on all major operating systems
- support most of the web servers (Apache, IIS, lighttpd, nginx, etc)
- support talking to other services - LDAP, IMAP, SNMP, NNTP, POP3, HTTP, COM (on Windows)
- work as either a module, or as a CGI processor
- do procedural programming or object-oriented programming (OOP), or a mixture of them both
PHP can con't
- also do command line scripting
- run without any server or browser - only the PHP parser is needed
- ideal for scripts regularly executed using cron (on Unix or macOS) or Task Scheduler (on Windows)
 
- so ie. do simple/stronger text processing tasks - Perl regexps (PCRE), etc
- output HTML, images, PDF, encrypted data, emails, JSON, XML (libxml2, SimpleXML, XMLReader, XMLWriter; XDebug)
- auto generate these files, and save them in the file system, instead of printing it out, forming a server-side cache for dynamic content
 
- support a wide range of databases
- via db specific ext, or abstraction layers (like PDO), or ODBC, cURL, sockets (CouchDB)
 
- support the WDDX complex data exchange
- instantiate Java objects and use them transparently as own objects
Data Structures (refresher only)
- Associative arrays
- Session variables, global variables, cookies
- Date
- File and File Upload
- Cookies and Sessions
- Error Handling
- Exceptions Handling
- PHP Filter
- Helpers
Examples and exercises
- localhost/phpWay
PHP XML
- SimpleXML
- Expat Parser - event-based
- XML DOM
- XML Reader
- https://www.php.net/XMLReader
- iterators helper - https://github.com/hakre/XMLReaderIterator
 
Examples and exercises
- localhost/ws_
Using Databases
- Methods of data storing
- PDO extension
- Connecting to a database using PDO
- Operations on data
- Error Handling PDO
- Transactions
- Primary keys
- Joins
- Aggregate functions and grouping
- connect to the database
- storing passwords
- executing queries
- processing data
- modifying and removing data
- binding form to records in the database
- Helpers
Examples and exercises
- localhost/phpWay
- localhost/ws_
- localhost/wordpress
Programming interfaces
- Architecture services
- Adding to the system API
- The data format JSON and XML
- RESTful Services
- Designing Web Service
Examples and exercises
- WebServices
- localhost/ws_
Object-Oriented Programming
- Terminology Object
- Declaring classes and constructors
- Creating and Using Objects
- Properties and methods
- Inheritance
- Access modifiers
- Magic methods
- Declaring and using interfaces
- exception Handling
- Helpers
Examples and exercises
- localhost/ws_
- localhost/wordpress
Dealing with Images
- GD Library and alternatives
- Exif - image meta data only
Examples and Exercises
- localhost/mw - enable GD and check how mw uses Image thumbnailing
Design Patterns, PSRs
- What are design patterns
- Singleton Pattern
- Factory Pattern
- MVC model-view-controller
- Helpers
Examples and exercises
- localhost/ws_
- localhost/wordpress
Efficiency
- Research applications performance
- Code cache
- built-in opcache (since ver 5)
- APCu, Memcached, Redis, WinCache
 
- Helpers
Examples and exercises
- localhost/wm - install wm and enable APCu
Safety
- Filtering input
- Session fixation
- Session hijacking
- SQL injection
- Storing passwords
- SSL
Security
- authorization and authentication
- using cookies and sessions
- OAUTH - https://oauth.net/2/
- JWT - https://www.rfc-editor.org/info/rfc7519
- Demo - https://jwt.io/
- Popular lib - https://github.com/firebase/php-jwt
 
Stacks and Frameworks - lamp, wamp, etc
- wordpress
- drupal
- symfony
- Laravel: A PHP framework known for its clean architecture and robust features, including database agnostic migrations, ORM, routing, and authentication tools.
- Zend Framework: An open-source framework for developing web applications and services using PHP.
wp
- wp-env
- ddev
- vvv
- xampp
- mamp
- local
wp con't
wp API refs
