PHP

In questo articolo esploreremo l'affascinante mondo di PHP. Dal suo impatto sulla società alla sua evoluzione nel tempo, PHP ha catturato l'attenzione e la curiosità di molte persone. Nel corso di questa analisi, esamineremo le diverse sfaccettature di PHP, dalla sua origine alla sua rilevanza oggi. Impareremo come PHP ha influenzato diversi aspetti della vita quotidiana, nonché il suo ruolo nella cultura popolare. Attraverso questo tour scopriremo l'importanza di PHP e il suo significato nel mondo moderno.

Disambiguazione – Se stai cercando altri significati, vedi PHP (disambigua).
PHP
linguaggio di programmazione
AutorePHP Group
Data di origine8 giugno 1995
Ultima versione8.3.13 (24 ottobre 2024) e 8.4.0 RC3 (24 ottobre 2024)
UtilizzoApplicazioni web lato server
ParadigmiImperativo, funzionale, orientato agli oggetti, procedurale, riflessione
TipizzazioneDebole
Estensioni comuniphp e phar
Influenzato daC++, Perl, C, Materia:Java, Tcl, HTML e JavaScript
Implementazione di riferimento
ImplementazioneInterprete
Sistema operativoMultipiattaforma
LicenzaLicenza PHP
Sito webwww.php.net

PHP (acronimo ricorsivo di "PHP: Hypertext Preprocessor", preprocessore di ipertesti; originariamente acronimo di "Personal Home Page"[1]) è un linguaggio di scripting interpretato, originariamente concepito per la programmazione di pagine web dinamiche. L'interprete PHP è un software libero distribuito sotto la licenza PHP[2].

Attualmente è principalmente utilizzato per sviluppare applicazioni web lato server, ma può essere usato anche per scrivere script a riga di comando o applicazioni stand-alone con interfaccia grafica. Un esempio di software scritto in PHP è MediaWiki, su cui si basano i progetti wiki della Wikimedia Foundation come Wikipedia.

Grazie soprattutto alla diffusione di Wordpress[3] (CMS scritto in PHP), secondo le statistiche, è il linguaggio lato server più usato al mondo[4][5][6].

Storia

Origini

Nato nel 1994 ad opera del danese Rasmus Lerdorf, PHP era in origine una raccolta di script CGI che permettevano una facile gestione delle pagine personali. Secondo l'annuncio originale di PHP 1.0 da parte dell'autore sul newsgroup comp.infosystems.www.authoring.cgi il significato originario dell'acronimo era Personal Home Page.[7]

Il pacchetto originario venne in seguito esteso e riscritto dallo stesso Lerdorf in C, aggiungendo funzionalità quali il supporto alla base di dati mSQL, e iniziò a chiamarsi PHP/FI, dove FI sta per Form Interpreter (interprete di form), prevedendo la possibilità di integrare il codice PHP nel codice HTML in modo da semplificare la realizzazione di pagine dinamiche. Nel 1997 si stimava che circa 50 000 siti Web erano basati su PHP.[8]

PHP 3

Il linguaggio cominciò a godere di una certa popolarità tra i progetti open source del web e venne così notato da Zeev Suraski e Andi Gutmans, due giovani programmatori. I due collaborarono nel 1998 con Lerdorf allo sviluppo della terza versione di PHP, il cui acronimo assunse il significato attuale, riscrivendone il motore che fu battezzato Zend da una contrazione dei loro nomi. Le caratteristiche chiave della versione PHP 3.0, frutto del loro lavoro, erano la straordinaria estensibilità, la connettività alla base di dati e il supporto iniziale per il paradigma a oggetti[9]. Verso la fine del 1998 PHP 3.0 era installato su circa il 10% dei server Web in Internet.

PHP 4

PHP diventò a questo punto sufficientemente maturo da competere con i linguaggi lato server come ASP, sviluppato da Microsoft, e cominciò ad essere usato su larga scala. La versione 4 di PHP venne lanciata nel 2000 e prevedeva notevoli migliorie[10].

La popolarità del linguaggio PHP è in costante crescita grazie alla sua flessibilità: nel giugno 2001 ha superato il milione di siti che lo utilizzano. Nell'ottobre 2002 più del 45% dei server Apache usava PHP[11].

Nel 2004 è stato uno dei linguaggi principali con cui è stato creato Facebook.

Nel gennaio 2005 è stato insignito del titolo di "Programming Language of 2004" dal TIOBE Programming Community Index[12], classifica che valuta la popolarità dei linguaggi di programmazione sulla base di informazioni raccolte dai motori di ricerca.

Nel 2005 la configurazione LAMP (Linux, Apache, MySQL, PHP) ha superato il 50% del totale dei server sulla rete mondiale.

PHP 5

Nel 2008 PHP 5 è diventata l'unica versione stabile in fase di sviluppo. A partire da PHP 5.3.0 il linguaggio implementa una funzione chiamata late static binding che può essere utilizzata per fare riferimento alla classe chiamata in un contesto di eredità statica.[13][14]

A partire dal 5 febbraio 2008, a causa dell'iniziativa GoPHP5 sostenuta da una serie di sviluppatori PHP, molti dei progetti open-source di alto profilo cessano di supportare PHP 4 nel nuovo codice e promuovono il passaggio da PHP 4 a PHP 5.[15]

La versione 5 di PHP ha raggiunto la release 5.6 prima di essere abbandonata dal punto di vista dello sviluppo e supporto nel gennaio 2019.[16]

PHP 7

Il 3 dicembre 2015 è stata pubblicata la versione 7, arrivata fino alla versione 7.4.33.[17] Il supporto della versione 7.4 è terminato nel novembre 2022.[18]

PHP 8

Il 27 novembre 2020 è stata pubblicata la versione 8.[19] È la prima versione di PHP a supportare la compilazione just-in-time aumentando di gran lunga le prestazioni.[20]

Caratteristiche

PHP riprende per molti versi la sintassi del C, come peraltro fanno molti linguaggi moderni, e del Perl. È un linguaggio a tipizzazione debole e dalla versione 5 migliora il supporto al paradigma di programmazione ad oggetti. Certi costrutti derivati dal C, come gli operatori fra bit e la gestione di stringhe come array, permettono in alcuni casi di agire a basso livello; tuttavia è fondamentalmente un linguaggio di alto livello, caratteristica questa rafforzata dall'esistenza delle sue oltre 3.000 funzioni API del nucleo base.

PHP è in grado di interfacciarsi a innumerevoli DBMS tra cui MySQL, PostgreSQL, MariaDB, Oracle, Firebird, IBM DB2, Microsoft SQL Server e anche basi di dati NoSql come MongoDB. Supporta numerose tecnologie come XML, SOAP, IMAP, FTP, CORBA. Si integra anche con altri linguaggi/piattaforme quali Java e .NET ed esiste un wrapper per tutte le librerie più diffuse come CURL, GD, Gettext, GMP, Ming, OpenSSL ed altro.

Fornisce un'API specifica per interagire con Apache, sebbene funzioni naturalmente con numerosi altri server web. È ben integrato senza l'uso di componenti esterni con il DBMS MySQL/MariaDB per il quale possiede più di una API (mysql, mysqli, PDO). A partire dalla versione 5, PHP integra al suo interno una piccola base di dati embedded, SQLite.[21] Per questi motivi esiste un'enorme quantità di script e librerie in PHP disponibili liberamente su Internet.

Dispone di un archivio chiamato PHP Extension and Application Repository (PEAR) che mette a disposizione un framework di librerie riusabili per lo sviluppo di applicazioni PHP e di PECL che raccoglie tutte le estensioni conosciute scritte in C.

PHP non ha ancora un supporto nativo per le stringhe Unicode o multibyte; il supporto Unicode è in fase di sviluppo per una futura versione di PHP e consentirà di usare caratteri non ASCII in stringhe e nomi di funzioni, classi e metodi.

Sicurezza

La percentuale di software non sicuro scritto in PHP, sul totale di tutte le falle di sicurezza nei software elencate dal Common Vulnerabilities and Exposures, ammontava al: 12% nel 2003, 20% nel 2004, 28% nel 2005, 43% nel 2006, 36% nel 2007, 34,8% nel 2008, 29,9% nel 2009 e 27,2% nel 2010[22]. La quasi totalità di queste vulnerabilità note ha origine da mancati adempimenti delle best practice da parte dei programmatori e dai relativi abusi di particolari funzionalità offerte dal PHP che in determinati utilizzi danno origine a gravi vulnerabilità. Un esempio noto sono i problemi legati agli abusi di Register globals e Magic quotes, funzionalità che se usate in modo errato potevano degenerare in vere e proprie backdoor all'interno del proprio programma PHP. Per evitare problemi di questo tipo molte di queste funzionalità sono state via via deprecate se non addirittura rimosse, come le due citate, nel susseguirsi delle versioni di PHP[23][24].

La maggior parte del software con problemi di sicurezza (2006) è associabile temporalmente con vecchie versioni di PHP in cui le configurazioni di default lasciavano spazio a una relativa semplicità nello scrivere software con potenziali problemi di sicurezza anche gravi.

È sempre buona norma rivedere la propria configurazione di PHP, contenuta generalmente nel file php.ini, per controllare le funzionalità attivate. Di solito nel file stesso si documentano 3 tipi di configurazioni: Configurazione di PHP di default, configurazione in un ambiente di sviluppo che consente per esempio di vedere a video gli errori e configurazione in un ambiente di produzione in cui tipicamente gli errori vengono scritti in un file di log.

Nel sito ufficiale è presente l'archivio storico delle versioni dismesse, aggiornato a novembre 2022.[16]

Attacchi hacker

PHP può essere soggetto a diversi attacchi hacker[25]:

  • Remote Code Execution (RCE) si verifica quando un utente malintenzionato è in grado di caricare codice sul sito Web ed eseguirlo.
  • SQL Injection o SQLi: permette agli attaccanti di effettuare attività di spoof identify, modificare dati esistenti, causare repudiation issues come l'annullamento di transazioni o la modifica dei bilanci, permette di ottenere tutti i dati sul sistema, eliminare o rendere inaccessibile dei dati, e creare o compromettere gli utenti del database server.
  • Cross-site scripting (XSS) si verifica quando un utente malintenzionato causa il caricamento di codice dannoso nel browser del visitatore del sito Web e la sua esecuzione. Questo codice può quindi eseguire azioni dannose come il furto di cookie utente.
  • Cross-site request forgery (CSRF): si verifica quando un utente malintenzionato può creare un collegamento e ottenere che un utente con accesso privilegiato lo clicchi per creare (per esempio) un nuovo utente "amministratore" con una password che conosce.
  • Iniezione di oggetti PHP. Si verifica quando un'applicazione PHP prende l'input dell'utente e lo passa a una funzione chiamata unserialize() che prende un oggetto immagazzinato e lo trasforma in un oggetto in memoria.
  • Remote e Local File Inclusion (RFI e LFI). Quando un'applicazione PHP accetta l'input dell'utente e lo passa a una funzione progettata per caricare un file. Se questo file è un URL, la funzione può caricare codice PHP da un altro sito Web specificato da un utente malintenzionato che verrà quindi eseguito sul sito Web attaccato. Le funzioni che possono essere suscettibili a RFI e LFI in PHP sono: include, include_once, fopen, file_get_contents, require, require_once.

Esempi di codice

Il seguente programma "Hello, World!" è scritto in codice PHP incorporato in un documento HTML:

<!DOCTYPE html>
<html>
    <head>
        <title>PHP "Hello, World!" program</title>
    </head>
    <body>
        <?php
            echo '<p>Hello, World!</p>';
        ?>
    </body>
</html>

Variabili

I nomi di variabili in PHP iniziano sempre con il simbolo del dollaro ($) e il carattere successivo non deve essere un numero, ad esempio $1 o $2 non sono nomi di variabili valide.

I nomi delle variabili sono case-sensitive, ovvero $ancora e $ANCORA sono due variabili distinte.

Una variabile può contenere tutti i caratteri A-Z , a-z , 0-9 e _. Una volta definite esse vengono istanziate senza definirne esplicitamente il "tipo":

$ciao = "Ciao mondo!";

Per mostrare il contenuto di $ciao, è possibile usare l'istruzione echo:

echo $ciao;

che visualizza “Ciao mondo!”. Se invece la variabile $ciao non esistesse generalmente echo genererebbe un errore non fatale (Notice).

Stringhe

In PHP una stringa di caratteri alfanumerici si rappresenta in due modi: racchiudendola tra apici doppi (") o singoli ('). Quando si usano gli apici doppi vengono interpretati eventuali caratteri speciali (per esempio la tabulazione, "col1\tcol2" o il carattere di fine riga, "riga1\nriga2") e viene restituito il contenuto delle variabili, ovvero:

echo "Ciao vale: $ciao";

Stampa: "Ciao vale: Ciao mondo!". Con gli apici singoli la stringa è salvata e utilizzata così com'è.

Esempio di composizione della frase "Wikipedia è meravigliosa" in due modi: usando gli apici singoli e doppi:

<?php
$uno = 'Wikipedia';
$due = 'è';
$tre = 'meravigliosa';

echo $uno . ' ' . $due . ' ' . $tre;
echo "$uno $due $tre";

Array (e foreach)

PHP gestisce gli array come delle mappe associative, ossia come un elenco di chiavi associate univocamente a un certo valore. Gli array in PHP possono perciò essere usati come una comune matrice, come una lista (vettore), uno stack, una coda o altro. Inoltre un qualsiasi elemento dell'array può a sua volta contenere altri array, anche multidimensionali[26] e tutti gli elementi dell'array o dei sotto-array possono essere fra loro di tipi di variabile diversi, dando così la possibilità di creare strutture dati complesse.

Gli array sono dinamici, infatti possono essere rimossi tramite unset();[27].

Dato che gli array in PHP sono associativi, possono essere usati tramite un costrutto chiamato foreach[28] che rende praticabile l'accesso ai contenuti ricavando tutte le singole associazioni di chiave-valore dell'array.

Codice d'esempio di un array associativo in cui ad ogni nome di città corrisponde il numero di abitanti. L'esempio visualizza a video ogni città con il suo numero di abitanti e poi la somma di tutti gli abitanti.

<?php
$residenti = [
    'Torino' => 908551,
    'Milano' => 1315791,
    'Roma' => 2753000
];

$somma = 0;

foreach ($residenti as $città => $nResidenti) {
	echo "La città $città ha $nResidenti abitanti";
	$somma += $nResidenti;
}

echo "In tutto ci sono $somma abitanti!";

L'output del codice è: La città Torino ha 908 551 abitanti. La città Milano ha 1 315 791 abitanti. La città Roma ha 2 753 000 abitanti. In tutto ci sono 4 977 342 abitanti

Per approfondimenti vedere la documentazione ufficiale online[26].

Funzioni

Le funzioni in PHP possono avere un insieme misto di parametri opzionali con valori predefiniti e parametri obbligatori.[29]

Esempio di funzione con un parametro obbligatorio e uno opzionale con valore predefinito.

<?php 
/**
* Programma che effettui
* la somma di minimo 2 numeri
* e massimo 3
*/
function somma(int $n1 = 0, int $n2 = 0, int $n3 = 0): int {
	return $n1 + $n2 + $n3;
}

echo somma(1, 5); //OUTPUT: 6
echo somma(1, 24); //OUTPUT: 25
echo somma(3, 4, 2); //OUTPUT: 9
echo somma(n1: 5, n3: 5); //OUTPUT: 10

Qualunque variabile di qualunque tipo creata dentro alla funzione è locale. Per specificare variabili globali dentro alla funzione si può usare global $variabile[30]

Esempio:

<?php
function esperimento(): void {
	global $a;
	$a = "tre";
	$b = "quattro";
	echo "Durante: $a $b";
}

$a = "uno";
$b = "due";

echo "Prima: $a $b";
esperimento();
echo "Dopo: $a $b";

Il risultato sarà: Prima uno due Durante tre quattro Dopo tre due.

Inclusioni

È possibile includere uno script PHP all'interno di un altro per eseguirne il codice, per evitare codice ridondante e per accedere a variabili, funzioni e classi definite nello script incluso.

Per farlo si utilizza una delle seguenti istruzioni: include[31], include_once[32], require[33] e require_once[34]. Esempio:

<?php
include 'header.php';
echo "Ciao mondo!";
include 'footer.php';

Tipi di inclusione:

  • Si usa include quando si vuole che venga inviato soltanto un segnale di avviso senza interrompere l'esecuzione del programma qualora la pagina da includere non esista.
  • Si usa require quando si vuole che venga inviato un segnale di errore fatale e il programma venga interrotto se la pagina da includere non esiste.
  • Si usa include_once, require_once quando il comando potrebbe essere ripetuto più volte anche in file diversi, creando così (potenzialmente) una inclusione ricorsiva, ma si vuole che la pagina non venga inclusa più di una volta. Se la pagina da includere non esiste si comportano analogamente ai rispettivi sopra citati.

Gestione dei parametri

PHP permette il passaggio di informazioni da una pagina all'altra attraverso le diverse funzionalità supportate dall'HTTP. Nello specifico, richieste di tipo GET (informazioni parametrizzate nella query string dell'URL), POST (informazioni generalmente con origine da un precedente invio di un form) e dei cookie (informazioni contenute in piccole stringhe di testo salvate fisicamente nella memoria locale di un browser), insieme al supporto alle sessioni (funzionalità basata sull'utilizzo dei cookie). Queste informazioni sono utilizzabili in PHP tramite quattro array di tipo associativo chiamati internamente: $_GET, $_POST, $_COOKIE, $_SESSION. Questi tipi di array vengono chiamati superglobali[35] ovvero che sono visibili ad ogni scope del programma.

In questo esempio di gestione di un parametro GET, con la richiesta http://example.org/esempio.php?pippo=Ciao, il server caricherà contenuto di esempio.php (qui sotto) e mostrerà sul browser "Ciao".

<?php
/*
 * Controllo se è stato ricevuto il parametro "pippo" tramite metodo GET.
 * Se è rilevato lo visualizzo; se non è rilevato avverto l'utente.
 */

if (isset($_GET)) {
	$a = $_GET; // Salvo nella variabile $a il parametro "pippo"

	$a = htmlentities( $a ); // Questo "disinnesca" eventuali contenuti HTML contenuti in $a

	echo $a; // Mostro a video
} else {
	echo "Nessun parametro di nome pippo trovato. Devi inviarlo!";
}

Una funzione con controllo sui parametri

<?php
function get_hello_world(mixed $value1, mixed $value2): string {
    $result = '';

	/*
	 * In PHP il controllo "if", se contiene una sola istruzione,
	 * può anche non avere le parentesi graffe di contenimento
	 * ma è buona norma usarle sempre, per leggibilità del codice.
	 */
    if ($value1 != '') {
        $result .= $value1;	// Equivale a: $result = $result . $value1;
    }

    if (($value1 != ' ') && ($value2 != ' ')) {
        $result .= " ";
	}

	/*
	 * !empty($value2) equivale a: $value2 != "" && $value2 != null
	 * Il "punto esclamativo" serve per negare un valore booleano
	 */
	if (!empty($value2)) {
		$result .= $value2;	// Equivale a: $result = $result . $value2;
	}

	return $result;
}

echo get_hello_world('Hello', 'world');

Il ciclo for

<?php
/*
 * In questo caso la variabile $n viene stampata a video, successivamente
 * viene incrementata di 1, il ciclo termina quando $n è uguale a 9 (il ciclo conta da 0 fino a 9 quindi 10 volte).
*/

for ($n = 0; $n <= 9; $n ++) {
     echo $n;
}

// Output -> 0123456789

Il ciclo while

<?php
/*
 * In questo caso vediamo come stampare a video dei risultati estratti
 * da una base di dati MySQL, eseguendo una query SQL.
 * Questo script è incompleto, in quanto prima è necessario effettuare
 * il collegamento alla base di dati MySQL tramite mysqli o PDO.
*/

$result = $mysqli->query("SELECT id FROM persone");

while ($row = $result->fetch_assoc()) {
	echo $row . "<br />";
}

/*
 * In questo modo estraiamo dei dati da una base di dati MySQL
 * sotto forma di array che verrà poi stampato tramite un ciclo while
*/

99 Bottles of Beer

Il seguente esempio stampa il testo della canzone 99 Bottles of Beer.

<?php
/*
 * Questo è un commento. Altri modi per commentare sono i simboli // e #
 * Questo tipo di commenti non ha bisogno degli asterischi (*) all'inizio
 * di ogni riga, ma lo si fa per convenzione. I simboli // e #
 * commentano solo il testo che si trova dopo di essi e fino alla fine della riga;
 * non c'è bisogno di finire il commento con qualche carattere speciale.
 */

/*
 * Prima definiamo una funzione chiamata "plural".
 * Restituisce una "s" se l'argomento passato non è 1.
 */
function plural(int $number): string {
	// L'operatore ternario (!= ? :) è una struttura condizionale 
	// simile a if-else: (condizione ? true : false)
	return ($number != 1 ) ? 's' : '';
}

// Definiamo una variabile chiamata $a_capo che contiene un a capo HTML,
// un carattere di ritorno e uno di nuova riga:
$a_capo = "<br />\r\n";

for ($i = 99; $i > 0; $i--) {
	echo "$i bottle" . plural($i) . " of beer on the wall,$a_capo";
	// Non abbiamo bisogno di ripetere il comando echo per ogni riga:
	echo "$i bottle" . plural($i) . " of beer . $a_capo
	Take one down, pass it around,$a_capo" .
	((($i - 1) != 0) ? $i - 1 : 'no more') .
	' bottle' . plural($i - 1) . " of beer on the wall.$a_capo$a_capo";
	/*
	 * PHP permette di creare stringhe su più righe, finché
	 * trova un punto e virgola (;) che termina l'istruzione.
	 * Un punto (.) concatena insieme più stringhe.
	 * Le variabili, che iniziano con il carattere "$", sono interpretate
	 * anche dentro i doppi apici ("), ma non dentro gli apici singoli (').
	 * Le funzioni, come plural(), non sono interpretate fra gli apici.
	 */
}
echo "Go to the store, $a_capo buy some more, $a_capo 99 bottles of beer on the wall!";

Esempio connessione con base di dati MySQL usando l'estensione MySQLi

Il PHP permette l'elaborazione di dati da base di dati MySQL. I dati verranno richiesti, inseriti e modificati attraverso opportune query usando alcune estensioni tra cui MySQLi e PDO.[36]

L'estensione MySQLi, dove la "i" sta per "improved", è stata messa a disposizione di PHP per sfruttare alcune nuove funzionalità messe a disposizione dalle versioni di MySQL versione 4.1.3 e successive ed è disponibile per PHP 5 e release superiori.

Esempio di connessione a base di dati e richiesta di un dato:

<?php
// Connessione a MySQL con l'estensione MySQLi
$mysqli = new mysqli('localhost', 'nome_utente_database', 'password_database', 'nome_database');

/*
 * Questo è il modo ufficiale di controllare se una connessione MySQL è fallita,
 */
if (null !== $mysqli->connect_error) {
    die("Connessione fallita, motivi: " . $mysqli->connect_error);
}

// Proviamo una query ipotizzando che stiamo elaborando dati provenienti da una simil-rubrica:
$SQLQuery = $mysqli->query("SELECT indirizzo, telefono FROM utenti WHERE nome = 'Francesca'");

// Da questa query otterremo l'indirizzo e il telefono della persona di nome Francesca, 
// ipotizzando sia presente nella tabella utenti della base di dati in questione.

// Ora "trasformiamo" i dati ricevuti dalla query in un array associativo, utilizzabile successivamente
$row = $SQLQuery->fetch_assoc();

// Mostriamo a video per esempio il numero di telefono dall'array
echo "Il numero di telefono di Francesca è: " . $row;

// Chiusura della connessione alla base di dati
$mysqli->close();

Per approfondimenti vedere il manuale online ufficiale MySQLi.[37]

php.ini

Il file di configurazione di PHP, chiamato php3.ini in PHP 3, e poi semplicemente php.ini nelle versioni successive, è letto all'avvio dell'interprete del linguaggio e fornisce le impostazioni dei vari moduli con cui l'interprete è stato compilato. Nella versione server modulare di PHP, questo avviene solo una volta, all'avvio del server web. Per le versioni CGI e CLI, invece, è invocato ad ogni richiesta.

Per visualizzare tutte le opzioni di configurazione è possibile utilizzare la funzione phpinfo().

Versioni

Versione Data di pubblicazione Supportato fino al
Vecchia versione non più supportata: 1.0 8 giugno 1995
Vecchia versione non più supportata: 2.0 1 novembre 1997
Vecchia versione non più supportata: 3.0 6 giugno 1998 20 ottobre 2000
Vecchia versione non più supportata: 4.0 22 maggio 2000 23 giugno 2001
Vecchia versione non più supportata: 4.1 10 dicembre 2001 12 marzo 2002
Vecchia versione non più supportata: 4.2 22 aprile 2002 6 settembre 2002
Vecchia versione non più supportata: 4.3 27 dicembre 2002 31 marzo 2005
Vecchia versione non più supportata: 4.4 11 luglio 2005 7 agosto 2008
Vecchia versione non più supportata: 5.0 13 luglio 2004 5 settembre 2005
Vecchia versione non più supportata: 5.1 24 novembre 2005 24 agosto 2006
Vecchia versione non più supportata: 5.2 2 novembre 2006 6 gennaio 2011
Vecchia versione non più supportata: 5.3 30 giugno 2009 14 agosto 2014
Vecchia versione non più supportata: 5.4 1 marzo 2012 3 settembre 2015
Vecchia versione non più supportata: 5.5 20 giugno 2013 10 luglio 2016
Vecchia versione non più supportata: 5.6 28 agosto 2014 31 dicembre 2018
6.x Non pubblicato N / A
Vecchia versione non più supportata: 7.0 3 dicembre 2015 3 dicembre 2018
Vecchia versione non più supportata: 7.1 1 dicembre 2016 1 dicembre 2019
Vecchia versione non più supportata: 7.2 30 novembre 2017 30 novembre 2020
Vecchia versione non più supportata: 7.3 6 dicembre 2018 6 dicembre 2021
Vecchia versione non più supportata: 7.4 28 novembre 2019 28 novembre 2022
Vecchia versione non più supportata: 8.0 26 novembre 2020 26 novembre 2023
Versione precedente ancora supportata: 8.1 25 novembre 2021 31 dicembre 2025
Versione precedente ancora supportata: 8.2 8 dicembre 2022 31 dicembre 2026
Versione stabile corrente: 8.3 23 novembre 2023 31 novembre 2027
Legenda:
Vecchia versione
Versione precedente ancora supportata
Versione corrente
Ultima versione di anteprima
Versione futura

Uso di PHP nei CMS

Grazie alle caratteristiche del linguaggio di programmazione è stato possibile realizzare CMS (Content Management Systems) modulari dove attraverso file. php è possibile integrare e migliorare le funzionalità del software (come accade con plugin e temi in Wordpress).[38] La complementarità tra linguaggio php e l'utilizzo di database relazionali interrogabili con l'SQL consente la creazione di CMS dinamici che portano alla realizzazione di siti web dalla struttura estremamente flessibile.

Alcuni dei CMS più diffusi che usano PHP sono:[39]

Uso di PHP nei MVC model view Controllers

Tra i più rinomati Model View Controllers Model-view-controller abbiamo Symfony e Laravel i quali hanno le caratteristiche di avere un core basato su librerie e packages creati da altri team e società come ad esempio Nodejs o Composer i quali rendono l'uso di packages (tali packages sono creati dalla comunità di programmatori PHP in packagist.org) composti da algoritmi integrativi e riutilizzabili nello stesso framework tramite PSR-4 o superiori si facilita l'uso di classi e l'autoload delle stesse. Usando la metodologia OOP (Oriented Object Programming) tramite l'incapsulazione si rende più sicura l'applicazione. Attualmente nel 2023 la versione consigliata per tali framework non può essere inferiore alla versione 8.0 "per questioni di sicurezza". Una delle Caratteristiche più evidenti rispetto ai vecchi monoliti e la capacita di essere una applicazione modulare capace di ampliarsi e cambiare la sua forma con molta rapidità.Tra gli strumenti che facilitano tale versatilità abbiamo Artisan e Php Cli e Tinker.

Ambienti di sviluppo

Lista non esaustiva di IDE e semplici editor di testo con evidenziazione della sintassi.

Note

  1. ^ The PHP Group, History of PHP and related projects, su it.php.net. URL consultato il 26 aprile 2011 (archiviato il 28 gennaio 2021).
  2. ^ PHP: License Information, su php.net. URL consultato il 28 febbraio 2020.
  3. ^ WordPress Usage Statistics, su trends.builtwith.com. URL consultato il 30 gennaio 2021.
  4. ^ (EN) Most used languages among software developers globally 2020, su Statista. URL consultato il 30 gennaio 2021.
  5. ^ (EN) Usage Statistics and Market Share of Server-side Programming Languages for Websites, January 2021, su w3techs.com. URL consultato il 30 gennaio 2021.
  6. ^ Confronto tra CMS nel 2021: i sistemi più popolari per la gestione dei contenuti, su IONOS Digitalguide. URL consultato il 30 gennaio 2021.
  7. ^ (EN) Announce: Personal Home Page Tools (PHP Tools), su groups.google.ch, 8 giugno 1995. URL consultato il 6 luglio 2011.
  8. ^ (EN) Ellie Quigley e Marko Gargenta, PHP and MySQL by Example, Prentice Hall Professional, 22 novembre 2006, ISBN 978-0-13-800602-0. URL consultato il 28 febbraio 2020.
  9. ^ (EN) PHP Version 3 Documentation, su php.net. URL consultato il 28 febbraio 2020.
  10. ^ (EN) PHP 4 - features, su ntchosting.com. URL consultato il 28 febbraio 2020.
  11. ^ (EN) Usage Statistics and Market Share of PHP for Websites, February 2020, su w3techs.com. URL consultato il 28 febbraio 2020.
  12. ^ (EN) TIOBE Software Award, su tiobe.com. URL consultato il 12 dicembre 2022.
  13. ^ (EN) PHP 5 ChangeLog § 5.3.0, su php.net. URL consultato il 12 gennaio 2022.
  14. ^ (EN) PHP: Late Static Bindings - Manual, su php.net. URL consultato il 12 gennaio 2022.
  15. ^ (EN) GOPHP5!, su pear.php.net. URL consultato il 26 settembre 2017.
  16. ^ a b (EN) PHP: Unsupported Branches, su www.php.net. URL consultato il 12 dicembre 2022.
  17. ^ (EN) PHP 7 ChangeLog, su php.net. URL consultato il 28 febbraio 2020.
  18. ^ (EN) PHP: Supported Versions, su www.php.net. URL consultato il 12 dicembre 2022.
  19. ^ PHP 8 ChangeLog, su php.net. URL consultato il 12 gennaio 2022.
  20. ^ (EN) PHP 8: JIT performance in real-life web applications, su stitcher.io, 2 luglio 2020. URL consultato il 12 dicembre 2022.
  21. ^ (EN) PHP 5 ChangeLog § Version 5.0.0 Beta 1, su php.net. URL consultato il 12 gennaio 2022.
  22. ^ (EN) PHP-related vulnerabilities on the National Vulnerability Database, su coelho.net. URL consultato il 6 luglio 2011 (archiviato dall'url originale il 28 giugno 2009).
  23. ^ (EN) Using Register Globals, su php.net (archiviato dall'url originale il 2 giugno 2016).
  24. ^ (EN) Magic Quotes, su php.net (archiviato dall'url originale il 2 giugno 2016).
  25. ^ (EN) What are PHP Vulnerabilities & How Do They Originate?, su Wordfence. URL consultato il 28 gennaio 2021 (archiviato il 29 gennaio 2021).
  26. ^ a b Manuale PHP - array, su it2.php.net. URL consultato il 14 marzo 2018 (archiviato dall'url originale il 15 marzo 2018).
  27. ^ PHP: unset - Manual, su php.net. URL consultato il 17 ottobre 2020.
  28. ^ PHP: foreach - Manual, su php.net. URL consultato il 17 ottobre 2020.
  29. ^ Default Function Parameters In PHP | #! code, su hashbangcode.com. URL consultato il 17 ottobre 2020.
  30. ^ PHP: Variable scope - Manual, su php.net. URL consultato il 17 ottobre 2020.
  31. ^ Manuale PHP - include, su php.net. URL consultato il 31 gennaio 2014 (archiviato dall'url originale il 1º febbraio 2014).
  32. ^ Manuale PHP - include_once, su it2.php.net. URL consultato il 31 gennaio 2014 (archiviato dall'url originale il 1º febbraio 2014).
  33. ^ Manuale PHP - require, su it2.php.net. URL consultato il 31 gennaio 2014 (archiviato dall'url originale il 1º febbraio 2014).
  34. ^ Manuale PHP - require_once, su it2.php.net. URL consultato il 31 gennaio 2014 (archiviato dall'url originale il 1º febbraio 2014).
  35. ^ PHP: Superglobals - Manual, su php.net. URL consultato il 17 ottobre 2020.
  36. ^ PHP: Database Extensions - Manual, su php.net. URL consultato il 17 ottobre 2020.
  37. ^ MySQLi:query, su it2.php.net. URL consultato il 29 gennaio 2014 (archiviato dall'url originale il 1º febbraio 2014).
  38. ^ (EN) it:Scrivi un Plugin « WordPress Codex, su codex.wordpress.org. URL consultato il 6 ottobre 2022.
  39. ^ (EN) Top 10 PHP CMS Platforms For Developers in 2022, su plesk.com, 7 agosto 2022. URL consultato il 6 ottobre 2022.

Bibliografia

  • Zak Greant, Graeme Merrall, Torben Wilson, Brett Michlitsch (2002): PHP Functions Essential Reference, Sams, ISBN 0-7357-0970-X
  • Luke Welling, Laura Thomson (2004): PHP and MySQL Web Development, 3rd ed., SAMS, ISBN 0-672-32672-8
  • Matt Zandstra (2004): PHP 5 Objects, Patterns, and Practice, Apress, ISBN 1-59059-380-4
  • Eric Rosebrock, Eric Filson (2004): Setting Up LAMP: Getting Linux, Apache, MySQL, and PHP Working Together, SYBEX, ISBN 0-7821-4337-7
  • Cristian Darie, Mihai Bucica (2004): Beginning PHP 5 and MySQL E-Commerce: From Novice to Professional, Apress, ISBN 1-59059-392-8
  • David Powers (2005): Foundation PHP 5 for Flash, Friends of ED, ISBN 1-59059-466-5
  • Elizabeth Naramore, (2005): Beginning PHP5, Apache, and MySQL Web Development, Wrox, ISBN 0-7645-7966-5
  • Thomas Myer (2005): No Nonsense XML Web Development With PHP, SitePoint, ISBN 0-9752402-0-X
  • Marc Wandschneider (2005): Core Web Application Development with PHP and MySQL, Prentice-Hall, ISBN 0-13-186716-4
  • Steven Holzner (2005): Spring Into PHP 5 , Addison-Wesley, ISBN 0-13-149862-2
  • (2005): Building Online Communities with phpBB 2 , Packt Publishing, ISBN 1-904811-13-2
  • (2005): Web Standards Programmer's Reference: HTML, CSS, JavaScript, Perl, Python, and PHP, Wrox, ISBN 0-7645-8820-6
  • Chris Newman (2005): Sams Teach Yourself PHP in 10 Minutes, ISBN 0-672-32762-7
  • Paul Hudson (2005): PHP in a Nutshell, O'Reilly, ISBN 0-596-10067-1
  • Andi Gutmans, Stig S. Bakken, Derick Rethans (2005): PHP 5: Guida completa, Apogeo, ISBN 88-503-2304-2
  • Jack Herrington (2006), PHP Trucchi e segreti, Tecniche Nuove Hops, ISBN 88-481-1951-4
  • Rasmus Lerdorf (2003), PHP Pocket Reference, Tecniche Nuove Hops, ISBN 88-8378-070-1
  • Peter B. MacIntyre (2010), PHP – Le tecniche per scrivere il codice migliore, Tecniche Nuove, ISBN 978-88-481-2505-5

Voci correlate

Altri progetti

Collegamenti esterni

Controllo di autoritàLCCN (ENsh99002710 · GND (DE4546126-0 · BNE (ESXX548742 (data) · BNF (FRcb135584386 (data) · J9U (ENHE987007530371705171