PHP
PHP es un lenguaje de programación interpretado[2] del lado del servidor y de uso general que se adapta especialmente al desarrollo web.[3] Fue creado inicialmente por el programador danés-canadiense Rasmus Lerdorf en 1994.[4] En la actualidad, la implementación de referencia de PHP es producida por The PHP Group.[5] PHP originalmente significaba Personal Home Page (Página personal), pero ahora significa el inicialismo[n 1] recursivo PHP: Hypertext Preprocessor.[7] El código PHP suele ser procesado en un servidor web por un intérprete PHP desarrollado como un módulo, un daemon o como un ejecutable de interfaz de entrada común (CGI). En un servidor web, el resultado del código PHP interpretado y ejecutado —que puede ser cualquier tipo de datos, como el HTML generado o datos de imágenes binarias— formaría la totalidad o parte de una respuesta HTTP. Existen diversos sistemas de plantillas, sistemas de gestión de contenidos y frameworks que pueden emplearse para organizar o facilitar la generación de esa respuesta. Por otra parte, PHP puede utilizarse para muchas tareas de programación fuera del contexto de la web, como aplicaciones gráficas autónomas[8] y el control de drones.[9] También se puede interpretar y ejecutar un código PHP cualquiera a través de una interfaz de línea de comandos (CLI). El intérprete estándar de PHP, impulsado por Motor Zend, es un software libre publicado bajo Licencia PHP. PHP ha sido ampliamente portado y puede ser desplegado en la mayoría de los servidores web en casi todos los sistemas operativos y plataformas, de forma gratuita. El lenguaje PHP evolucionó sin una especificación formal escrita o un estándar hasta 2014, con la implementación original actuando como el estándar de facto que otras implementaciones intentaban seguir. Desde 2014, se ha trabajado para crear una especificación formal de PHP.[10] Visión generalPHP puede ser desplegado en la mayoría de los servidores web y en todos los sistemas operativos y plataformas sin costo alguno. El lenguaje PHP se encuentra instalado en más de 20 millones de sitios web y en un millón de servidores. Migrar los servicios basados en PHP hacia las nuevas tecnologías que aparecen, supone un costo a justificar monetariamente (sobre todo, en términos de hardware y rendimiento), por ello, hablar si el número de sitios basados en PHP se ha visto reducido progresivamente en los últimos años, con la aparición de nuevas tecnologías como Node.js, Golang, ASP.NET, etc. Poderse hacer una visión general de como PHP está evolucionando a día de hoy, es hablar sobre las nuevas librerías disponibles, el uso de matrices,[11] manejo de números enteros, tratamiento de la criptografía cuando se usa una Base64,[12][13][14] Web scraping, indexación de webs, precocinado de datos, Macrodatos, set de datos, supervisión de datos, set de proposiciones dimensionales. Como vemos, una visión general de este lenguaje, es mucho más compleja que afirmar que es un lenguaje para desarrollo web. Dicha realidad, subyace en la aparición de dominios xyz, cuya finalidad y especialidad es el cacheado de los servicios PHP para servir contenido con una orientación al desempeño vinculada a servicios para consumo de otros servicios que necesitan datos, tales como I.A.s. donde PHP está viendo una acogida con un sentimiento de confianza en los resultados a obtener (sin pretender servir de lenguaje en sí mismo orientado a la I.A., dado que no fue su conceptualización origen). Aunque el marketing que está recibiendo este tipo de dominios, está relacionado con las nuevas generaciones de personas educadas en las nuevas tecnologías[15] Como parte de la visión general, habría que incluir un último aspecto, y es la capacidad de generar capas de seguridad autodependientes, en un paradigma solo emergente gracias a las librerías de las que dispone PHP (En proceso de desarrollo). El sitio web de Wikipedia está desarrollado en PHP.[16] Es también el módulo Apache más popular entre las computadoras que utilizan Apache como servidor web. El gran parecido que posee PHP con los lenguajes más comunes de programación estructurada, como C y Perl, permiten a la mayoría de los programadores crear aplicaciones complejas con una curva de aprendizaje muy corta. También les permite involucrarse con aplicaciones de contenido dinámico sin tener que aprender todo un nuevo grupo de funciones. Aunque todo en su diseño está orientado a facilitar la creación de sitios webs, es posible crear aplicaciones con una interfaz gráfica de usuario, utilizando alguna extensión como puede ser PHP-Qt, PHP-GTK,[17] WxPHP, WinBinder, Roadsend PHP, Phalanger, Phc o HiP Hop VM. También puede ser usado desde la línea de comandos, de la misma manera como Perl o Python pueden hacerlo; a esta versión de PHP se la llama PHP-CLI (Command Line Interface).[18] Cuando el cliente hace una petición al servidor para que le envíe una página web, el servidor ejecuta el intérprete de PHP. Este procesa el script solicitado que generará el contenido de manera dinámica (por ejemplo obteniendo información de una base de datos). El resultado es enviado por el intérprete al servidor, quien a su vez se lo envía al cliente. Mediante extensiones es también posible la generación de archivos PDF,[19] Flash, así como imágenes en diferentes formatos. Permite la conexión a diferentes tipos de servidores de bases de datos tanto SQL como NoSQL tales como MySQL, PostgreSQL, Oracle, ODBC, DB2, Microsoft SQL Server, Firebird, SQLite o MongoDB.[20] PHP también tiene la capacidad de ser ejecutado en la mayoría de los sistemas operativos, tales como Unix (y de ese tipo, como Linux o Mac OS X) y Microsoft Windows, y puede interactuar con los servidores de web más populares ya que existe en versión CGI, módulo para Apache e ISAPI. PHP es una alternativa a las tecnologías de Microsoft ASP y ASP.NET (que utiliza C# y Visual Basic .NET como lenguajes), a ColdFusion de la empresa Adobe, a JSP/Java, CGI/Perl y a Node.js/Javascript. Aunque su creación y desarrollo se da en el ámbito de los sistemas libres, bajo la licencia GNU, existe además un entorno de desarrollo integrado comercial llamado Zend Studio. CodeGear (la división de lenguajes de programación de Borland) ha sacado al mercado un entorno de desarrollo integrado para PHP, denominado 'Delphi for PHP. También existen al menos un par de módulos para Eclipse, uno de los entornos más populares.[21] HistoriaFue originalmente diseñado en Perl, con base en la escritura de un grupo de CGI binarios escritos en el lenguaje C por el programador danés-canadiense Rasmus Lerdorf en el año 1994 para mostrar su currículum vítae y guardar ciertos datos, como la cantidad de tráfico que su página web recibía. El 8 de junio de 1995 fue publicado «Personal Home Page Tools» después de que Lerdorf lo combinara con su propio Form Interpreter para crear PHP/FI. Dos programadores israelíes del Technion, Zeev Suraski y Andi Gutmans, reescribieron el analizador sintáctico (parser, en inglés) en 1997 y crearon la base del PHP3, y cambiaron el nombre del lenguaje por PHP: Hypertext Preprocessor. Inmediatamente comenzaron experimentaciones públicas de PHP3, y se publicó oficialmente en junio de 1998. Para 1999, Suraski y Gutmans reescribieron el código de PHP, y produjeron lo que hoy se conoce como motor Zend. También fundaron Zend Technologies en Ramat Gan, Israel. En mayo del 2000, PHP 4 se lanzó bajo el poder del motor Zend 1.0. El 13 de julio de 2007 se anunció la suspensión del soporte y desarrollo de la versión 4 de PHP,[22] y, a pesar de lo anunciado, se ha liberado una nueva versión con mejoras de seguridad, la 4.4.8, publicada el 13 de enero del 2008, y posteriormente la versión 4.4.9, publicada el 7 de agosto del 2008.[23] Según esta noticia,[24] se le dio soporte a fallos críticos hasta el 9 de agosto del 2008. El 13 de julio de 2004, se lanzó PHP 5, utilizando el motor Zend Engine 2.0 (o Zend Engine 2). Incluye todas las ventajas que provee el nuevo Zend Engine 2, como:
En abril de 2020, más de la mitad de los sitios en la web que usaban PHP seguían en la versión descontinuada[25] 5.6 o anterior.[26] y con la versión 7.0 y 7.1 más del 68%, que no están oficialmente soportadas por The PHP Development Team,[27] mientras que el soporte de seguridad es proporcionado por terceros, como Debian (hasta junio de 2020 para PHP 5).[28] Adicionalmente, la versión 7.2, la versión con soporte más popular, dejó de recibir actualizaciones de seguridad el 30 de noviembre de 2020.[25] El 26 de noviembre de 2020 se presenta la actualización del lenguaje PHP a su versión 8.0 que más recursos y optimizaciones incluyendo argumentos nombrados, tipos de uniones, atributos, promoción de propiedades constructivas, expresiones match, operador nullsafe, JIT (traducción dinámica) y también mejoras en el sistema de tipos, manejo de errores y consistencia en general.[29], esta la cual llegara a su fin en noviembre del 2023, también considerando que a partir de lanzamiento de php 8.2 el 8 de noviembre del año 2022, Wordpress que ha logrado ser compatible al día siguiente el 9 de diciembre del 2022.[30] seguido del Framework CodeIgniter que actualmente ha expulsado a php7.4 de sus compatibilidades en sus nuevas actualizaciones.[31] En enero de 2023, según W3Techs «PHP es utilizado por el 77.8 % de todos los sitios web que se ejecutan en el lado del servidor»[1]. También informa de que sólo el 8 % de los usuarios de PHP utilizan las versiones 8.x actualmente soportadas.[32] La última versión publicada de PHP es PHP 8.3. Historial de lanzamiento
SintaxisLa sintaxis de PHP, se fundamenta en los principios de programación de C. El intérprete de PHP solo ejecuta el código que se encuentra entre sus delimitadores. Los delimitadores más comunes son Las variables se prefijan con el símbolo del dólar ( Los comentarios se pueden escribir bien con dos barras (//) al principio de la línea, o con una almohadilla (#). También permite comentarios multi-línea encapsulados en En cuanto a las palabras clave, PHP comparte con la mayoría de otros lenguajes con sintaxis C las condiciones con Ejemplos de código en PHP BásicoPrograma Hola mundo con PHP inmerso dentro de código HTML: <!DOCTYPE html>
<html lang="es" dir="ltr">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Ejemplo básico PHP</title>
</head>
<body>
<?php
echo 'Hola mundo';
?>
</body>
</html>
Programa Hola mundo con PHP en forma de app monolítica: <?php
// Area de cabeceras, constantes e includes (inicialización de la aplicación)
// Encabezado solo para demostración, no es necesario
header('Content-Type: text/html; charset=UTF-8');
$respuesta = '';
// Lógica de la aplicación, como obtener usuario de la sesión, contenido, etc.
// Este código podría venir de una plantilla externa para una fácil reutilización
$respuesta .= '<!DOCTYPE html>';
$respuesta .= '<html lang="es">';
$respuesta .= '';
$respuesta .= '<head>';
$respuesta .= ' <meta charset="UTF-8" />';
$respuesta .= ' <meta name="viewport" content="width=device-width, initial-scale=1.0" />';
$respuesta .= ' <title>Ejemplo básico de PHP</title>';
$respuesta .= '</head>';
$respuesta .= '';
$respuesta .= '<body>';
$respuesta .= ' <h1>Hola mundo!</h1>';
$respuesta .= '</body>';
$respuesta .= '';
$respuesta .= '</html>';
// Envía respuesta
echo $respuesta;
// Notar que no se cierra la "etiqueta" <?php. PHP-FIG recomienda esta práctica en
// archivos que contienen solo código PHP para así no enviar contenido HTML de
// manera accidental.
Programa Hola mundo con PHP respondiendo en formato JSON: <?php
// Archivo respuesta_json.php
// Le comunica al navegador que la respuesta será JSON
header('Content-Type: application/json; charset=UTF-8');
$respuesta = [
'mensaje' => 'Hola mundo!'
];
echo json_encode($respuesta);
// No se cierra la "etiqueta" <?php ya que el archivo contiene solo código PHP
El lado del cliente que realizará petición al archivo PHP: <!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Ejemplo de respuesta en formato JSON desde PHP</title>
</head>
<body>
<div>
<h2>Respuesta en texto plano</h2>
<pre><code id="respuesta-plana"></code></pre>
</div>
<div>
<h2>Respuesta procesada (campo «mensaje» de la respuesta JSON)</h2>
<pre><code id="respuesta-procesada"></code></pre>
</div>
<script>
document.addEventListener('DOMContentLoaded', () => {
const contenedorRespuestaPlana = document.querySelector('#respuesta-plana');
const contenedorRespuestaProcesada = document.querySelector('#respuesta-procesada');
// Realiza petición asíncrona al archivo de php
fetch('respuesta_json.php')
.then(respuesta => respuesta.json()) // Transforma la respuesta a un objeto JSON
.then(respuestaJson => {
// respuestaJson es un objeto con el formato { mensaje: "Hola mundo!" }
contenedorRespuestaPlana.innerHTML = JSON.stringify(respuestaJson);
contenedorRespuestaProcesada.innerHTML = respuestaJson.mensaje;
});
// manejar errores con .catch()
});
</script>
</body>
</html>
Bases de datos (MySQL)PHP puede combinarse con MySQL para trabajar con bases de datos, aunque también se pueden utilizar otros motores de base de datos como Microsoft SQL Server, PostgreSQL, MongoDB, entre otros. El siguiente ejemplo se muestra el inicio de sesión con usuario y contraseña utilizando MySQL y PHP con el estilo orientado a objetos: <?php
// Conexión a la base de datos local 'sitio'. Normalmente esto vendría de un
// servicio externo que se reutiliza en todo el sitio.
$conexion = new PDO('mysql:host=127.0.0.1;dbname=sitio', 'root', '', [
// Lanza excepción si ocurre un error, así el gestor de errores tomará las acciones necesarias
// como mostrar un error 500 o terminar la ejecución del sistema. Nótese que no se utiliza
// try-catch acá para delegarle la responsabilidad al gestor de errores.
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
// Desactiva emulación de sentencias preparadas (solo las nativas son seguras)
PDO::ATTR_EMULATE_PREPARES => false,
]);
// Se obtienen los datos enviados por el formulario
// Para la simplicidad de la demostración se utiliza el operador coalesce (??)
$nombre_usuario = trim($_POST['nombre_usuario'] ?? ''); // Se eliminan los espacios al inicio y al final
$contrasena = $_POST['contrasena'] ?? ''; // La contraseña se deja tal cual, sin trim()
// Solo actuar si el formulario ha sido enviado con datos
if (isset($_POST['enviar']) && !empty($nombre_usuario) && !empty($contrasena)) {
// Consulta para buscar el usuario en la base de datos
// Se utilizan sentencias preparadas para prevenir inyecciones SQL
$consulta_usuario = $conexion->prepare('SELECT * FROM usuarios WHERE nombre_usuario = ? LIMIT 1');
$consulta_usuario->execute([$nombre_usuario]);
// Verifica si se ha encontrado un usuario
if ($consulta_usuario->rowCount() > 0) {
// Obtiene los datos del usuario
$usuario_encontrado = $consulta_usuario->fetch(PDO::FETCH_ASSOC);
// Comprobar si la contraseña enviada es correcta
// Utiliza algoritmos seguros como BCrypt o Argon2i
if (password_verify($contrasena, $usuario_encontrado['contrasena'])) {
// Credenciales correctas, iniciar sesión
} else {
// Credenciales incorrectas, mostrar mensaje de error
}
} else {
// Nombre de usuario no existe, mostrar mensaje de error
// Nótese que, por seguridad, aquí y arriba se debe mostrar un error
// genérico como "Credenciales incorrectas", así de esta forma un posible
// atacante no sabrá si ha ingresado el nombre de usuario correcto
}
}
// No se cierra la "etiqueta" <?php ya que el archivo contiene solo código PHP
El siguiente ejemplo hace lo mismo que el anterior, pero con la seguridad de que sea cual sea el estado medio del servicio, si no hay forma de conectar, se destruirá la clase y se cerrará lo adjunto a sus hilos. Bórrese <?php //Archivo BD_access.class.php
class interfazSesion
{
public $conexion;
public $BD_ACCESS;
public $HOST_ACCESS;
public $USER_ACCESS;
public $PWD_ACCESS;
public $error;
public function __construct(array $args)
{
$salida='';
try {
if ((null!==$args['BD_ACCESS']) && (null!==$args['HOST_ACCESS']) && (null !== $args['USER_ACCESS']) && (null !== $args['PWD_ACCESS'])){
//Construimos la clase
$this->BD_ACCESS = $args['BD_ACCESS'];
$this->HOST_ACCESS = $args['BD_ACCESS'];
$this->USER_ACCESS = $args['BD_ACCESS'];
$this->PWD_ACCESS = $args['BD_ACCESS'];
} else {
throw new Exception('Error de construccion del interfaz de conexion a datos: No se suministran todos los argumentos',400);
}
} catch(Exception $e){
die('"{error":"'.$e->getMessage.'}"');
} finally{
// Conectar al servidor MySQL y seleccionar la base de datos con el nombre 'login'
$this->conexion = @new mysqli($this->HOST_ACCESS, $this->USER_ACCESS, $this->PWD_ACCESS, $this->BD_ACCESS);
}
try{
if (!$this->conexion){
throw new Exception('Error de conexión a la base de datos: los argumentos introducidos no son suficientes para crear una conexión',410);
}
} catch (Exception $e){
die('"{error":"'.$e->getMessage.'}"');
} finally{
$salida='{"Ok":"La conexión se ha realizado"}';
}
$this->error=$salida;
}
public function consultaSQL(string $queSQLquery): string
{
$salida='';
// Consulta para buscar los usuarios en la base de datos
$consulta_usuario = $this->conexion->query($queSQLquery);
// Verificar que se ha encontrado un usuario
if ($consulta_usuario->num_rows > 0) {
// Obtener los datos del usuario en forma de un array asociativo
$usuario_encontrado = $consulta_usuario->fetch_assoc();
// Comprobar si la contraseña utilizada es la misma que la que está en la base de datos
if ($contrasena === $usuario_encontrado['contrasena']) {
// Texto de exito
$salida = '{"Ok":"Has iniciado la sesión correctamente"}';
} else {
// Texto de error
$salida = '{"error":"La contraseña utilizada no es correcta"}';
}
} else {
// Texto de error
$salida = '{"error":"El usuario introducido no existe"}';
}
// Cerrar la conexión
$this->conexion->close();
return $salida;
}
}
?>
<?php //Archivo cabecera.h.php
// Solo mostrar errores fatales, de parseo y advertencias para el ejemplo
error_reporting(E_ERROR | E_PARSE | E_WARNING);
//Inclusion de clases para instancias de gestion
$seHaIncluido=include_once(BD_access.class.php);
if($seHaIncluido){
// Comprobar que el formulario fue enviado utilizando el boton enviar
if (isset($_POST['enviar'])) {
//Iniciando variables
$usuario='';
$contrasena='';
// Obtener los datos enviados por método POST y borrar los espacios en blanco del inicio y del final
$usuario = trim($_POST['usuario']);
$contrasena = sha1(trim($_POST['contrasena']));
//Comprobacion de que las variables no están vacías
if(!empty($usuario) && !empty($contrasena)){
$args = array('BD_ACCESS'=>'usuarios', 'HOST_ACCESS'=>'localhost','USER_ACCESS'=>'root','PWD_ACCESS'=>'sin_contrasenia'){
//Se instancian los objetos asociados a las clases correspondientes
$misAccesos = new interfazSesion($args);
$estadoConn = JSON.decode($misAccesos->error);
if(isset($estadoConn['Ok'])){
$estadoQuery=$misAccesos->consultaSQL("SELECT * FROM usuarios WHERE usuario = '$usuario' LIMIT 1");
echo '{"salida":"'.$estadoQuery.'"}';
}else if(isset($estadoConn['error'])){
echo '{"error":"'.$estadoQuery.'"}';
}
}else{
echo '{"error":"campos del formulario con datos no reconocidos"}';
}
}else{
echo '{"error":"intento de acceso no permitido"}';
}
}
?>
Como servicio RESTLos servicios REST se fundamentan en tres conceptos fundamentales:
Características de PHPCaracterísticas
Inconvenientes
DesafíosUna de las dificultades que enfrentan las empresas para actualizar a las versiones más altas actuales de los lenguajes de programación es la compatibilidad con el código existente contrastado las mejoras. Muchas veces, el código antiguo utiliza funciones o sintaxis que han sido modificadas o eliminadas en las nuevas versiones, lo que genera errores o incompatibilidades.[59] Además, las empresas deben invertir tiempo y recursos en capacitar a sus programadores para que se adapten a los cambios y puedan aprovechar las nuevas características y ventajas de los lenguajes actualizados. El desafío de cambiar las versiones de PHP también puede ser que algunas bibliotecas, complementos y extensiones utilizados en la aplicación también necesiten actualizarse. Si estos no se actualizan, pueden generar conflictos o errores en la aplicación. XAMPP, LAMP, WAMP, MAMP, UwAmpXAMPP es un servidor independiente de plataforma, software libre, que consiste principalmente en la base de datos MySQL, el servidor web Apache y los intérpretes para lenguajes de script: PHP y Perl. El nombre proviene del acrónimo de X (para cualquiera de los diferentes sistemas operativos), Apache, MySQL, PHP, Perl. El programa está liberado bajo la licencia GNU y actúa como un servidor web libre, fácil de usar y capaz de interpretar páginas dinámicas. Actualmente XAMPP está disponible para Microsoft Windows, GNU/Linux, Solaris, y MacOS X. Es un software «liviano» que se puede utilizar en cualquier PC. No necesita muchos recursos. LAMP presenta una funcionalidad parecida a XAMPP, pero enfocada en Linux, WAMP lo hace enfocado en Windows, y MAMP para MacOS X. UwAmp es muy idéntico a WAMP y se destaca en que se puede ejecutar desde una memoria USB. Principales sitios desarrollados con PHPSe utiliza PHP en millones de sitios; entre los más destacados se encuentran: Véase tambiénNotasReferencias
Enlaces externos
|
Portal di Ensiklopedia Dunia