Paradigma | Multiparadigma : imperativo , funcional , orientado a objetos , procedimental , reflexivo |
---|---|
Diseñado por | Rasmus Lerdorf |
Revelador | El equipo de desarrollo de PHP , Zend Technologies , PHP Foundation |
Apareció por primera vez | 8 de junio de 1995 ( 08-06-1995 ) | [1] [2]
Versión estable | 8.3.12 / 26 de septiembre de 2024 ( 26/09/2024 ) [3] |
Versión preliminar | 8.4.0 RC 2 / 10 de octubre de 2024 ( 10/10/2024 ) [4] |
Disciplina de mecanografía | Dinámico , débil , gradual [5] |
Lenguaje de implementación | C (principalmente; algunos componentes C++ ) |
Sistema operativo | Similar a Unix , Windows , macOS , IBM i , OpenVMS , IBM Z |
Licencia | Licencia Pública General GNU versión 2 o cualquier versión posterior con doble licencia y Licencia PHP para versiones PHP 3.0 o anteriores. [6] Solo Licencia PHP (la mayor parte del motor Zend bajo la Licencia Zend Engine ) para 3.01x y versiones posteriores. |
Extensiones de nombre de archivo | .php , .phar , .phtml , .pht ,.phps |
Sitio web | www.php.net |
Implementaciones principales | |
Motor Zend , HHVM , PeachPie , Quercus , Parrot | |
Influenciado por | |
Perl , C , C++ , Java , [7] Tcl , [2] JavaScript [8] | |
Influenciado | |
Hackear , JSP , ASP , React JS | |
PHP es un lenguaje de programación de propósito general orientado al desarrollo web . [9] Fue creado originalmente por el programador danés-canadiense Rasmus Lerdorf en 1993 y lanzado en 1995. [10] [11] La implementación de referencia de PHP ahora es producida por PHP Group. [12] PHP era originalmente una abreviatura de Personal Home Page , [13] [14] pero ahora representa el acrónimo recursivo PHP: Hypertext Preprocessor . [15]
El código PHP generalmente se procesa en un servidor web mediante un intérprete PHP implementado como un módulo , un demonio o un ejecutable de Common Gateway Interface (CGI). En un servidor web, el resultado del código PHP interpretado y ejecutado (que puede ser cualquier tipo de datos, como HTML generado o datos de imágenes binarias ) formaría la totalidad o parte de una respuesta HTTP . Existen varios sistemas de plantillas web , sistemas de gestión de contenido web y marcos web que se pueden emplear para orquestar o facilitar la generación de esa respuesta. Además, PHP se puede utilizar para muchas tareas de programación fuera del contexto web, como aplicaciones gráficas independientes [16] y control de drones . [17] El código PHP también se puede ejecutar directamente desde la línea de comandos .
El intérprete PHP estándar, impulsado por Zend Engine , es un software libre publicado bajo la Licencia PHP . PHP ha sido ampliamente adaptado y puede implementarse en la mayoría de los servidores web en una variedad de sistemas operativos y plataformas . [18]
El lenguaje PHP ha evolucionado sin una especificación o estándar formal escrito, y la implementación original actuó como el estándar de facto que otras implementaciones intentaron seguir.
W3Techs informa que al 23 de mayo de 2024 [actualizar](seis meses después del lanzamiento de PHP 8.3), el 76,2 % de todos los sitios web cuyo lenguaje de programación se pudo determinar utilizan PHP, y el 55,1 % de ellos utilizan PHP 7, que está desactualizado y se sabe que es inseguro. [19] [20]
El desarrollo de PHP comenzó en 1993 [10] cuando Rasmus Lerdorf escribió varios programas de Interfaz de Puerta de Enlace Común (CGI) en C , [21] [22] que utilizó para mantener su página de inicio personal . Los amplió para que funcionaran con formularios web y para comunicarse con bases de datos , y llamó a esta implementación "Página de inicio personal/Intérprete de formularios" o PHP/FI.
Un ejemplo de la sintaxis PHP temprana : [23]
<!--include /texto/encabezado.html--><!--getenv HTTP_USER_AGENT--> <!--if substr $exec_result Mozilla--> ¡Oye, estás usando Netscape! < p > <!--endif--><!--sql database select * from table where user='$username'--> <!--ifless $numentries 1--> Lo sentimos, ese registro no existe < p > <!--endif exit--> ¡Bienvenido <!--$user--> ! < p > Le quedan <!--$index:0--> créditos en su cuenta. < p ><!--include /texto/pie de página.html-->
PHP/FI se podía utilizar para crear aplicaciones web simples y dinámicas . Para acelerar el reporte de errores y mejorar el código, Lerdorf anunció inicialmente el lanzamiento de PHP/FI como "Personal Home Page Tools (PHP Tools) versión 1.0" en el grupo de discusión de Usenet comp.infosystems.www.authoring.cgi el 8 de junio de 1995. [1] [24] Esta versión incluía funcionalidades básicas como variables similares a Perl , manejo de formularios y la capacidad de incrustar HTML . En este punto, la sintaxis había cambiado para parecerse a la de Perl , pero era más simple, más limitada y menos consistente. [13] [12]
En sus inicios, PHP nunca tuvo la intención de ser un nuevo lenguaje de programación ; más bien, creció orgánicamente, y Lerdorf señaló en retrospectiva: "No sé cómo detenerlo [...] nunca hubo ninguna intención de escribir un lenguaje de programación [...] No tengo ni la menor idea de cómo escribir un lenguaje de programación [...] Simplemente seguí añadiendo el siguiente paso lógico en el camino". [25] Se empezó a formar un equipo de desarrollo y, después de meses de trabajo y pruebas beta , lanzó oficialmente PHP/FI 2 en noviembre de 1997. [26]
El hecho de que PHP no haya sido diseñado originalmente, sino que se haya desarrollado orgánicamente, ha llevado a una denominación inconsistente de las funciones y a un orden inconsistente de sus parámetros. [27] En algunos casos, los nombres de las funciones se eligieron para que coincidieran con las bibliotecas de nivel inferior que PHP estaba "envolviendo", [28] mientras que en algunas versiones muy tempranas de PHP la longitud de los nombres de las funciones se usaba internamente como una función hash , por lo que se eligieron nombres para mejorar la distribución de los valores hash . [29]
Zeev Suraski y Andi Gutmans reescribieron el analizador en 1997 y formaron la base de PHP 3, cambiando el nombre del lenguaje al acrónimo recursivo PHP: Hypertext Preprocessor . [12] [30] Posteriormente, comenzaron las pruebas públicas de PHP 3 y el lanzamiento oficial se produjo en junio de 1998. Suraski y Gutmans comenzaron entonces una nueva reescritura del núcleo de PHP, produciendo el motor Zend en 1999. [31] También fundaron Zend Technologies en Ramat Gan , Israel . [12]
El 22 de mayo de 2000 se lanzó PHP 4, basado en el motor Zend Engine 1.0. [12] En agosto de 2008, esta rama había alcanzado la versión 4.4.9. PHP 4 ya no se encuentra en desarrollo y no se prevé lanzar actualizaciones de seguridad. [32] [33]
El 1 de julio de 2004 se lanzó PHP 5, impulsado por el nuevo Zend Engine II. [12] PHP 5 incluía nuevas características como un soporte mejorado para la programación orientada a objetos , la extensión PHP Data Objects (PDO) (que define una interfaz liviana y consistente para acceder a bases de datos) y numerosas mejoras de rendimiento. [34] En 2008, PHP 5 se convirtió en la única versión estable en desarrollo. El enlace estático tardío había estado ausente en versiones anteriores de PHP, y se agregó en la versión 5.3. [35] [36]
Muchos proyectos de código abierto de alto perfil dejaron de soportar PHP 4 en código nuevo a partir del 5 de febrero de 2008, debido a la iniciativa GoPHP5, [37] proporcionada por un consorcio de desarrolladores de PHP que promovía la transición de PHP 4 a PHP 5. [38] [39]
Con el tiempo, los intérpretes de PHP se hicieron disponibles en la mayoría de los sistemas operativos de 32 y 64 bits existentes , ya sea compilándolos a partir del código fuente de PHP o utilizando binarios precompilados. [40] Para las versiones 5.3 y 5.4 de PHP, las únicas distribuciones binarias de Microsoft Windows disponibles eran compilaciones IA-32 de 32 bits , [41] [42] que requerían el modo de compatibilidad de 32 bits de Windows al usar Internet Information Services (IIS) en una plataforma Windows de 64 bits. La versión 5.5 de PHP hizo que las compilaciones x86-64 de 64 bits estuvieran disponibles para Microsoft Windows. [43]
El soporte de seguridad oficial para PHP 5.6 finalizó el 31 de diciembre de 2018. [44]
PHP recibió críticas mixtas debido a la falta de soporte nativo de Unicode en el nivel del lenguaje principal. [45] [46] En 2005, se inició un proyecto encabezado por Andrei Zmievski para brindar soporte nativo de Unicode en todo PHP, incorporando la biblioteca International Components for Unicode (ICU) y representando cadenas de texto como UTF-16 internamente. [47] Dado que esto causaría cambios importantes tanto en el interior del lenguaje como en el código de usuario, se planeó lanzar esto como la versión 6.0 del lenguaje, junto con otras características importantes que entonces estaban en desarrollo. [48]
Sin embargo, la falta de desarrolladores que comprendieran los cambios necesarios y los problemas de rendimiento que surgieron de la conversión a y desde UTF-16, que rara vez se utiliza en un contexto web, provocaron retrasos en el proyecto. [49] Como resultado, se creó una versión PHP 5.3 en 2009, con muchas características no Unicode incorporadas desde PHP 6, en particular los espacios de nombres. En marzo de 2010, el proyecto en su forma actual fue abandonado oficialmente y se preparó una versión PHP 5.4 para contener la mayoría de las características no Unicode restantes de PHP 6, como los rasgos y la re-vinculación de cierres. [50] Las esperanzas iniciales eran que se formara un nuevo plan para la integración de Unicode, pero en 2014 no se había adoptado ninguno. [ cita requerida ]
Durante 2014 y 2015, se desarrolló una nueva versión principal de PHP, PHP 7. La numeración de esta versión generó cierto debate entre los desarrolladores internos. [51] Si bien los experimentos Unicode de PHP 6 nunca se habían publicado, varios artículos y títulos de libros hacían referencia a los nombres de PHP 6, lo que podría haber causado confusión si una nueva versión reutilizara el nombre. [52] Después de una votación, se eligió el nombre PHP 7. [53]
La base de PHP 7 es una rama de PHP que originalmente se denominó PHP next generation ( phpng ). Fue creada por Dmitry Stogov, Xinchen Hui y Nikita Popov, [54] y tenía como objetivo optimizar el rendimiento de PHP mediante la refactorización del motor Zend, manteniendo al mismo tiempo una compatibilidad casi completa con el lenguaje. [55] Para el 14 de julio de 2014, los puntos de referencia basados en WordPress , que sirvieron como la suite de puntos de referencia principal para el proyecto phpng, mostraron un aumento de casi el 100% en el rendimiento. Los cambios de phpng facilitan la mejora del rendimiento en versiones futuras, ya que las estructuras de datos más compactas y otros cambios se consideran más adecuados para una migración exitosa a un compilador justo a tiempo (JIT). [56] Debido a los cambios significativos, el motor Zend rediseñado se denominó Zend Engine 3 , sucediendo al Zend Engine 2 utilizado en PHP 5. [57]
Debido a los importantes cambios internos en phpng, debe recibir un nuevo número de versión principal de PHP, en lugar de una versión menor de PHP 5, según el proceso de lanzamiento de PHP. [58] Las versiones principales de PHP pueden romper la compatibilidad con versiones anteriores del código y, por lo tanto, PHP 7 presentó una oportunidad para otras mejoras más allá de phpng que requieren interrupciones de compatibilidad con versiones anteriores. [ cita requerida ] En particular, implicó los siguientes cambios:
->
, []
, ()
, {}
, y ::
, con expresiones arbitrarias con significado del lado izquierdo. [60]foreach
declaración para que fuera más predecible. [62]mysql
(SAPI) y extensiones sin mantenimiento o en desuso, en particular la extensión heredada. [64]list()
Se modificó el comportamiento del operador para eliminar el soporte para cadenas. [65]<%
y %>
y <script language="php"> ... </script>
. [66]default
cláusulas. [67]PHP 7 también incluyó nuevas características del lenguaje. En particular, introdujo declaraciones de tipos de retorno para funciones [71] que complementan las declaraciones de tipos de parámetros existentes, y soporte para los tipos escalares (entero, flotante, cadena y booleano) en las declaraciones de parámetros y tipos de retorno. [72]
PHP 8 se lanzó el 26 de noviembre de 2020 y actualmente es la segunda versión principal de PHP más utilizada. PHP 8 es una versión principal y tiene cambios importantes con respecto a las versiones anteriores. [73] [74] Las nuevas características y los cambios notables incluyen:
La compilación Just-in-time es compatible con PHP 8. [75]
El compilador JIT de PHP 8 puede proporcionar mejoras de rendimiento sustanciales para algunos casos de uso, [76] [77] mientras que el desarrollador de PHP Nikita Popov afirmó que las mejoras de rendimiento para la mayoría de los sitios web serán menos sustanciales que la actualización de PHP 5 a PHP 7. [78] Se esperan mejoras sustanciales más para operaciones de tipo matemático que para casos de uso de desarrollo web comunes. [78] Además, el compilador JIT proporciona el potencial futuro de mover algo de código de C a PHP, debido a las mejoras de rendimiento para algunos casos de uso. [79]
PHP 8 introdujo la match
expresión. [80] La expresión de coincidencia es conceptualmente similar a una switch
declaración y es más compacta para algunos casos de uso. [81] Debido a que match
es una expresión, su resultado puede asignarse a una variable o devolverse desde una función. [82]
PHP 8 introdujo tipos de unión, un nuevo static
tipo de retorno y un nuevo mixed
tipo. [73]
Los "atributos", a menudo denominados "anotaciones" en otros lenguajes de programación, se agregaron en PHP 8, lo que permite agregar metadatos a las clases. [73]
throw
pasó de ser una declaración a ser una expresión. [83] Esto permite que se lancen excepciones en lugares donde antes no era posible. [73]
PHP 8 incluye cambios para permitir sintaxis alternativas, más concisas o más consistentes en una serie de escenarios. Por ejemplo, el operador nullsafe es similar al operador null coalescing ??
, pero se utiliza al llamar a métodos. [84] El siguiente fragmento de código no generará un error si getBirthday()
devuelve null:
$fecha_legible_humana = $usuario -> obtenerCumpleaños () ?-> diffForHumans ();
Se ha añadido la promoción de propiedades del constructor como " azúcar sintáctico ", lo que permite que las propiedades de clase se establezcan automáticamente cuando se pasan parámetros a un constructor de clase . [73] Esto reduce la cantidad de código repetitivo que debe escribirse. [85]
Otros cambios menores incluyen soporte para el uso de ::class
en objetos, que sirve como una alternativa para el uso de get_class()
; [73] capturas sin captura en bloques try-catch; ajustes de sintaxis de variables para resolver inconsistencias; soporte para argumentos nombrados; y soporte para comas finales en listas de parámetros, lo que agrega consistencia con el soporte para comas finales en otros contextos, como en matrices. [74]
WeakMap
contiene referencias a objetos, pero estas referencias no impiden que dichos objetos sean recolectados como basura . [86] Esto puede proporcionar mejoras de rendimiento en escenarios en los que se almacenan datos en caché ; esto es de particular relevancia para los mapeos relacionales de objetos (ORM). [73]DateTime
objetos a partir de interfaces y la adición de una Stringable
interfaz que se puede usar para sugerencias de tipos. [73]str_contains()
str_starts_with()
str_ends_with()
fdiv()
get_debug_type()
get_resource_id()
token_get_all()
PHP 8.1 se lanzó el 25 de noviembre de 2021. [89] Añadió compatibilidad con enumeraciones (también llamadas "enums"), la declaración de propiedades como readonly
(que evita la modificación de la propiedad después de la inicialización) y la descompresión de matrices con claves de cadena. El nuevo tipo never se puede utilizar para indicar que una función no retorna. [90]
PHP 8.2 se lanzó el 8 de diciembre de 2022. [91] Las novedades de esta versión son readonly
las clases (cuyas propiedades de instancia son implícitamente de solo lectura), los tipos de forma normal disyuntiva (DNF) y la random
extensión, que proporciona un generador de números pseudoaleatorios con una API orientada a objetos , [92] la redacción de valores de parámetros sensibles y un montón de otras características.
Versión | Fecha de lanzamiento | Con soporte hasta [93] | Notas |
---|---|---|---|
Versión antigua, ya no se mantiene: 1.0 | 8 de junio de 1995 | Oficialmente se denomina "Personal Home Page Tools (PHP Tools)". Este es el primer uso del nombre "PHP". [12] | |
Versión antigua, ya no se mantiene: 2.0 | 1 de noviembre de 1997 | Oficialmente llamado "PHP/FI 2.0", es la primera versión que podría definirse como PHP, ya que es un lenguaje independiente con muchas características que han perdurado hasta nuestros días. | |
Versión antigua, ya no se mantiene: 3.0 | 6 de junio de 1998 | 20 de octubre de 2000 [93] | El desarrollo pasa de una persona a varios desarrolladores. Zeev Suraski y Andi Gutmans reescribieron la base para esta versión. [12] |
Versión antigua, ya no se mantiene: 4.0 | 22 de mayo de 2000 [94] | 23 de junio de 2001 [93] | Se agregó un sistema de análisis de etiquetas de dos etapas más avanzado, llamado motor Zend. [95] |
Versión antigua, ya no se mantiene: 4.1 | 10 de diciembre de 2001 [96] | 12 de marzo de 2002 [93] | Se introdujeron "superglobales" ( $_GET , $_POST , $_SESSION , etc.) [95] |
Versión antigua, ya no se mantiene: 4.2 | 22 de abril de 2002 [97] | 6 de septiembre de 2002 [93] | Desactivado register_globals por defecto. Los datos recibidos a través de la red ya no se insertan directamente en el espacio de nombres global , cerrando así posibles agujeros de seguridad en las aplicaciones. [95] |
Versión antigua, ya no se mantiene: 4.3 | 27 de diciembre de 2002 [98] | 31 de marzo de 2005 [93] | Se introdujo la interfaz de línea de comandos (CLI) para complementar la CGI. [95] [99] |
Versión antigua, ya no se mantiene: 4.4 | 11 de julio de 2005 [100] | 7 de agosto de 2008 [93] | Se corrigió un error de corrupción de memoria que requería romper la compatibilidad binaria con extensiones compiladas con la versión PHP 4.3.x. [101] |
Versión antigua, ya no se mantiene: 5.0 | 13 de julio de 2004 [102] | 5 de septiembre de 2005 [93] | Zend Engine II con un nuevo modelo de objetos. [103] |
Versión antigua, ya no se mantiene: 5.1 | 24 de noviembre de 2005 [104] | 24 de agosto de 2006 [93] | Mejoras de rendimiento con la introducción de variables del compilador en el motor PHP rediseñado. [103] Se agregaron objetos de datos PHP (PDO) como una interfaz consistente para acceder a bases de datos. [105] |
Versión antigua, ya no se mantiene: 5.2 | 2 de noviembre de 2006 [106] | 6 de enero de 2011 [93] | Se habilitó la extensión de filtro de forma predeterminada. Compatibilidad nativa con JSON . [103] |
Versión antigua, ya no se mantiene: 5.3 | 30 de junio de 2009 [107] | 14 de agosto de 2014 [93] | Soporte de espacios de nombres ; enlaces estáticos tardíos , etiqueta de salto ( goto limitado ), funciones anónimas , cierres , archivos PHP (phar), recolección de basura para referencias circulares, soporte mejorado para Windows , sqlite3, mysqlnd como reemplazo de libmysql como la biblioteca subyacente para las extensiones que funcionan con MySQL , fileinfo como reemplazo de mime_magic para un mejor soporte MIME , la extensión de internacionalización y la desaprobación de la extensión ereg. |
Versión antigua, ya no se mantiene: 5.4 | 1 de marzo de 2012 [108] | 3 de septiembre de 2015 [93] | Compatibilidad con características , compatibilidad con sintaxis de matriz corta. Elementos eliminados: register_globals , safe_mode , allow_call_time_pass_reference , , y . Servidor web integrado. [109] Varias mejoras en las características existentes, rendimiento y requisitos de memoria reducidos.session_register() session_unregister() session_is_registered() |
Versión antigua, ya no se mantiene: 5.5 | 20 de junio de 2013 [110] | 10 de julio de 2016 [111] | Soporte para generadores , finally bloques para manejo de excepciones, OpCache (basado en Zend Optimizer+) incluido en la distribución oficial. [112] |
Versión antigua, ya no se mantiene: 5.6 | 28 de agosto de 2014 [113] | 31 de diciembre de 2018 [111] | Expresiones escalares constantes, funciones variádicas , desempaquetado de argumentos, nuevo operador de exponenciación, extensiones de la use declaración para funciones y constantes, nuevo phpdbg depurador como módulo SAPI y otras mejoras menores. [114] |
6.x | No publicado | — | Versión abandonada de PHP que planeaba incluir soporte nativo para Unicode. [115] [116] |
Versión antigua, ya no se mantiene: 7.0 | 3 de diciembre de 2015 [117] | 10 de enero de 2019 [58] | Zend Engine 3 (mejoras de rendimiento [56] y compatibilidad con enteros de 64 bits en Windows [118] ), sintaxis de variable uniforme, [60] proceso de compilación basado en AST , [119] añadido , [120] consistencia de desplazamiento bit a bit en todas las plataformas, [121] operador ( null coalesce ), [122] sintaxis de escape de punto de código Unicode , [123] declaraciones de tipo de retorno, [71] declaraciones de tipo escalar (entero, float, string y booleano), [72] operador de comparación de tres vías "spaceship" , [124] delegación de generador , [125] clases anónimas , [126] API CSPRNG más simple y más consistentemente disponible , [127] reemplazo de muchos "errores" internos de PHP restantes con las excepciones más modernas , [59] y sintaxis abreviada para importar múltiples elementos desde un espacio de nombres. [128]Closure::call() ?? <=> |
Versión antigua, ya no se mantiene: 7.1 | 1 de diciembre de 2016 | 1 de diciembre de 2019 [111] | iterable tipo, [129] tipos que aceptan valores nulos, [130] void tipo de retorno , [131] modificadores de visibilidad de constantes de clase , [132] sintaxis de lista corta, [133] multi-catch [134] |
Versión antigua, ya no se mantiene: 7.2 | 30 de noviembre de 2017 | 30 de noviembre de 2020 [111] | Declaración de parámetros de objeto y tipo de retorno, [135] extensión de libsodium, [136] anulación de métodos abstractos, [137] ampliación de tipos de parámetros [138] |
Versión antigua, ya no se mantiene: 7.3 | 6 de diciembre de 2018 [139] | 6 de diciembre de 2021 | Sintaxis flexible de Heredoc y Nowdoc, [140] compatibilidad con asignación de referencias y deconstrucción de matrices con , [141] compatibilidad con PCRE2, [142] función [143]list() hrtime |
Versión antigua, ya no se mantiene: 7.4 | 28 de noviembre de 2019 [144] | 28 de noviembre de 2022 | Propiedades tipificadas 2.0, [145] precarga, [146] operador de asignación de coalescencia nula, [147] mejora openssl_random_pseudo_bytes , [148] referencias débiles, [86] interfaz de función externa (FFI), [149] extensión hash siempre disponible, [150] registro de hash de contraseña, [151] división de cadenas multibyte, [152] reflexión para referencias, [153] desagregar ext/wddx, [154] nuevo mecanismo de serialización de objetos personalizados [155] |
Versión antigua, ya no se mantiene: 8.0 | 26 de noviembre de 2020 [156] | 26 de noviembre de 2023 | Compilación Just-In-Time (JIT) , [75] matrices que comienzan con un índice negativo, [157] semántica de lenguaje más estricta/sensata (validación para métodos de rasgos abstractos), [158] comparaciones de cadenas a números más sensatas, [159] cadenas numéricas más sensatas, [160] TypeError sobre operadores aritméticos/bit a bit no válidos, [161] reclasificación de varios errores del motor, [162] errores de tipo consistentes para funciones internas, [163] error fatal para firmas de método incompatibles [164] ), conversión de flotante a cadena independiente de la configuración regional, [165] ajustes de sintaxis de variables, [166] atributos, [167] [168] [169] [170] argumentos nombrados, [171 ] expresión de coincidencia, [172] promoción de propiedad del constructor, [173] tipos de unión, [174] mixed tipo, [175] tipo de retorno estático, [176] operador nullsafe, [84] capturas sin captura, [177] throw expresión, [83] la extensión JSON siempre está disponible. [178] |
Versión antigua, pero aún mantenida: 8.1 | 25 de noviembre de 2021 [179] | 31 de diciembre de 2025 | Notación literal octal explícita de enteros, [180] enumeraciones, [181] propiedades de solo lectura, [182] sintaxis invocable de primera clase, [183] new en inicializadores, [184] tipos de intersección pura, [185] never tipo de retorno, [186] final restricciones de clase, [187] fibras [188] |
Versión antigua, pero aún mantenida:8.2 | 8 de diciembre de 2022 [189] | 31 de diciembre de 2026 | Clases de solo lectura, [190] null , false , y true como tipos independientes, [191] [192] conversión de mayúsculas y minúsculas independiente de la configuración regional, [193] tipos de forma normal disyuntiva, [194] constantes en rasgos [195] |
Versión estable actual: 8.3 | 23 de noviembre de 2023 [196] | 31 de diciembre de 2027 | Constantes de clase tipificadas, [197] obtención de constantes de clase dinámicas, [198] atributos, [199] clonación profunda de propiedades de solo lectura, [200] nueva función, [201] adiciones de aleatorizadores, [202] el linter de línea de comandos admite varios archivos#[\Override] json_validate |
Lanzamiento futuro: 8.4 | 21 de noviembre de 2024 [203] | 31 de diciembre de 2028 | |
Leyenda: Versión antigua, sin mantenimiento Versión antigua, aún mantenida Última versión Última versión preliminar Lanzamiento futuro |
A partir del 28 de junio de 2011, el equipo de desarrollo de PHP implementó un cronograma para el lanzamiento de nuevas versiones de PHP. [58] Bajo este sistema, se debe realizar al menos un lanzamiento cada mes. Una vez al año, se debe realizar un lanzamiento menor que puede incluir nuevas características. Cada lanzamiento menor debe tener soporte al menos durante dos años con correcciones de seguridad y errores, seguido de al menos un año de solo correcciones de seguridad, para un total de un proceso de lanzamiento de tres años para cada lanzamiento menor. No se deben introducir nuevas características, a menos que sean pequeñas y autónomas, en un lanzamiento menor durante el proceso de lanzamiento de tres años.
La mascota del proyecto PHP es el elePHPant , un elefante azul con el logo de PHP en su costado, diseñado por Vincent Pontier [204] en 1998. [205] "Las letras (PHP) formaban la forma de un elefante si se las miraba de lado". [206] El elePHPant a veces tiene un color diferente cuando tiene forma de juguete de peluche . [207]
A lo largo de los años se han realizado muchas variaciones de esta mascota. Solo los elePHPants basados en el diseño original de Vincent Pontier son considerados oficiales por la comunidad. [208] Estos son coleccionables y algunos de ellos son extremadamente raros. [209]
El siguiente programa "¡Hola, mundo!" está escrito en código PHP incrustado en un documento HTML :
<!DOCTYPE html> < html > < head > < title > Programa PHP "¡Hola, mundo!" </ title > </ head > < body > < p > <? = '¡Hola, mundo!' ?> </ p > </ body > </ html >
Sin embargo, como no existe ningún requisito para que el código PHP esté integrado en HTML, la versión más simple de ¡Hola, mundo! se puede escribir así, ?>
omitiendo la etiqueta de cierre, como se prefiere en archivos que contienen código PHP puro. [210]
<?php echo '¡Hola, mundo!' ;
El intérprete PHP sólo ejecuta código PHP dentro de sus delimitadores . PHP no procesa nada que esté fuera de sus delimitadores, aunque el texto que no es PHP sigue estando sujeto a las estructuras de control descritas en el código PHP. Los delimitadores más comunes son <?php
para abrir y ?>
cerrar secciones PHP. <?
También existe la forma abreviada. Este delimitador corto hace que los archivos de script sean menos portables, ya que su compatibilidad se puede desactivar en la configuración local de PHP y, por lo tanto, se desaconseja. [211] [212] Por el contrario, no hay ninguna recomendación contra la etiqueta corta echo <?=
. [213] Antes de PHP 5.4.0, esta sintaxis corta para echo
sólo funciona con la short_open_tag
opción de configuración habilitada, mientras que para PHP 5.4.0 y posteriores siempre está disponible. [214] [215] [211] El propósito de todos estos delimitadores es separar el código PHP del contenido que no es PHP, como el código JavaScript o el marcado HTML. [216] Por lo tanto, el programa "Hola, mundo" más corto escrito en PHP es:
<? = '¡Hola, mundo!' ;
La primera forma de delimitadores, <?php
y ?>
, en XHTML y otros documentos XML , crea instrucciones de procesamiento XML correctamente formadas. [217] Esto significa que la mezcla resultante de código PHP y otros marcados en el archivo del lado del servidor es en sí misma XML bien formado.
Las variables tienen como prefijo el símbolo del dólar y no es necesario especificar un tipo de antemano. PHP 5 introdujo declaraciones de tipos que permiten a las funciones forzar a que sus parámetros sean objetos de una clase específica, matrices, interfaces o funciones de devolución de llamada . Sin embargo, antes de PHP 7, las declaraciones de tipos no se podían usar con tipos escalares como números enteros o cadenas. [72]
A continuación se muestra un ejemplo de cómo se declaran e inicializan las variables PHP.
<?php $name = 'John' ; // variable de tipo cadena que se declara e inicializa $age = 18 ; // variable de tipo entero que se declara e inicializa $height = 5.3 ; // variable de tipo doble que se declara e inicializa echo $name . ' is ' . $height . "m tall \n " ; // concatenando variables y cadenas echo " $name is $age years old." ; // interpolando variables a cadena ?>
A diferencia de los nombres de funciones y clases, los nombres de variables distinguen entre mayúsculas y minúsculas. Tanto las cadenas entre comillas dobles ("") como las cadenas heredoc proporcionan la capacidad de interpolar el valor de una variable en la cadena. [218] PHP trata las nuevas líneas como espacios en blanco a la manera de un lenguaje de formato libre , y las sentencias terminan con un punto y coma. [219] PHP tiene tres tipos de sintaxis de comentarios : /* */
marca comentarios en bloque y en línea; //
o #
se utilizan para comentarios de una sola línea. [220] La echo
sentencia es una de las varias facilidades que ofrece PHP para generar texto. [ cita requerida ]
En términos de palabras clave y sintaxis del lenguaje, PHP es similar a la sintaxis de estilo C. if
Las condiciones, for
los while
bucles y los retornos de funciones son similares en sintaxis a lenguajes como C, C++, C#, Java y Perl. [ cita requerida ]
PHP es de tipo flexible . Almacena números enteros en un rango dependiente de la plataforma, ya sea como un entero con signo de 32, 64 o 128 bits equivalente al tipo long del lenguaje C. Los números enteros sin signo se convierten en valores con signo en ciertas situaciones, lo que es un comportamiento diferente al de muchos otros lenguajes de programación. [221] Las variables enteras se pueden asignar utilizando notaciones decimales (positivas y negativas), octales , hexadecimales y binarias . [ cita requerida ]
Los números de punto flotante también se almacenan en un rango específico de la plataforma. Se pueden especificar utilizando notación de punto flotante o dos formas de notación científica . [222] PHP tiene un tipo booleano nativo que es similar a los tipos booleanos nativos en Java y C++ . Usando las reglas de conversión de tipo booleano, los valores distintos de cero se interpretan como verdaderos y cero como falso, como en Perl y C++. [222]
El tipo de datos nulo representa una variable que no tiene valor; NULL
es el único valor permitido para este tipo de datos. [222]
Las variables del tipo "recurso" representan referencias a recursos de fuentes externas. Normalmente, las crean funciones de una extensión determinada y solo pueden procesarlas funciones de la misma extensión; por ejemplo, recursos de archivos, imágenes y bases de datos. [222]
Las matrices pueden contener elementos de cualquier tipo que PHP pueda manejar, incluidos recursos, objetos e incluso otras matrices. El orden se conserva en listas de valores y en hashes con claves y valores, y ambos pueden entremezclarse. [222] PHP también admite cadenas , que se pueden usar con comillas simples, comillas dobles, sintaxis nowdoc o heredoc . [223]
La biblioteca PHP estándar (SPL) intenta resolver problemas estándar e implementa interfaces y clases de acceso a datos eficientes. [224]
PHP define una amplia gama de funciones en el lenguaje central y muchas también están disponibles en varias extensiones; estas funciones están bien documentadas en la documentación de PHP en línea. [225] Sin embargo, la biblioteca incorporada tiene una amplia variedad de convenciones de nomenclatura e inconsistencias asociadas, como se describe en el historial anterior.
El desarrollador puede definir funciones personalizadas:
function myAge ( int $birthYear ) : string { // calcula la edad restando el año de nacimiento del año actual. $yearsOld = date ( 'Y' ) - $birthYear ; // devuelve la edad en una cadena descriptiva. return $yearsOld . ( $yearsOld == 1 ? ' year' : ' years' ); }echo 'Actualmente soy ' .myAge ( 1995 ) . ' viejo. ' ;
A partir de 2024, el resultado del programa de ejemplo anterior es "Actualmente tengo 29 años".
En lugar de punteros de función , las funciones en PHP pueden ser referenciadas por una cadena que contiene su nombre. De esta manera, las funciones normales de PHP pueden ser utilizadas, por ejemplo, como devoluciones de llamadas o dentro de tablas de funciones . [226] Las funciones definidas por el usuario pueden ser creadas en cualquier momento sin necesidad de prototipos . [225] [226] Las funciones pueden ser definidas dentro de bloques de código, lo que permite una decisión en tiempo de ejecución sobre si una función debe ser definida o no. Hay una función que determina si una función con un nombre dado ya ha sido definida. Las llamadas a funciones deben usar paréntesis, con la excepción de las funciones constructorasfunction_exists
de clase de cero argumentos llamadas con el operador PHP , en cuyo caso los paréntesis son opcionales. [ cita requerida ]new
Desde PHP 4.0.1 create_function()
, una envoltura delgada alrededor de eval()
, permitió que se crearan funciones PHP normales durante la ejecución del programa; quedó obsoleta en PHP 7.2 y se eliminó en PHP 8.0 [227] a favor de la sintaxis para funciones anónimas o " cierres " [228] que pueden capturar variables del ámbito circundante, que se agregó en PHP 5.3. La sintaxis de flecha abreviada se agregó en PHP 7.4: [229]
función getAdder ( $x ) { return fn ( $y ) => $x + $y ; }$adder = getAdder ( 8 ); echo $adder ( 2 ); // imprime "10"
En el ejemplo anterior, getAdder()
la función crea un cierre utilizando el argumento pasado $x
, que toma un argumento adicional $y
y devuelve el cierre creado al invocador. Una función de este tipo es un objeto de primera clase, lo que significa que se puede almacenar en una variable, pasar como parámetro a otras funciones, etc. [230]
De manera inusual para un lenguaje de tipado dinámico, PHP admite declaraciones de tipos en parámetros de funciones, que se aplican en tiempo de ejecución. Esto se ha admitido para clases e interfaces desde PHP 5.0, para matrices desde PHP 5.1, para "callables" desde PHP 5.4 y para tipos escalares (enteros, float, string y booleanos) desde PHP 7.0. [72] PHP 7.0 también tiene declaraciones de tipos para tipos de retorno de funciones, que se expresan colocando el nombre del tipo después de la lista de parámetros, precedido por dos puntos. [71] Por ejemplo, la getAdder
función del ejemplo anterior podría anotarse con tipos como en PHP 7:
función getAdder ( int $x ) : Cierre { return fn ( int $y ) : int => $x + $y ; }$adder = getAdder ( 8 ); echo $adder ( 2 ); // imprime "10" echo $adder ( null ); // lanza una excepción porque se pasó un tipo incorrecto $adder = getAdder ([]); // también lanzaría una excepción
De manera predeterminada, las declaraciones de tipos escalares siguen principios de tipado débil. Por ejemplo, si el tipo de un parámetro es int
, PHP permitiría que se pasaran a esa función no solo números enteros, sino también cadenas numéricas convertibles, números flotantes o booleanos, y los convertiría. [72] Sin embargo, PHP 7 tiene un modo de "tipado estricto" que, cuando se utiliza, no permite dichas conversiones para llamadas de función y devoluciones dentro de un archivo. [72]
La funcionalidad básica de programación orientada a objetos se agregó en PHP 3 y se mejoró en PHP 4. [12] Esto permitió que PHP obtuviera mayor abstracción, lo que facilitó las tareas creativas para los programadores que usaban el lenguaje. El manejo de objetos se reescribió por completo para PHP 5, lo que amplió el conjunto de características y mejoró el rendimiento. [231] En versiones anteriores de PHP, los objetos se manejaban como tipos de valor . [231] El inconveniente de este método era que el código tenía que hacer un uso intensivo de las variables de "referencia" de PHP si quería modificar un objeto que se le pasaba en lugar de crear una copia del mismo. En el nuevo enfoque, los objetos se referencian por identificador y no por valor. [ cita requerida ]
PHP 5 introdujo variables y métodos miembros privados y protegidos , junto con clases abstractas , clases finales , métodos abstractos y métodos finales . También introdujo una forma estándar de declarar constructores y destructores , similar a la de otros lenguajes orientados a objetos como C++ , y un modelo estándar de manejo de excepciones . Además, PHP 5 agregó interfaces y permitió la implementación de múltiples interfaces. Hay interfaces especiales que permiten que los objetos interactúen con el sistema de tiempo de ejecución. Los objetos que implementan ArrayAccess se pueden usar con sintaxis de matriz y los objetos que implementan Iterator o IteratorAggregate se pueden usar con el foreach
lenguaje construct . No hay una característica de tabla virtual en el motor, por lo que las variables estáticas se vinculan con un nombre en lugar de una referencia en tiempo de compilación. [232]
Si el desarrollador crea una copia de un objeto utilizando la palabra reservada clone
, el motor Zend comprobará si __clone()
se ha definido un método. Si no, llamará a un valor predeterminado __clone()
que copiará las propiedades del objeto. Si __clone()
se define un método, entonces será responsable de establecer las propiedades necesarias en el objeto creado. Para mayor comodidad, el motor proporcionará una función que importe las propiedades del objeto de origen, de modo que el programador pueda comenzar con una réplica por valor del objeto de origen y solo anular las propiedades que se deben cambiar. [233]
La visibilidad de las propiedades y métodos de PHP se define utilizando las palabras claves public
, private
, y protected
. El valor predeterminado es public, si solo se utiliza varvar
; es un sinónimo de public
. public
Se puede acceder a los elementos declarados en todas partes. protected
limita el acceso a las clases heredadas (y a la clase que define el elemento). private
limita la visibilidad solo a la clase que define el elemento. [234] Los objetos del mismo tipo tienen acceso a los miembros privados y protegidos de los demás, aunque no sean la misma instancia. [ cita requerida ]
El siguiente es un ejemplo básico de programación orientada a objetos en PHP 8:
<?php clase abstracta Usuario{ cadena protegida $nombre ; función pública __construct ( cadena $nombre ) { // hacer que la primera letra sea mayúscula y el resto minúscula $this -> nombre = ucfirst ( strtolower ( $nombre )); } función pública saludo () : cadena { devuelve "Hola, mi nombre es " . $this -> nombre ; } función pública abstracta job () : cadena ; }La clase Estudiante extiende Usuario{ función pública __construct ( cadena $nombre , cadena privada $curso ) { padre :: __construct ( $nombre ); } función pública job () : cadena { devuelve "Aprendo" . $this -> curso ; }}La clase Profesor extiende al Usuario{ función pública __construct ( cadena $nombre , matriz privada $cursosdeenseñanza ) { padre :: __construct ( $nombre ); } función pública job () : cadena { devuelve "Yo enseño" . implode ( ", " , $this -> cursosenseñanza ); }}$estudiantes = [ Estudiante nuevo ( "Alice" , "Ciencias de la Computación" ), Nuevo estudiante ( "Bob" , "Ciencias de la Computación" ), Nuevo estudiante ( "Charlie" , "Estudios Empresariales" ),];$profesores = [ nuevo Profesor ( "Dan" , [ "Ciencias de la Computación" , "Seguridad de la Información" ]), nueva profesora ( "Erin" , [ "Ciencias de la Computación" , "Programación de Gráficos 3D" ]), nuevo Profesor ( "Frankie" , [ "Marketing Online" , "Estudios Empresariales" , "Comercio Electrónico" ]),];foreach ([ $estudiantes , $profesores ] como $usuarios ) { echo $usuarios [ 0 ] :: clase . "s: \n " ; array_walk ( $usuarios , función ( Usuario $usuario ) { echo " { $usuario -> saludo () } , { $usuario -> trabajo () } \n " ; });}
Este programa genera el siguiente resultado:
Estudiantes:Hola, mi nombre es Alice, estudio informática.Hola, mi nombre es Bob, estudio Ciencias de la Computación.Hola, mi nombre es Charlie, estudio Estudios Empresariales.Profesores:Hola, mi nombre es Dan, enseño Ciencias de la Computación, Seguridad de la Información.Hola, mi nombre es Erin, enseño Ciencias de la Computación, Programación de Gráficos 3D.Hola, mi nombre es Frankie, doy clases de Marketing Online, Estudios Empresariales, Comercio Electrónico.
La única implementación completa de PHP es la original, conocida simplemente como PHP. Es la más utilizada y está impulsada por el motor Zend . Para distinguirlo de otras implementaciones, a veces se lo llama extraoficialmente "Zend PHP". El motor Zend compila el código fuente de PHP sobre la marcha en un formato interno que puede ejecutar, por lo que funciona como un intérprete . [235] [236] También es la "implementación de referencia" de PHP, ya que PHP no tiene una especificación formal, y por lo tanto la semántica de Zend PHP define la semántica de PHP. Debido a la semántica compleja y matizada de PHP, definida por cómo funciona Zend, es difícil que las implementaciones de la competencia ofrezcan una compatibilidad completa. [ cita requerida ]
El modelo de ejecución de una sola solicitud por script de PHP y el hecho de que Zend Engine sea un intérprete conducen a la ineficiencia; como resultado, se han desarrollado varios productos para ayudar a mejorar el rendimiento de PHP. Para acelerar el tiempo de ejecución y no tener que compilar el código fuente de PHP cada vez que se accede a la página web, los scripts de PHP también se pueden implementar en el formato interno del motor PHP mediante el uso de un caché de códigos de operación , que funciona almacenando en caché la forma compilada de un script PHP (códigos de operación) en la memoria compartida para evitar la sobrecarga de analizar y compilar el código cada vez que se ejecuta el script. Un caché de códigos de operación, Zend Opcache , está integrado en PHP desde la versión 5.5. [237] Otro ejemplo de un caché de códigos de operación ampliamente utilizado es el Alternative PHP Cache (APC), que está disponible como una extensión PECL . [238]
Si bien Zend PHP sigue siendo la implementación más popular, se han desarrollado otras implementaciones. Algunas de ellas son compiladores o admiten la compilación JIT y, por lo tanto, ofrecen ventajas de rendimiento sobre Zend PHP a costa de carecer de compatibilidad total con PHP. [ cita requerida ] Las implementaciones alternativas incluyen las siguientes:
create_function()
y . [242]eval()
PHP es un software libre publicado bajo la Licencia PHP , que estipula que: [243]
Los productos derivados de este software no pueden llamarse "PHP", ni puede aparecer "PHP" en su nombre, sin el permiso previo por escrito de [email protected]. Puede indicar que su software funciona en conjunto con PHP diciendo " Foo for PHP" en lugar de llamarlo "PHP Foo" o "phpfoo".
Esta restricción en el uso de "PHP" hace que la Licencia PHP sea incompatible con la Licencia Pública General GNU (GPL), mientras que la Licencia Zend es incompatible debido a una cláusula de publicidad similar a la de la licencia BSD original . [244]
PHP incluye varias bibliotecas gratuitas y de código abierto en su distribución fuente o las utiliza en compilaciones binarias PHP resultantes. PHP es fundamentalmente un sistema que reconoce Internet con módulos integrados para acceder a servidores de Protocolo de Transferencia de Archivos (FTP) y muchos servidores de bases de datos, incluidos PostgreSQL , MySQL , Microsoft SQL Server y SQLite (que es una base de datos integrada), servidores LDAP y otros. Numerosas funciones son familiares para los programadores de C, como las de la familia stdio , que están disponibles en compilaciones PHP estándar. [245]
PHP permite a los desarrolladores escribir extensiones en C para añadir funcionalidad al lenguaje PHP. Las extensiones PHP pueden compilarse estáticamente en PHP o cargarse dinámicamente en tiempo de ejecución. Se han escrito numerosas extensiones para añadir compatibilidad con la API de Windows , gestión de procesos en sistemas operativos tipo Unix , cadenas multibyte ( Unicode ), cURL y varios formatos de compresión populares . Otras características de PHP disponibles a través de extensiones incluyen la integración con Internet Relay Chat (IRC), la generación dinámica de imágenes y contenido de Adobe Flash , PHP Data Objects (PDO) como una capa de abstracción utilizada para acceder a bases de datos, [246] [247] [248 ] [ 249] [250] [251] [252] e incluso síntesis de voz . Algunas de las funciones principales del lenguaje, como las que tratan con cadenas y matrices, también se implementan como extensiones. [253] El proyecto PHP Extension Community Library (PECL) es un repositorio de extensiones para el lenguaje PHP. [254]
Otros proyectos, como Zephir , ofrecen la posibilidad de crear extensiones PHP en un lenguaje de alto nivel y compilarlas en extensiones PHP nativas. Este enfoque, en lugar de escribir extensiones PHP directamente en C, simplifica el desarrollo de extensiones y reduce el tiempo necesario para la programación y las pruebas. [255]
En diciembre de 2018, el Grupo PHP estaba formado por diez personas: Thies C. Arntzen, Stig Bakken, Shane Caraveo, Andi Gutmans , Rasmus Lerdorf , Sam Ruby , Sascha Schumann, Zeev Suraski , Jim Winstead y Andrei Zmievski . [256]
Zend Technologies ofrece un examen de certificación PHP basado en PHP 7 [257] (y anteriormente basado en PHP 5.5) para que los programadores se conviertan en desarrolladores PHP certificados.
Formación | 22 de noviembre de 2021 ( 22/11/2021 ) |
---|---|
Fundador | Automattic , Laravel , Acquia, Zend , Private Packagist, Symfony , Craft CMS, Tideways, PrestaShop , JetBrains [258] |
Sitio web | https://lafundacionphp |
El 26 de noviembre de 2021, el blog JetBrains anunció la creación de The PHP Foundation, que patrocinará el diseño y desarrollo de PHP. [259]
Año | Se compromete | Reseñas | RFC (Requerimientos de comentarios) |
---|---|---|---|
2022 [260] | 683 | 283 | 8 |
2023 [261] | 784 | 702 | 17 |
La fundación contrata a "desarrolladores básicos" para trabajar en el repositorio básico del lenguaje PHP. Roman Pronskiy, miembro de la junta directiva de la fundación, dijo que su objetivo es pagar "salarios de mercado" a los desarrolladores. [262]
La respuesta a la fundación ha sido mayoritariamente positiva, y se la ha elogiado por brindar un mejor soporte al lenguaje y ayudar a detener la disminución de la popularidad del lenguaje. [263] [264] Sin embargo, también ha sido criticada por agregar cambios importantes a versiones menores de PHP, como en PHP 8.2, donde inicializar miembros de una clase fuera del alcance de la clase original causaría errores de depreciación, [265] estos cambios afectaron a varios proyectos de código abierto, incluido WordPress . [266]
El Fondo Tecnológico Soberano de Alemania proporcionó más de 200.000 euros para apoyar a la Fundación PHP. [267]
Existen dos formas principales de agregar soporte para PHP a un servidor web: como un módulo de servidor web nativo o como un ejecutable CGI. PHP tiene una interfaz de módulo directa llamada interfaz de programación de aplicaciones de servidor (SAPI), que es compatible con muchos servidores web, incluidos Apache HTTP Server , Microsoft IIS y iPlanet Web Server . Algunos otros servidores web, como OmniHTTPd, admiten la Interfaz de programación de aplicaciones de servidor de Internet (ISAPI), que es la interfaz de módulo de servidor web de Microsoft . Si PHP no tiene soporte de módulo para un servidor web, siempre se puede usar como una Interfaz de puerta de enlace común (CGI) o un procesador FastCGI ; en ese caso, el servidor web está configurado para usar el ejecutable CGI de PHP para procesar todas las solicitudes a archivos PHP. [268]
PHP-FPM (FastCGI Process Manager) es una implementación alternativa de FastCGI para PHP, incluida en la distribución oficial de PHP desde la versión 5.3.3. [269] En comparación con la implementación anterior de FastCGI, contiene algunas características adicionales, en su mayoría útiles para servidores web con mucha carga. [270]
Al utilizar PHP para la ejecución de scripts desde la línea de comandos, se necesita un ejecutable de interfaz de línea de comandos (CLI) de PHP. PHP admite una interfaz de programación de aplicaciones de servidor CLI (SAPI) desde PHP 4.3.0. [271] El objetivo principal de esta SAPI es desarrollar aplicaciones de shell utilizando PHP. Existen bastantes diferencias entre la SAPI CLI y otras SAPI, aunque comparten muchos de los mismos comportamientos. [272]
PHP tiene una interfaz de módulo directo llamada SAPI para diferentes servidores web; [273] en el caso de PHP 5 y Apache 2.0 en Windows, se proporciona en forma de un archivo DLL llamado php5apache2.dll , [274] que es un módulo que, entre otras funciones, proporciona una interfaz entre PHP y el servidor web, implementado en un formato que el servidor entiende. Este formato es lo que se conoce como SAPI. [ cita requerida ]
Existen diferentes tipos de SAPI para varias extensiones de servidor web. Por ejemplo, además de las mencionadas anteriormente, otras SAPI para el lenguaje PHP incluyen la interfaz de puerta de enlace común y la interfaz de línea de comandos. [273] [275]
PHP también se puede utilizar para escribir aplicaciones de interfaz gráfica de usuario (GUI) de escritorio, mediante el uso de la extensión PHP-GTK . PHP-GTK no está incluido en la distribución oficial de PHP [268] y, como extensión, se puede utilizar únicamente con las versiones de PHP 5.1.0 y posteriores. La forma más común de instalar PHP-GTK es compilándolo a partir del código fuente [276] .
Cuando se instala y utiliza PHP en entornos de nube , se proporcionan kits de desarrollo de software (SDK) para utilizar funciones específicas de la nube. [ cita requerida ] Por ejemplo:
Se admiten numerosas opciones de configuración que afectan tanto a las funciones básicas de PHP como a las extensiones. [279] [280] El archivo de configuración php.ini
se busca en diferentes ubicaciones, según la forma en que se utiliza PHP. [281] El archivo de configuración se divide en varias secciones, [282] mientras que algunas de las opciones de configuración también se pueden establecer dentro de la configuración del servidor web. [283]
PHP es un lenguaje de programación de propósito general que es especialmente adecuado para el desarrollo web del lado del servidor , en cuyo caso PHP generalmente se ejecuta en un servidor web . Cualquier código PHP en un archivo solicitado es ejecutado por el entorno de ejecución de PHP, generalmente para crear contenido de página web dinámico o imágenes dinámicas utilizadas en sitios web o en otros lugares. [284] También se puede utilizar para scripts de línea de comandos y aplicaciones de interfaz gráfica de usuario (GUI) del lado del cliente . PHP se puede implementar en la mayoría de los servidores web, muchos sistemas operativos y plataformas , y se puede utilizar con muchos sistemas de administración de bases de datos relacionales (RDBMS). La mayoría de los proveedores de alojamiento web admiten PHP para su uso por parte de sus clientes. Está disponible de forma gratuita y PHP Group proporciona el código fuente completo para que los usuarios lo creen, personalicen y amplíen para su propio uso. [18]
Originalmente diseñado para crear páginas web dinámicas , PHP ahora se enfoca principalmente en scripts del lado del servidor , [285] y es similar a otros lenguajes de scripts del lado del servidor que proporcionan contenido dinámico desde un servidor web a un cliente , como Python , ASP.NET de Microsoft , JavaServer Pages de Sun Microsystems , [286] y . PHP también ha atraído el desarrollo de muchos marcos de software que proporcionan bloques de construcción y una estructura de diseño para promover el desarrollo rápido de aplicaciones (RAD). [ cita requerida ] Algunos de estos incluyen PRADO , CakePHP , Symfony , CodeIgniter , Laravel , Yii Framework , Phalcon y Laminas , que ofrecen características similares a otros marcos web .mod_perl
La arquitectura LAMP se ha vuelto popular en la industria web como una forma de implementar aplicaciones web. [287] PHP se usa comúnmente como la P en este paquete junto con Linux , Apache y MySQL , aunque la P también puede referirse a Python , Perl o alguna combinación de los tres. Paquetes similares, WAMP y MAMP , también están disponibles para Windows y macOS , y la primera letra representa el sistema operativo respectivo. Aunque tanto PHP como Apache se proporcionan como parte de la instalación base de macOS, los usuarios de estos paquetes buscan un mecanismo de instalación más simple que se pueda mantener actualizado más fácilmente. [ cita requerida ]
Para escenarios de uso específicos y más avanzados, PHP ofrece una forma bien definida y documentada de escribir extensiones personalizadas en C o C++ . [288] [289] [290] [291] [292] [293] [294] [ se necesita una fuente no primaria ] Además de extender el lenguaje en sí en forma de bibliotecas adicionales , las extensiones brindan una forma de mejorar la velocidad de ejecución donde es crítica y hay espacio para mejoras mediante el uso de un lenguaje compilado real . [295] [296] PHP también ofrece formas bien definidas de incrustarse en otros proyectos de software. De esa manera, PHP se puede usar fácilmente como un lenguaje de script interno para otro proyecto, proporcionando también una interfaz estrecha con las estructuras de datos internas específicas del proyecto . [297]
PHP recibió críticas mixtas debido a la falta de soporte para subprocesos múltiples en el nivel del lenguaje central, [298] aunque el uso de subprocesos es posible gracias a la extensión PECL "pthreads" . [299] [300]
Se han producido una interfaz de línea de comandos, php-cli, y dos motores de scripts ActiveX Windows Script Host para PHP. [ cita requerida ]
PHP se utiliza para sistemas de gestión de contenido web , incluidos MediaWiki , [301] WordPress , [302] Joomla , [303] Drupal , [304] Moodle , [305] eZ Publish , eZ Platform y SilverStripe . [306]
En enero de 2013 [actualizar], PHP se utilizaba en más de 240 millones de sitios web (el 39 % de los muestreados) y estaba instalado en 2,1 millones de servidores web . [307]
Al 23 de septiembre de 2024 [actualizar](diez meses después del lanzamiento de PHP 8.3), PHP se utiliza como lenguaje de programación del lado del servidor en el 75,8% de los sitios web donde se pudo determinar el lenguaje; PHP 7 es la versión más utilizada del lenguaje con el 51% de los sitios web que usan PHP en esa versión, mientras que el 35,3% usa PHP 8, el 13,5% usa PHP 5 y el 0,1% usa PHP 4. [20]
En 2019, el 11% de todas las vulnerabilidades enumeradas por la Base de Datos Nacional de Vulnerabilidades estaban vinculadas a PHP; [312] históricamente, alrededor del 30% de todas las vulnerabilidades enumeradas desde 1996 en esta base de datos están vinculadas a PHP. Las fallas técnicas de seguridad del lenguaje en sí o de sus bibliotecas principales no son frecuentes (22 en 2009, alrededor del 1% del total, aunque PHP se aplica a aproximadamente el 20% de los programas enumerados). [313] Reconociendo que los programadores cometen errores, algunos lenguajes incluyen la verificación de defectos para detectar automáticamente la falta de validación de entrada que induce muchos problemas. Esta característica se ha propuesto para PHP en el pasado, pero se ha rechazado o se ha abandonado la propuesta. [314] [315] [316]
Proyectos de terceros como Suhosin [317] y Snuffleupagus [318] tienen como objetivo eliminar o cambiar partes peligrosas del lenguaje.
Históricamente, las versiones antiguas de PHP tenían algunos parámetros de configuración y valores predeterminados para dichas configuraciones de tiempo de ejecución que hacían que algunas aplicaciones PHP fueran propensas a problemas de seguridad. Entre ellas, las directivas de configuración magic_quotes_gpc
y register_globals
[319] eran las más conocidas; la última convertía cualquier parámetro de URL en variable de PHP, abriendo un camino a graves vulnerabilidades de seguridad al permitir que un atacante estableciera el valor de cualquier variable global no inicializada e interfiriera en la ejecución de un script de PHP. El soporte para las configuraciones de " comillas mágicas " y "registro de variables globales" ha quedado obsoleto desde PHP 5.3.0 y se eliminó de PHP 5.4.0. [320]
Otro ejemplo de la vulnerabilidad potencial de configuración en tiempo de ejecución proviene de no deshabilitar la ejecución de PHP (por ejemplo, utilizando la engine
directiva de configuración) [321] para el directorio donde se almacenan los archivos cargados; habilitarla puede resultar en la ejecución de código malicioso incrustado dentro de los archivos cargados. [322] [323] [324] La mejor práctica es ubicar el directorio de imágenes fuera de la raíz del documento disponible para el servidor web y servirlo a través de un script intermediario o deshabilitar la ejecución de PHP para el directorio que almacena los archivos cargados. [ cita requerida ]
Además, habilitar la carga dinámica de extensiones PHP (a través de enable_dl
una directiva de configuración) [325] en un entorno de alojamiento web compartido puede generar problemas de seguridad. [326] [327]
Las conversiones de tipos implícitas que dan como resultado que valores diferentes se traten como iguales, a veces en contra de la intención del programador, pueden generar problemas de seguridad. Por ejemplo, el resultado de la comparación '0e1234' == '0'
es true
, porque las cadenas que se pueden analizar como números se convierten en números; en este caso, el primer valor comparado se trata como notación científica con el valor (0 × 10 1234 ), que es cero. Errores como este dieron lugar a vulnerabilidades de autenticación en Simple Machines Forum , [328] Typo3 [329] y phpBB [330] cuando se compararon los hashes de contraseña MD5 . La forma recomendada es utilizar (para la seguridad frente a ataques de tiempo ), o el operador de identidad ( ), ya que da como resultado . [ cita requerida ]hash_equals()
strcmp
===
'0e1234' === '0'
false
En un análisis de 2013 de más de 170.000 desfiguraciones de sitios web , publicado por Zone-H , la técnica utilizada con mayor frecuencia (53%) fue la explotación de la vulnerabilidad de inclusión de archivos , relacionada principalmente con el uso inseguro de las construcciones del lenguaje PHP include
, require
y allow_url_fopen
. [331] [332]
PHP incluye rand()
[333] y funciones que utilizan un generador de números pseudoaleatorios y no son criptográficamente seguras. A partir de la versión 8.1, se incluye la función que utiliza una fuente de aleatoriedad criptográficamente segura proporcionada por el sistema. [335]mt_rand()[334]
random_int()
Hay dos ataques que se pueden realizar sobre fuentes de entropía PHP: "ataque de semilla" y "ataque de recuperación de estado". [ cita requerida ] A partir de 2012, una GPU de $250 puede realizar hasta 230 cálculos MD5 por segundo, mientras que una GPU de $750 puede realizar cuatro veces más cálculos al mismo tiempo. [336] En combinación con un " ataque de cumpleaños ", esto puede conducir a graves vulnerabilidades de seguridad. [ cita requerida ]
El equipo de desarrollo de PHP proporciona correcciones de errores oficiales durante 2 años después del lanzamiento de cada versión menor, seguido de otros 2 años en los que solo se publican correcciones de seguridad. [337] Después de esto, la versión se considera al final de su vida útil y ya no recibe soporte oficial.
Los proveedores comerciales, como Zend y otros, ofrecen soporte a largo plazo más allá de esto [338] [339]
Hacer que NaN e Infinity siempre se conviertan en cero cuando se convierten a números enteros significa una mayor consistencia entre plataformas y también es menos sorprendente que lo que se produce actualmente.
Hay libros en las estanterías que dicen cubrir PHP 6 desde al menos 2008. Pero, en marzo de 2010, la versión de PHP 6 aún no ha salido; de hecho, ni siquiera está cerca de salir. Los acontecimientos recientes sugieren que PHP 6 no se lanzará antes de 2011, si es que llega a lanzarse.
Las versiones recientes de PHP han formado parte de la serie de lanzamientos 5.x, pero no habrá PHP 6. "Vamos a omitir [la versión] 6, porque hace años teníamos planes para una 6, pero esos planes eran muy diferentes de lo que estamos haciendo ahora", dijo Gutmans. Pasar directamente a la versión 7 evita confusiones.
PHP es el lenguaje de programación en el que está escrito MediaWiki [...]
WordPress fue [...] creado con PHP
SilverStripe requiere PHP 5.3.2+
{{cite web}}
: CS1 maint: nombres numéricos: lista de autores ( enlace ){{cite web}}
: CS1 maint: URL no apta ( enlace )¿Cuál es el mínimo absoluto que debo saber sobre PHP?