PHP Programming: Difference between revisions

From Training Material
Jump to navigation Jump to search
 
(17 intermediate revisions by the same user not shown)
Line 61: Line 61:
** <small>https://phpcheatsheets.com/</small>
** <small>https://phpcheatsheets.com/</small>
** <small>https://phptherightway.com/pages/The-Basics.html</small>
** <small>https://phptherightway.com/pages/The-Basics.html</small>
* '''Examples and exercises'''
'''Examples and exercises'''
** ''localhost/phpWay''
* ''localhost/phpWay''
 
== Security ==
* authorization and authentication
* using cookies and sessions
 
== Dealing with Images ==
GD Library and alternatives


== PHP XML ==
== PHP XML ==
Line 81: Line 74:
'''Examples and exercises'''
'''Examples and exercises'''
* ''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
* '''Examples and exercises'''
** ''localhost/ws_''
** ''localhost/wordpress''


== Using Databases ==
== Using Databases ==
Line 112: Line 91:
* modifying and removing data
* modifying and removing data
* binding form to records in the database
* binding form to records in the database
* '''Examples and exercises'''
* '''Helpers'''
** ''localhost/phpWay''
** <small>https://phptherightway.com/#databases</small>
** ''localhost/ws_''
'''Examples and exercises'''
** ''localhost/wordpress''
* ''localhost/phpWay''
* ''localhost/ws_''
* ''localhost/wordpress''


== Programming interfaces ==
== Programming interfaces ==
Line 127: Line 108:
* ''localhost/ws_''
* ''localhost/ws_''


== Design Patterns ==
== 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
* '''Examples and exercises'''
* '''Helpers'''
** ''localhost/ws_''
** <small>https://www.php-fig.org/psr/</small>
** ''localhost/wordpress''
** <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 -->
<!-- TODO: prep the OOP example with tdd, unit tests and docker; DAY2 -->


Line 140: Line 150:
* 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 ==
Line 149: Line 165:
* SSL
* SSL


== Stacks - lamp, wamp, etc ==
== Security ==
* authorization and authentication
* using cookies and sessions
* '''OAUTH''' - <small>https://oauth.net/2/</small>
** ''openid'' - <small>https://openid.net/developers/how-connect-works/</small>
* '''JWT''' - <small>https://www.rfc-editor.org/info/rfc7519</small>
** ''Demo'' - <small>https://jwt.io/</small>
** ''Popular lib'' - <small>https://github.com/firebase/php-jwt</small>
 
== Stacks and Frameworks - lamp, wamp, etc ==
* '''wordpress'''
* '''wordpress'''
** <small>https://developer.wordpress.org/advanced-administration/before-install/development/</small>
** <small>https://developer.wordpress.org/advanced-administration/before-install/development/</small>
Line 186: Line 211:
wp '''API''' refs
wp '''API''' refs
* <small>https://developer.wordpress.org/reference/</small>
* <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.

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)

Examples and exercises

  • localhost/phpWay

PHP XML

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

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

Examples and Exercises

  • localhost/mw - enable GD and check how mw uses Image thumbnailing

Design Patterns, PSRs

Examples and exercises

  • localhost/ws_
  • localhost/wordpress

Efficiency

Examples and exercises

  • localhost/wm - install wm and enable APCu

Safety

  • Filtering input
  • Session fixation
  • Session hijacking
  • SQL injection
  • Storing passwords
  • SSL

Security

Stacks and Frameworks - lamp, wamp, etc

wp

wp con't

wp API refs

mw