Aprender PHP, MySQL y JavaScript
Por Robin Nixon
4.5/5
()
Información de este libro electrónico
Gracias a esta guía práctica, abordará la programación web dinámica con la última versión de las principales herramientas del momento: PHP, MySQL, CSS, HTML5 y las bibliotecas clave de jQuery. Asimismo, aprenderá a utilizar estas tecnologías en su conjunto y accederá a valiosas prácticas de programación web.
-Explorar MySQL desde la estructura de la base de datos hasta consultas complejas
-Utilizar la extensión MySQLi, la interfaz MySQL mejorada de PHP
-Crear páginas web dinámicas que se adaptan al usuario
-Gestionar las cookies y las sesiones, y conservar un alto grado de seguridad
-Mejorar el lenguaje JavaScript con las bibliotecas jQuery y jQuery Mobile
-Utilizar las llamadas con AJAX para la comunicación en segundo plano entre el navegador y el servidor
-Diseñar páginas web con las habilidades que adquirirá en CSS2 y CSS3
-Implementar las características de HTML5, incluidas la geolocalización, el audio, el vídeo y el elemento lienzo
-Reformatear sus sitios web con aplicaciones web para móviles
Al final del libro, descubrirá cómo unir todos los temas tratados para crear un sitio de redes sociales completamente funcional, adecuado para navegadores tanto de equipos de escritorio como de dispositivos móviles. Además, en la parte inferior de la primera página del libro encontrará el código de acceso que le permitirá acceder de forma gratuita a los contenidos adicionales en www.marcombo.info.
Robin Nixon es periodista de las TI y especialista en las tecnologías presentadas en este libro. Ha trabajado y ha escrito sobre ordenadores desde 1980, es autor de cientos de artículos y libros sobre informática y ha desarrollado numerosos sitios web con herramientas de código abierto.
Relacionado con Aprender PHP, MySQL y JavaScript
Libros electrónicos relacionados
JavaScript: Guía completa Calificación: 4 de 5 estrellas4/5Aprender Javascript Avanzado con 100 ejercicios prácticos Calificación: 5 de 5 estrellas5/5El gran libro de HTML5, CSS3 y Javascript Calificación: 3 de 5 estrellas3/5HTML para novatos Calificación: 5 de 5 estrellas5/5Introducción a PHP Calificación: 0 de 5 estrellas0 calificacionesCurso de Programación Web Calificación: 4 de 5 estrellas4/5Creación de un sitio web con PHP y MySQL. 5ª Edición actualizada.: BASES DE DATOS Calificación: 5 de 5 estrellas5/5Desarrollo Web en Java Calificación: 3 de 5 estrellas3/5Creación de un portal con PHP y MySQL. 4ª Edición: Gráficos y diseño web Calificación: 5 de 5 estrellas5/5La Guía Básica de Javascript Calificación: 5 de 5 estrellas5/5Bases de Datos con MySQL Calificación: 4 de 5 estrellas4/5Curso de Programación con Java - 2ª Edición Calificación: 5 de 5 estrellas5/5Programación Orientada a Objetos en JAVA Calificación: 0 de 5 estrellas0 calificacionesAprende Programación Web con PHP y MySQL Calificación: 4 de 5 estrellas4/5Curso de Programación y Análisis de Software Calificación: 4 de 5 estrellas4/5HTTP - Lo mínimo que todo desarrollador web debe saber Calificación: 5 de 5 estrellas5/5HTML5 Avanzado Calificación: 0 de 5 estrellas0 calificacionesGuía de HTML5, CSS3 y Javascript. La Web 2.0 Calificación: 4 de 5 estrellas4/5Python a fondo Calificación: 5 de 5 estrellas5/5HTML, CSS, Bootstrap, Php, Javascript y MySql: Todo lo que necesitas saber para crear un sitio dinámico Calificación: 0 de 5 estrellas0 calificacionesAprende a Programar con Java Calificación: 4 de 5 estrellas4/5Aprende a Programar en C++ Calificación: 5 de 5 estrellas5/5Aprende a Programar en Python Calificación: 5 de 5 estrellas5/5Desarrollo web con HTML 5 Calificación: 0 de 5 estrellas0 calificacionesAprende a Programar ASP .NET y C# - Segunda Edición Calificación: 0 de 5 estrellas0 calificacionesAprende a Programar Ajax y jQuery Calificación: 1 de 5 estrellas1/5Datos Informáticos Calificación: 0 de 5 estrellas0 calificacionesFundamentos de Programación y Bases de Datos: 2ª Edición Calificación: 0 de 5 estrellas0 calificacionesFundamentos de Programación y Bases de Datos Calificación: 0 de 5 estrellas0 calificacionesCurso de Programación de Apps. Android y iPhone Calificación: 5 de 5 estrellas5/5
Programación para usted
Python a fondo Calificación: 5 de 5 estrellas5/5GuíaBurros Microsoft Excel: Todo lo que necesitas saber sobre esta potente hoja de cálculo Calificación: 4 de 5 estrellas4/5Python para principiantes Calificación: 5 de 5 estrellas5/5Aprender a programar con Excel VBA con 100 ejercicios práctico Calificación: 5 de 5 estrellas5/5Aprende programación Python: python, #1 Calificación: 0 de 5 estrellas0 calificacionesPython Paso a paso: PROGRAMACIÓN INFORMÁTICA/DESARROLLO DE SOFTWARE Calificación: 4 de 5 estrellas4/5Linux Essentials: una guía para principiantes del sistema operativo Linux Calificación: 5 de 5 estrellas5/5Excel de la A a la Z: El Manual Práctico Paso a Paso de Microsoft Excel para Aprender Funciones Básicas y Avanzadas, Fórmulas y Gráficos con Ejemplos Fáciles y Claros Calificación: 0 de 5 estrellas0 calificacionesVBA Excel Guía Esencial Calificación: 5 de 5 estrellas5/5Tablas dinámicas y Gráficas para Excel: Una guía visual paso a paso Calificación: 0 de 5 estrellas0 calificacionesAprender a programar Android: con 100 ejercicios prácticos Calificación: 4 de 5 estrellas4/5Fundamentos De Programación Calificación: 5 de 5 estrellas5/5Curso básico de Python: La guía para principiantes para una introducción en la programación con Python Calificación: 0 de 5 estrellas0 calificacionesEl gran libro de Python Calificación: 5 de 5 estrellas5/5Tablas dinámicas para todos. Desde simples tablas hasta Power-Pivot: Guía útil para crear tablas dinámicas en Excel Calificación: 0 de 5 estrellas0 calificacionesAprendizaje automático y profundo en python: Una mirada hacia la inteligencia artificial Calificación: 0 de 5 estrellas0 calificacionesAprende a Programar en C++ Calificación: 5 de 5 estrellas5/5Programación orientada a objetos con C++, 5ª edición. Calificación: 5 de 5 estrellas5/5Aprende a Programar a Python Calificación: 0 de 5 estrellas0 calificacionesTodo el mundo miente: Lo que internet y el big data pueden decirnos sobre nosotros mismos Calificación: 4 de 5 estrellas4/5Curso de Programación y Análisis de Software Calificación: 4 de 5 estrellas4/5115 Ejercicios resueltos de programación C++ Calificación: 3 de 5 estrellas3/5Controles PLC con Texto Estructurado (ST): IEC 61131-3 y la mejor práctica de programación ST Calificación: 3 de 5 estrellas3/5Arduino. Trucos y secretos.: 120 ideas para resolver cualquier problema Calificación: 5 de 5 estrellas5/5Python Aplicaciones prácticas Calificación: 4 de 5 estrellas4/5Introducción al Uso de Formularios (UserForms) en VBA Calificación: 3 de 5 estrellas3/5Ortografía para todos: La tabla periódica de la ortografía Calificación: 5 de 5 estrellas5/5Programación (GRADO SUPERIOR): PROGRAMACIÓN INFORMÁTICA/DESARROLLO DE SOFTWARE Calificación: 4 de 5 estrellas4/5Arduino para Principiantes Calificación: 4 de 5 estrellas4/5
Comentarios para Aprender PHP, MySQL y JavaScript
10 clasificaciones0 comentarios
Vista previa del libro
Aprender PHP, MySQL y JavaScript - Robin Nixon
Capítulo 1
Introducción al contenido dinámico de la web
La World Wide Web es una red en constante evolución que ha ido mucho más lejos de lo que fue su concepción a principios de la década de 1990, cuando se creó con el propósito de resolver un problema específico. Los experimentos más avanzados del CERN (Laboratorio Europeo de Física de Partículas, ahora más conocido como el operador del Gran Colisionador de Hadrones) generaban ingentes cantidades de datos, hasta tal punto que resultaba difícil hacerlos llegar a los científicos de todo el mundo que participaban en las investigaciones.
En aquel momento, Internet ya estaba en funcionamiento, y a la red estaban conectados varios cientos de miles de ordenadores, por lo que Tim Berners-Lee (miembro del CERN) ideó un método para navegar entre ellos mediante una estructura de hiperenlaces, la cual llegó a conocerse como Protocolo de Transferencia de Hipertexto, o HTTP. También creó un lenguaje de marcado llamado Hypertext Markup Language, o HTML. Para integrarlos, desarrolló el primer navegador y el primer servidor web.
Hoy en día estamos acostumbrados a disponer de estas herramientas, pero en aquellas fechas el concepto era revolucionario. Hasta aquel momento, la conectividad más avanzada que tenían a su alcance los usuarios que disponían de un módem en casa era la de realizar una llamada y conectarse a un tablón de anuncios, alojado en un ordenador, a través del que el usuario podía comunicarse e intercambiar datos solo con otros usuarios de ese servicio. Por consiguiente, era necesario que el usuario fuera miembro de muchos sistemas de tablones de anuncios para poder comunicarse electrónicamente de manera efectiva con sus colegas y amigos.
Pero la contribución de Berners-Lee cambió todo aquello de golpe y, a mediados de la década de 1990, había tres grandes navegadores gráficos que competían por la captación de 5 millones de usuarios. Pronto se hizo evidente, sin embargo, que algo faltaba. Es cierto que las páginas de texto con hipervínculos que nos llevan a otras páginas fue un concepto brillante, pero los resultados no reflejaban el potencial de los ordenadores y de Internet para satisfacer de forma inmediata las necesidades particulares de cada usuario con contenidos que cambian dinámicamente. Utilizar la web era una experiencia árida y poco atractiva, incluso aunque hubiéramos tenido ¡texto en movimiento y GIF animados! Los carritos de la compra, los motores de búsqueda y las redes sociales han alterado sin duda la forma en la que utilizamos la web. En este capítulo, echaremos un breve vistazo a los diversos componentes que forman la web y al software que ayuda a hacer de su uso una experiencia rica y dinámica.
HTTP y HTML: los conceptos básicos de Berners-Lee
HTTP es un estándar de comunicación que gobierna las peticiones y respuestas que se envían entre el navegador, que se ejecuta en el ordenador del usuario final, y el servidor web.
El servidor tiene como función aceptar una petición del cliente e intentar responderle en un archivo de manera efectiva, por lo general mediante la entrega de la página web que ha solicitado. Este es el motivo por el que se utiliza el término servidor. El equivalente por naturaleza del servidor es el cliente, término que se aplica tanto al navegador web como al ordenador en el que se ejecuta.
Entre el cliente y el servidor puede haber otros equipos, como enrutadores, proxies, pasarelas, etc. Cumplen diferentes funciones para garantizar que las solicitudes y las respuestas se transfieran correctamente entre el cliente y el servidor. Habitualmente se utiliza Internet como medio para enviar esta información. Algunos de estos dispositivos intermedios también pueden ayudar a acelerar la respuesta de Internet, almacenan páginas o información de forma local en lo que se denomina una caché y, a continuación, sirven este contenido a los clientes directamente desde la caché, en lugar de tener que transferirlo desde el servidor de origen.
Un servidor web normalmente puede manejar múltiples conexiones de forma simultánea, y cuando no está comunicándose con un cliente, se dedica a escuchar para detectar una conexión entrante. Cuando llega una conexión, el servidor envía una respuesta para confirmar su recepción.
Procedimiento de solicitud/respuesta
En su nivel más básico, el proceso de solicitud/respuesta consiste en una pregunta que formula el navegador web al servidor web para que este le envíe una página web, y el servidor le envía la página. El navegador se encarga de mostrar la página (ver Figura 1-1).
IllustrationFigura 1-1. Secuencia básica de solicitud/respuesta entre cliente/servidor
Los pasos en la secuencia de solicitud y respuesta son los siguientes:
1. Introduces http://server.com en la barra de direcciones del navegador.
2. El navegador busca la dirección del protocolo Internet (IP) de server.com .
3. El navegador emite la solicitud de la página de inicio de server.com .
4. La solicitud viaja por Internet y llega al servidor web de server.com .
5. El servidor web, una vez recibida la petición, busca la página web en su disco.
6. El servidor web recupera la página de su disco y la envía al navegador.
7. El navegador muestra la página web.
Para una página web normal, este proceso también se lleva a cabo para cada objeto dentro de la página, ya sea un gráfico, un vídeo integrado o un archivo flash, o incluso una plantilla CSS.
En el paso 2, observamos que el navegador busca la dirección IP de server.com. Cada máquina conectada a Internet tiene una dirección IP (incluido nuestro ordenador) pero generalmente accedemos a los servidores web utilizando un nombre, como por ejemplo google.com. Como probablemente ya sabes, el navegador consulta un servicio adicional de Internet llamado Servicio de Nombres de Dominio (DNS) para encontrar la dirección IP asociada al servidor y, posteriormente, la utiliza para comunicarse con el ordenador.
Para páginas web dinámicas, el procedimiento es un poco más complicado, porque puede ser una mezcla de PHP y MySQL. Por ejemplo, supongamos que hacemos clic sobre la imagen de un impermeable. A continuación, PHP creará una petición usando el lenguaje de base de datos estándar, SQL (muchos de cuyos comandos aprenderás en este libro) y la enviará al servidor MySQL. El servidor MySQL devolverá la información del impermeable que hemos seleccionado, el código PHP lo encerrará todo en HTML, y el servidor lo enviará al navegador (ver la Figura 1-2).
IllustrationFigura 1-2. Secuencia dinámica de solicitud/respuesta entre cliente/servidor
Los pasos son los siguientes:
1. Tecleas http://server.com en la barra de direcciones del navegador.
2. El navegador busca la dirección IP de server.com .
3. El navegador envía una solicitud de la página de inicio del servidor web, a esa dirección.
4. La solicitud viaja por Internet y llega al servidor web server.com .
5. El servidor web, una vez recibida la petición, recupera la página de inicio de su disco duro.
6. Con la página de inicio ahora en memoria, el servidor web se da cuenta de que es un archivo que incorpora PHP y pasa la página al intérprete de PHP.
7. El intérprete de PHP ejecuta el código PHP.
8. Algunos de los códigos PHP contienen sentencias SQL, que el intérprete PHP ahora pasa al motor de base de datos MySQL.
9. La base de datos MySQL devuelve los resultados de las sentencias al intérprete PHP.
10. El intérprete PHP devuelve los resultados del código PHP ejecutado, junto con el archivo de la base de datos MySQL, al servidor web.
11. El servidor web devuelve la página al programa cliente que la ha solicitado, y este la muestra al usuario.
Aunque es útil conocer este proceso para saber cómo funcionan los tres elementos juntos, en la práctica no es necesario que nos preocupemos por ellos, porque todos se ejecutan automáticamente.
Las páginas HTML, devueltas al navegador en cada uno de los ejemplos, pueden contener código en JavaScript, que interpretará localmente el cliente, el cual podría iniciar otra petición, de la misma manera que lo podrían hacer los objetos integrados o las imágenes.
Ventajas de PHP, MySQL, JavaScript, CSS y HTML5
Al principio de este capítulo, introduje el mundo de la Web 1.0, pero no había transcurrido mucho tiempo cuando se dieron prisa en crear la Web 1.1, que incorporaba el desarrollo de mejoras en el navegador como Java, JavaScript, JScript (una variante con pocos cambios de JavaScript de Microsoft) y ActiveX. Por lo que respecta al servidor, se estaban realizando progresos en la interfaz de pasarela común (CGI) con lenguajes de scripting (secuencia de comandos) como Perl (una alternativa al lenguaje PHP) y scripts, insertando el contenido de un archivo (o la salida de la ejecución de un programa local) en otro, de forma dinámica.
Una vez calmados los ánimos, tres tecnologías principales se diferenciaban de las demás. Aunque Perl seguía siendo un lenguaje de programación con un gran número de seguidores, la simplicidad de PHP y los enlaces integrados al programa de base de datos MySQL habían ganado la partida: contaban con más del doble del número de usuarios. Y JavaScript, que se había convertido en una parte esencial de la ecuación para manipular dinámicamente Cascading Style Sheets (CSS) y HTML, ahora asumía la tarea aún más difícil de manejar el lado de cliente de la comunicación asíncrona (el intercambio de datos entre el cliente y el servidor después de que se haya cargado una página web). Mediante el uso de la comunicación asíncrona, las páginas web realizan el tratamiento de datos y envían solicitudes a los servidores web en segundo plano, sin que el usuario de la web sea consciente de que esto esté sucediendo.
Sin duda la naturaleza simbiótica de PHP y MySQL ayudó a impulsar a ambos, pero ¿qué fue lo que más atrajo a los desarrolladores de estos dos lenguajes de programación? La respuesta más sencilla es la facilidad con la que se pueden utilizar para crear rápidamente elementos dinámicos en sitios web. MySQL es un sistema de base de datos rápido y potente, pero al mismo tiempo fácil de usar, que ofrece casi todo lo que un sitio web necesita para encontrar y servir datos a los navegadores. Cuando PHP se alía con MySQL para almacenar y recuperar estos datos, tenemos los componentes fundamentales necesarios para poder desarrollar sitios de redes sociales, lo que marca el comienzo de la Web 2.0.
Y cuando también se incorporan al conjunto JavaScript y CSS, disponemos de la receta para crear sitios web altamente dinámicos e interactivos, especialmente porque ahora hay una amplia gama de sofisticados entornos de funciones JavaScript a los que se puede recurrir para acelerar de forma real el desarrollo web, como la conocida biblioteca jQuery, que ahora es probablemente el recurso más habitual que utilizan los programadores para acceder a las funciones de comunicación asíncrona.
MariaDB: el clon de MySQL
Después de que Oracle comprara Sun Microsystems (los propietarios de MySQL), surgió en la comunidad de desarrolladores la preocupación de que MySQL no siguiera siendo totalmente de software libre, así que, para asegurar esto, MariaDB se escindió de MySQL para mantenerse como software libre bajo licencia GNU GPL. El desarrollo de MariaDB está liderado por algunos de los desarrolladores que crearon MySQL y su compatibilidad es extremadamente alta con MySQL. Por lo tanto, podemos encontrar instalado MariaDB en algunos servidores en lugar de MySQL, pero en lo que respecta a los ejemplos de este libro, no hay que preocuparse, todos ellos funcionan igualmente bien tanto con MySQL como con MariaDB, sistema que se basa en el mismo código base que MySQL Server 5.5. A todos los efectos se pueden intercambiar y no se aprecia ninguna diferencia.
De todos modos, muchos de los temores iniciales parecen haberse disipado, ya que MySQL sigue siendo de software libre, y Oracle solamente cobra por el soporte y las ediciones que proporcionan características adicionales como la georreplicación y el escalado automático. Sin embargo, a diferencia de MariaDB, la comunidad ya no gestiona MySQL, así que si tenemos en cuenta que MariaDB siempre estará ahí por si alguna vez se necesita, proporcionará mucha tranquilidad a los desarrolladores y, probablemente, garantice que el mismo MySQL siga siendo de software libre.
Utilización de PHP
Con PHP, integrar la actividad dinámica en páginas web es una cuestión sencilla. Cuando le asignamos a las páginas la extensión .php, tienen acceso instantáneo a este lenguaje de scripting. Desde el punto de vista del desarrollador, todo lo que hay que hacer es escribir código como el siguiente:
echo Today is
. date(l
) . .
;
?>
Here's the latest news.
La apertura . Fuera de este constructor, todo se envía al cliente directamente como HTML. Entonces, el texto Here's the latest news. se envía al navegador, y dentro de las etiquetas PHP, la función integrada date (fecha), muestra el día en curso de la semana de acuerdo con la hora del sistema del servidor.
La salida final de las dos partes será:
Today is Wednesday. Here's the latest news.
PHP es un lenguaje flexible, y algunos prefieren colocar el constructor PHP directamente al lado del código PHP, así:
Today is l); ?>. Here's the latest news.
Hay incluso más posibilidades de formatear y dar salida a la información, que explicaré en los capítulos correspondientes a PHP. Lo importante es que con PHP, los desarrolladores web tienen un lenguaje de programación que, aunque no es tan rápido como la compilación del código en C o un lenguaje similar, es increíblemente rápido y también se integra perfectamente con el marcado HTML.
Al utilizar PHP, tenemos un control ilimitado sobre nuestro servidor web. Ya sea que necesitemos modificar HTML sobre la marcha, procesar una tarjeta de crédito, añadir detalles de usuario a una base de datos o buscar información de un sitio web de terceros. Podemos hacerlo todo en los mismos archivos PHP en los que reside el propio HTML.
Utilización de MySQL
Por supuesto, no tiene mucho sentido cambiar a una salida HTML dinámica a menos que también tengamos un medio para rastrear la información que los usuarios proporcionan a nuestro sitio web a medida que lo utilizan. En los primeros tiempos de la web, muchos sitios utilizaban archivos de texto plano
para almacenar datos como nombres de usuarios y contraseñas. Pero este enfoque podía causar problemas si el archivo no estaba adecuadamente bloqueado contra la corrupción de múltiples accesos simultáneos. Además, un archivo plano puede crecer hasta cierto punto antes de que sea difícil de manejar, por no mencionar la dificultad de intentar fusionar archivos y realizar búsquedas complejas en un periodo de tiempo razonable.
Ahí es donde las bases de datos relacionales con consultas estructuradas se convierten en esenciales. Y MySQL, al poderse utilizar e instalar libremente en un gran número de servidores web de Internet, viene magníficamente para la ocasión. Es un sistema de gestión de bases de datos robusto y excepcionalmente rápido que utiliza comandos en inglés.
El nivel más alto de la estructura MySQL es una base de datos, dentro de la cual pueden existir una o más tablas que contienen los datos. Por ejemplo, supongamos que estamos trabajando en una tabla llamada users (usuarios), dentro de la cual hemos creado columnas para surname (apellido) firstname (nombre) y email (correo electrónico), y ahora deseamos añadir otro usuario. Un comando que podemos usar para hacerlo es el siguiente:
INSERT INTO users VALUES('Smith', 'John', 'jsmith@mysite.com');
Anteriormente habremos utilizado otros comandos para crear la base de datos y la tabla, y para configurar todos los campos correctamente, pero el comando SQL INSERT en este caso muestra lo sencillo que puede ser añadir nuevos datos a una base de datos. SQL es un lenguaje diseñado a principios de los años 70 que recuerda a uno de los lenguajes de programación más antiguos, COBOL. Sin embargo, se adapta muy bien a las consultas de bases de datos, por lo que sigue utilizándose después de todo este tiempo.
Es igualmente fácil buscar datos. Supongamos que tenemos la dirección de correo electrónico de un usuario y necesitamos buscar el nombre de esa persona. Para ello, podemos generar una consulta MySQL como la siguiente:
SELECT surname,firstname FROM users WHERE
email='jsmith@mysite.com';
MySQL devolverá Smith, John y cualesquiera otros pares de nombres y apellidos que puedan estar asociados con esa dirección de correo electrónico en la base de datos.
Como es de esperar, podemos hacer mucho más con MySQL de lo que hacen los comandos básicos INSERT y SELECT. Por ejemplo, se pueden combinar conjuntos de datos relacionados para reunir información relacionada, pedir resultados mediante órdenes muy variadas, hacer coincidencias parciales cuando solo conocemos una parte de la cadena que estamos buscando, devolver solo el enésimo resultado, etc.
Con PHP, podemos hacer todas estas llamadas directamente a MySQL sin que tener que acceder a la interfaz de línea de comandos MySQL. Esto significa que podemos guardar los resultados en matrices para procesar y realizar búsquedas múltiples, cada una dependiente de los resultados devueltos de las anteriores, para profundizar en el elemento de datos que necesitamos.
Para conseguir un mayor rendimiento, como veremos más adelante, hay funciones adicionales incorporadas a MySQL a las que podemos invocar para ejecutar eficientemente operaciones habituales dentro de MySQL, en lugar de crearlas a partir de múltiples llamadas de PHP a MySQL.
Utilización de JavaScript
La más antigua de las tres tecnologías básicas expuestas en este libro, JavaScript, se creó para permitir el acceso de la programación a todos los elementos de un documento HTML. En otras palabras, proporcionaba un medio para la interacción dinámica del usuario, como la comprobación de la validez de la dirección de correo electrónico en formularios de entrada y la visualización de indicaciones como ¿Querías realmente decir eso?
(sin embargo, no se puede confiar en esta tecnología para temas de seguridad, que siempre se deben llevar a cabo en el servidor web).
Combinado con CSS (ver la siguiente sección), JavaScript es el responsable que hay detrás de las páginas web dinámicas que cambian ante nuestros propios ojos, a diferencia del caso en el que el servidor devuelve una página nueva.
Sin embargo, JavaScript también puede resultar difícil de usar, debido a algunas diferencias importantes entre las formas en las que los diferentes diseñadores de navegadores han elegido implementarlo. Esto sucedió principalmente cuando algunos fabricantes trataron de incluir funcionalidades adicionales a sus navegadores a expensas de la compatibilidad con sus rivales.
Afortunadamente, los desarrolladores han entrado en razón y se han dado cuenta de la necesidad de una compatibilidad total entre sí, por lo que hoy en día es menos exigente tener que optimizar nuestro código para diferentes navegadores. Sin embargo, aún quedan millones de usuarios que utilizan navegadores heredados, y este seguirá siendo probablemente el caso durante muchos años. Afortunadamente, hay soluciones para los problemas de incompatibilidad; más tarde, en este libro, veremos las bibliotecas y técnicas que nos permiten poder ignorar con total seguridad estas diferencias.
Por ahora, veamos cómo usar JavaScript básico, aceptado por todos los navegadores:
document.write(Today is
+ Date() );
Este fragmento de código le dice al navegador web que interprete todo dentro de las etiquetas
Today is Sun Jan 01 2017 01:23:45
Como se mencionó anteriormente, JavaScript se desarrolló originalmente para ofrecer un control dinámico sobre los diversos elementos dentro de un documento HTML, y ese sigue siendo su principal cometido. Pero cada vez más, JavaScript se utiliza para la comunicación asíncrona, el proceso de acceso al servidor web en segundo plano.
La comunicación asíncrona es lo que permite que las páginas web empiecen a parecerse a los programas independientes, porque no hay que volverlas a cargar en su totalidad para mostrar un nuevo contenido. En lugar de eso, una llamada asíncrona puede incorporar y actualizar un solo elemento en una página web, como cambiar tu fotografía en un sitio de redes sociales o reemplazar un botón en el que se hace clic para responder a una pregunta. Este tema se trata con detalle en el Capítulo 17.
Después, en el Capítulo 21, echamos un vistazo al entorno de trabajo de jQuery, que podemos usar para evitar tener que reinventar la rueda cuando necesitamos un código rápido de navegador cruzado para manipular nuestras páginas web. Por supuesto, también hay otros entornos de trabajo disponibles, pero jQuery es, con diferencia, el más popular. Debido a su mantenimiento continuo, es extremadamente fiable y es una herramienta importante en el kit de utilidades de muchos desarrolladores web experimentados.
Utilización de CSS
CSS es el compañero indispensable de HTML, con el que se asegura que el texto HTML y las imágenes se presentan de forma coherente y adecuada en la pantalla del usuario. Con la aparición del estándar CSS3 en los últimos años, CSS ofrece ahora un nivel de interactividad dinámica anteriormente soportada solo por JavaScript. Por ejemplo, no solo se puede cambiar el estilo de cualquier elemento HTML para modificar sus dimensiones, colores, bordes, espaciado, etc., sino que ahora también podemos añadir transiciones animadas y transformaciones a las páginas web, con solo unas pocas líneas de CSS.
El uso de CSS puede ser tan simple como insertar algunas reglas entre las etiquetas en el encabezamiento de una página web, así:
p {
text-align:justify;
font-family:Helvetica;
}
Estas reglas cambian la alineación predeterminada del texto de la etiqueta
para que los párrafos contenidos en ella estén totalmente justificados y utilicen la fuente helvética.
Como veremos en el Capítulo 18, existen muy variadas formas de diseñar reglas CSS; las podemos incluir directamente dentro de etiquetas o guardar un conjunto de reglas en un archivo externo, que se carga por separado. Esta flexibilidad no solo nos permite estilizar nuestro HTML con precisión, sino que también podemos, por ejemplo, proporcionar la funcionalidad integrada de movimiento de los objetos cuando el ratón pasa sobre ellos. También aprenderás a acceder a todas las funciones de un elemento desde JavaScript y HTML.
Y luego está HTML5
A pesar de la utilidad de todas estas incorporaciones a los estándares web, no fueron suficientes para desarrolladores cada vez más ambiciosos. Por ejemplo, todavía no existía una forma sencilla de manipular gráficos en un navegador web sin recurrir a complementos como Flash. Y lo mismo ocurría con la inserción de audio y vídeo en las páginas web. Además, varias inconsistencias molestas se habían colado en HTML durante su evolución.
Por lo tanto, para aclarar todo esto y llevar Internet más allá de la Web 2.0 y a su próxima iteración, se creó un nuevo estándar para HTML con el fin de subsanar todas estas deficiencias: HTML5. Su desarrollo comenzó ya en 2004, cuando la Fundación Mozilla y Opera Software (desarrolladores de dos populares webs) redactaron el primer borrador, pero no fue hasta principios de 2013, año en el que se envió el borrador definitivo al World Wide Web Consortium (W3C), el organismo internacional que gobierna los estándares de calidad de la web.
El desarrollo de HTML5 ha necesitado varios años, pero ahora estamos en una fase muy sólida y estable de la versión 5.1 (desde 2016). Es un ciclo interminable de desarrollo. Sin embargo, es seguro que con el tiempo aumentará su funcionalidad. Algunas de las mejores características de HTML5 para el manejo y visualización de los media incluyen el
El servidor web Apache
Además de PHP, MySQL, JavaScript, CSS y HTML5, hay un sexto héroe en la web dinámica: el servidor web. En el caso de este libro, este es el servidor web Apache. Hemos discutido un poco sobre lo que hace un servidor web durante el intercambio HTTP entre servidor/cliente, pero hace muchas más cosas entre bastidores.
Por ejemplo, Apache no solo sirve archivos HTML, sino que maneja una amplia gama de archivos, desde imágenes y archivos Flash hasta archivos de audio MP3, RSS (Really Simple Syndication), etc. Y estos objetos no tienen que ser archivos estáticos como las imágenes GIF. Todos ellos pueden estar generados por programas como scripts PHP. Así es: PHP puede incluso crear imágenes y otros archivos para nosotros, ya sea sobre la marcha o por adelantado para servirlos más tarde.
Para hacer esto, normalmente tiene módulos bien precompilados en Apache o PHP o bien se los llama durante la ejecución. Uno de estos módulos es la biblioteca GD (Graphics Draw), que PHP usa para crear y manejar gráficos.
Apache también soporta una amplia gama de módulos propios. Además de PHP, lo más importante para nuestros propósitos como programadores web son los módulos que se encargan de la seguridad. Otros ejemplos son el módulo Rewrite, que permite al servidor web manejar un rango de tipos de URL y reescribirlos adaptándolos a sus propios requerimientos internos, y el módulo Proxy, que se puede utilizar para servir páginas que se solicitan con frecuencia, desde una caché, para agilizar la carga del servidor.
Más adelante, en el libro, veremos cómo usar algunos de estos módulos para mejorar las características que proporcionan las tres principales tecnologías.
Uso de dispositivos móviles
Actualmente vivimos en un mundo de dispositivos informáticos móviles interconectados, y el concepto de desarrollar sitios web solo para ordenadores de mesa se ha vuelto bastante anticuado. En lugar de esto, los desarrolladores ahora pretenden desarrollar sitios y aplicaciones web sensibles que se adapten al entorno en el que se están ejecutando.
Así que como novedad en esta edición, explico cómo se pueden crear fácilmente este tipo de productos solo con las tecnologías detalladas en este libro, junto con la potente tecnología jQuery Mobile de funciones sensibles JavaScript. Con ella, podrás centrarte en el contenido y usabilidad de tus sitios y aplicaciones web, sabiendo que la forma en que se muestran se optimizará automáticamente para una amplia gama de dispositivos informáticos diferentes: una cosa menos de la que preocuparte.
Para mostrar cómo hacer pleno uso de sus capacidades, en el capítulo final de este libro se crea un sencillo sitio web de ejemplo de red social. Para ello utilizamos jQuery Mobile, para que tengas capacidad de respuesta y estés seguro de que se presenta adecuadamente en cualquier dispositivo, desde la pantalla de un pequeño teléfono móvil a una tablet o a un ordenador de mesa.
Sobre el software libre
Las tecnologías que se tratan en este libro son de software libre: a cualquier persona se le permite leer y cambiar el código. Se ha debatido a menudo si este hecho es o no la razón por la que estas tecnologías son tan populares, sea como sea, PHP, MySQL y Apache son las tres herramientas que se usan con más frecuencia en sus categorías. Lo que se puede decir de manera definitiva, sin embargo, es que el hecho de que sean de software libre significa que se han desarrollado en la comunidad por equipos de programadores que escriben las características que ellos mismos quieren y necesitan, y el código original está disponible para que todos tengamos acceso al mismo e incluso podamos modificarlo. Los errores se pueden encontrar rápidamente y las infracciones de seguridad se pueden prevenir antes de que ocurran.
Hay otra ventaja: todos estos programas son gratuitos. No hay que preocuparse por tener que comprar licencias adicionales si tienes que ampliar tu sitio web y añadir más servidores, y no necesitas estudiar el presupuesto antes de decidir si deseas actualizar estos productos a las últimas versiones.
Todo junto
La verdadera belleza de PHP, MySQL, JavaScript (a veces con la ayuda de jQuery u otros entornos de trabajo), CSS y HTML5 es la maravillosa forma en que todos ellos trabajan juntos para crear contenido web dinámico: PHP gestiona el trabajo principal en el servidor web, MySQL gestiona los datos y la combinación de CSS y JavaScript se encarga de la presentación de la página web. JavaScript también puede hablar con tu código PHP en el servidor web siempre que necesites actualizar algo (ya sea en el servidor o en la página web). Y con las nuevas y potentes funciones de HTML5, como el lienzo, el audio, el vídeo y la geolocalización, puedes hacer que tus páginas web sean muy dinámicas, interactivas y estén repletas de multimedia.
Sin usar código de programación, vamos a resumir el contenido de este capítulo estudiando el proceso de combinar algunas de estas tecnologías con la característica de comunicación asíncrona cotidiana que utilizan muchos sitios web: comprobar si ya existe un nombre de usuario deseado en el sitio cuando un usuario se está registrando para crear una nueva cuenta. Un buen ejemplo de esto se puede ver en Gmail (ver la Figura 1-3).
IllustrationFigura 1-3. Gmail usa la comunicación asíncrona para verificar la disponibilidad de nombres de usuario
Los pasos a seguir en este proceso asíncrono serán parecidos a los siguientes:
1. El servidor genera el código HTML para crear el formulario web, en el que se pide la información necesaria, como el nombre de usuario, nombre, apellido y dirección de correo electrónico.
2. Al mismo tiempo, el servidor añade código JavaScript a HTML para monitorizar el cuadro de entrada de nombre de usuario y comprobar dos cosas: si se ha tecleado texto y si la entrada ha dejado de estar seleccionada debido a que el usuario hizo clic en otro cuadro de entrada.
3. Una vez que se ha introducido el texto y se ha deseleccionado el campo, el código JavaScript pasa, en segundo plano, el nombre de usuario que se escribió, a un script PHP en el servidor web y espera una respuesta.
4. El servidor web busca el nombre de usuario y responde a JavaScript en cuanto a si ese nombre ya existe.
5. JavaScript entonces coloca una indicación al lado del cuadro de entrada del nombre de usuario para mostrar si el nombre está disponible, tal vez una marca de verificación verde o un gráfico con una cruz roja, junto con alguna indicación de texto.
6. Si el nombre de usuario no está disponible y el usuario sigue enviando el formulario, JavaScript interrumpe la presentación y vuelve a hacer hincapié (quizás con un gráfico más grande y/o un cuadro de aviso) en que el usuario necesita elegir otro nombre de usuario.
7. Opcionalmente, una versión mejorada de este proceso podría incluso examinar el nombre de usuario y sugerir una alternativa que esté disponible en ese momento.
Todo esto se lleva a cabo discretamente, en segundo plano, y hace que la experiencia del usuario sea cómoda e impecable. Sin comunicación asíncrona, se tendría que enviar todo el formulario al servidor, que entonces devolvería el HTML y resaltaría cualquier error. Sería una solución viable, pero ni de lejos tan ordenada o placentera como el procesamiento de los campos del formulario sobre la marcha.
Sin embargo, la comunicación asíncrona se puede utilizar para mucho más que una simple verificación y procesamiento de entradas. Vamos a explorar muchas otras cosas que podemos hacer con ella más adelante en este libro.
En este capítulo, he presentado una completa introducción a las tecnologías básicas de PHP, MySQL, JavaScript, CSS y HTML5 (así como Apache), y has aprendido cómo funcionan juntas. En el Capítulo 2, veremos cómo puedes instalar tu propio servidor de desarrollo web en el que practicar todo lo que vas a aprender.
Preguntas
1. ¿Cuáles son los cuatro componentes (como mínimo) necesarios para crear una página web completamente dinámica?
2. ¿Qué significa HTML?
3. ¿Por qué el nombre MySQL contiene las letras SQL?
4. PHP y JavaScript son lenguajes de programación que generan resultados dinámicos para páginas web. ¿Cuál es su principal diferencia, y por qué los usarías a los dos?
5. ¿Qué significa CSS?
6. Enumera tres nuevos elementos principales introducidos en HTML5.
7. Si encuentras un error (que es raro) en una de las herramientas de software libre, ¿cómo crees que podrías arreglarlo?
8. ¿Por qué un framework como jQuery Mobile es tan importante para desarrollar sitios web y aplicaciones web modernas?
Consulta Respuestas del Capítulo 1
en la página 705 del Apéndice A para comprobar las respuestas a estas preguntas.
Capítulo 2
Configuración del servidor de desarrollo
Si deseas desarrollar aplicaciones de Internet pero no tienes tu propio servidor de desarrollo, tendrás que subir cada modificación que hagas a un servidor situado en algún lugar de la web antes de que puedas probarla.
Incluso en el caso de una conexión de banda ancha de alta velocidad, esto puede suponer una importante pérdida de tiempo de desarrollo. Sin embargo, en un ordenador local las pruebas pueden ser tan sencillas como guardar una actualización (que normalmente es cuestión de hacer clic una vez en un icono) y luego pulsar el botón Refresh (Actualizar) en el navegador.
Otra ventaja de disponer de un servidor de desarrollo es que cuando programas y haces pruebas, no tienes que preocuparte de errores embarazosos o por problemas de seguridad. Sin embargo, cuando tu aplicación está en un sitio web público, tienes que estar al tanto de lo que la gente puede ver o hacer con ella. Es mejor solucionarlo todo mientras todavía la tienes instalada en un equipo de casa o de la oficina, los cuales están presumiblemente protegidos por cortafuegos y otras medidas de seguridad.
Una vez que tengas tu propio servidor de desarrollo, te preguntarás cómo has podido sobrevivir sin uno. Es muy fácil crear uno. Solo tienes que seguir los pasos que se detallan en las siguientes secciones y utilizar las instrucciones apropiadas para PC, Mac o para el sistema Linux.
En este capítulo, trataremos de la experiencia web solo el lado del servidor, como se describe en el Capítulo 1. Pero para probar los resultados de tu trabajo, especialmente cuando más adelante, en este libro, empecemos a usar JavaScript, CSS y HTML5, lo ideal sería tener funcionando los principales navegadores web en algún sistema que te resulte cómodo. Siempre que sea posible, en la lista de navegadores deben figurar al menos Microsoft Edge, Mozilla Firefox, Opera, Safari y Google Chrome. Si quieres tener la seguridad de que tus sitios se vean bien en dispositivos móviles, debes tratar de organizar el acceso a una amplia gama de dispositivos iOS y Android.
¿Qué son WAMP, MAMP o LAMP?
WAMP, MAMP y LAMP son abreviaturas de Windows, Apache, MySQL y PHP
, Mac, Apache, MySQL y PHP
y Linux, Apache, MySQL y PHP
.
Cada una de estas abreviaturas describe una configuración funcional que se utiliza para desarrollar páginas web dinámicas en Internet.
WAMP, MAMP y LAMP se presentan en forma de paquetes en los que los programas están agrupados, lo que evita tener que instalarlos y configurarlos por separado. Esto significa que puedes descargar e instalar un solo programa y seguir algunas indicaciones sencillas para poner en marcha el servidor de desarrollo web de forma rápida y con las mínimas molestias.
Durante la instalación, se crean varias configuraciones por defecto. Las configuraciones de seguridad de una instalación de este tipo no serán tan estrictas como las de un servidor web de producción, ya que su desarrollo está optimizado para uso local. Por estas razones, no debes instalar estas configuraciones como un servidor de producción.
Sin embargo, para desarrollar y probar sitios web y aplicaciones, debería ser suficiente utilizar una de estas instalaciones.
Instalación de AMPPS en Windows
Hay varios servidores WAMP disponibles, cada uno de los cuales ofrece configuraciones ligeramente diferentes. De las varias opciones de software libre y gratuito, una de las mejores es AMPPS. Puedes descargar la aplicación haciendo clic en el botón de la página de inicio (http://amppscom/), del sitio web, que se muestra en la Figura 2-1.
Te recomiendo que descargues siempre la última versión estable (mientras escribo esto, es la 3.8, que tiene un tamaño aproximado de 128 MB). Los distintos instaladores de Windows, macOS y Linux aparecen en la página de descargas.
IllustrationFigura 2-1. Sitio web de AMPPS
Una vez que hayas descargado el instalador, ejecútalo y se abrirá una ventana como la que se muestra en la Figura 2-2. Sin embargo, antes de llegar a esa ventana, si utilizas un programa antivirus o tienes activado el control de cuentas de usuario de Windows, es posible que primero se te muestren uno o más avisos y tengas que hacer clic en Yes y/o OK para continuar con la instalación.
Haz clic en Next (Siguiente), después de lo cual debes aceptar el acuerdo. Vuelve a hacer clic en Next y, luego, otra vez para pasar la pantalla de información. Ahora tendrás que confirmar el lugar en el que se va a instalar AMPPS. Probablemente te sugerirá algo como lo siguiente, en función de la letra del disco duro principal de tu ordenador, pero lo puedes cambiar si lo deseas:
C:\Program Files (x86)\Ampps
IllustrationFigura 2-2. Ventana de apertura del instalador
Una vez que hayas decidido dónde instalar AMPPS, haz clic en Next, elige un nombre de carpeta en el menú Start (Inicio) y vuelve a hacer clic en Next. Puedes elegir qué iconos deseas instalar, como se muestra en la Figura 2-3. En la pantalla siguiente, haz clic en el botón Install (Instalar) para iniciar el proceso.
IllustrationFigura 2-3. Elección de los iconos que deseas instalar
La instalación durará unos minutos, después de los cuales verás la pantalla de finalización de la Figura 2-4, y puedes hacer clic en Finish (Terminar).
IllustrationFigura 2-4. AMPPS ya está instalado
Lo último que debes hacer es instalar C++ Redistributable Visual Studio, si aún no lo has hecho. Visual Studio es un entorno en el que realizaremos trabajo de desarrollo. Se abrirá una ventana para preguntarte sobre la instalación, como se muestra en la Figura 2-5. Haz clic en Yes para iniciar la instalación o en No si estás seguro de que ya la tienes.
IllustrationFigura 2-5. Instala C++ Redistributable Visual Studio si aún no lo tienes
Si decides continuar con la instalación, tendrás que aceptar los términos y condiciones que se muestran en la ventana emergente que aparece y, a continuación, hacer clic en Install. La instalación debería ser bastante rápida. Haz clic en Close (Cerrar) para finalizar.
Una vez instalado AMPPS, debería aparecer en la parte inferior derecha de tu escritorio la ventana de control que se muestra en la Figura 2-6. También puedes acceder a esta ventana mediante el acceso directo de la aplicación AMPPS en el menú Start (Inicio) o en el escritorio, si has permitido que se hayan creado estos iconos.
IllustrationFigura 2-6. Ventana de control de AMPPS
Antes de continuar, te recomiendo que te familiarices con la documentación de AMPPS (http://ampps.com/wiki). Una vez que la hayas digerido, si todavía tiene alguna dificultad, hay un enlace de Support (Soporte) en la parte inferior de la ventana de control que te llevará al sitio web de AMPPS, donde puedes abrir un ticket con el problema.
Prueba de la instalación
Lo primero que hay que hacer llegados a este punto es verificar que todo funciona correctamente. Para ello, introducimos uno de los dos siguientes URL en la barra de direcciones del navegador:
localhost
127.0.0.1
Se abrirá una pantalla de introducción, en la que tendrás la oportunidad de proteger AMPPS proporcionando una contraseña (consultar la Figura 2-7). Te recomiendo que no marques la casilla y hagas clic en el botón Submit (Enviar) para continuar sin establecer una contraseña.
IllustrationFigura 2-7. Pantalla inicial de la configuración de seguridad
Una vez hecho esto, te llevará a la página de control principal en localhost/ampps/ (de ahora en adelante supongo que accedes a AMPPS a través de localhost en lugar de 127.0.0.1). Desde aquí puedes configurar y controlar todos los aspectos de la pila AMPPS, así que toma nota de esto para futuras referencias, o quizás puedas poner un marcador en tu navegador.
A continuación, para ver la carpeta principal (descrita en la siguiente sección) de tu nuevo servidor web Apache, escribe lo siguiente en la barra del navegador:
localhost
Esta vez, en lugar de ver la pantalla inicial de la configuración de seguridad, deberías ver algo similar a la Figura 2-8.
IllustrationFigura 2-8. Visualización de la carpeta principal
Acceso a la carpeta principal (Windows)
La carpeta principal es el directorio que contiene los principales documentos web de un dominio. Este directorio es el que utiliza el servidor cuando se escribe en el navegador un URL básico sin ruta, como http://yahoo.com o, para tu servidor local, http://localhost.
Por defecto, AMPPS utilizará la siguiente ubicación como carpeta principal:
C:\Program Files (x86)\Ampps\www
Para tener la seguridad de que tienes todo configurado correctamente, debes crear ahora el obligado archivo Hello World
. Por lo tanto, crea un pequeño archivo HTML con las líneas que se detallan a continuación, con el bloc de notas de Windows o cualquier otro programa o editor de texto, pero no un procesador de texto enriquecido como Microsoft Word (a menos que lo guardes como texto plano):
en>
Hello World!
Una vez que lo hayas escrito, guarda el archivo en el directorio de la carpeta principal, con el nombre de archivo test.html. Si utilizas el bloc de notas, ten en cuenta que el valor de la casilla Save as type
(Guardar como
) cambia de Text Documents (*.txt)
(Documentos de texto (*.txt)
) a All Files (*.*)
( Todos los archivos (*.*)
).
Ahora puedes llamar a esta página en tu navegador; escribe el siguiente URL en la barra de direcciones (ver la Figura 2-9):
localhost/test.html
IllustrationFigura 2-9. Tu primera página web
WAMP alternativos
Cuando el software se actualiza, a veces funciona de manera diferente a como esperamos que lo haga, e incluso se pueden introducir errores. Así que, si encuentras dificultades que no puedes resolver en AMPPS, puede que prefieras elegir alguna de las otras soluciones disponibles en la web.
Podrás seguir utilizando todos los ejemplos de este libro, pero tendrás que seguir las instrucciones que se facilitan con cada WAMP, que pueden no ser tan fáciles de seguir como las de la guía anterior.
He aquí una selección de algunos de los mejores, en mi opinión:
•EasyPHP
•XAMPP
•WAMPServer
•Glossword WAMP
Instalación de AMPPS en macOS
AMPPS también está disponible en macOS, y puedes descargarlo desde el sitio web (https://apachefriends.org/), como se mostraba anteriormente en la Figura 2-1 (cuando escribo esto, la versión actual es la 3.8 y su tamaño es de unos 270 MB).
Si el navegador no lo abre automáticamente una vez descargado, haz doble clic en archivo .dmg y, a continuación, arrastra la carpeta AMPPS a tu carpeta Applications (consulta la Figura 2-10).
IllustrationFigura 2-10. Arrastra la carpeta AMPPS a Applications (Aplicaciones)
Ahora abres la carpeta Applications de la forma habitual y haz doble clic en el programa AMPPS. Si la configuración de seguridad impide que se abra el archivo, mantén pulsada la tecla Control y haz clic en el icono una vez. Aparecerá una nueva ventana que te pregunta si estás seguro de que deseas abrirlo. Haz clic en Open (Abrir). Cuando se inicie la aplicación, es posible que tengas que introducir tu contraseña de macOS para continuar.
Una vez que AMPPS esté en funcionamiento, aparecerá una ventana de control similar a la que se muestra en la Figura 2-6 en la parte inferior izquierda del escritorio.
Acceso a la carpeta principal (macOS)
Por defecto, AMPPS utilizará la siguiente ubicación como raíz del documento:
/Applications/Ampps/www
Para tener la seguridad de que tenemos todo configurado correctamente, debemos crear ahora el obligado archivo Hello World
. Por lo tanto, creamos un pequeño archivo HTML con las siguientes líneas con el programa TextEdit o cualquier otro programa o editor de texto, pero no procesador de texto enriquecido (a menos que lo grabemos como texto sin formato):
Hello World!
Una vez que hayamos escrito esto, guardamos el archivo en la carpeta principal del documento con el nombre de archivo test.html.
Ahora podemos llamar a esta página en el navegador escribiendo el siguiente URL en la barra de direcciones (para ver un resultado similar al de la Figura 2-9):
localhost/test.html
Instalación de LAMP en Linux
Este libro está dirigido principalmente a usuarios de PC y Mac, pero el código funcionará igual de bien en un ordenador con Linux. Sin embargo, hay docenas de sabores populares de Linux, y en cada uno de ellos es posible que la instalación de LAMP se tenga que hacer de una manera ligeramente diferente, así que no podemos tratarlas todas en este libro.
Dicho esto, muchas versiones de Linux vienen preinstaladas con un servidor web y MySQL, y lo más probable es que ya estén listas para funcionar. Para averiguarlo, intentamos introducir la dirección en un navegador y ver si obtiene una página web predeterminada de la carpeta principal:
Localhost
Si esto funciona, es probable que tengas el servidor Apache instalado y que también tengas MySQL funcionando. Consulta con el administrador del sistema para estar seguro.
Sin embargo, si aún no tienes un servidor web instalado, hay una versión de AMPPS disponible que puedes descargar desde el sitio web (http://apachefriends.org/).
La secuencia de instalación es similar a la mostrada en la sección anterior. Si necesitas más ayuda para utilizar el software, consulta la documentación (http://ampps.com/wiki/Main_Page).
Trabajar de forma remota
Si tienes acceso a un servidor web ya configurado con PHP y MySQL, siempre lo puedes usar para desarrollar tu web. Pero a menos que tengas una conexión de alta velocidad, no siempre es la mejor opción. El desarrollo local te permite probar las modificaciones con poco o ningún retraso en el proceso de carga.
Acceder a MySQL remotamente puede no ser fácil tampoco. Debemos usar el SSH seguro para iniciar sesión en el servidor y crear manualmente bases de datos y establecer permisos desde la línea de comandos. La empresa con la que tienes contratado tu alojamiento web te aconsejará la mejor manera de hacerlo y te proporcionara cualquier contraseña que haya fijado para que accedas a MySQL (así como, por supuesto, para entrar en el servidor en primer lugar). A menos que no tengas elección, te recomiendo que no utilices el inseguro protocolo Telnet para conectarte remotamente a cualquier servidor.
Inicio de sesión
Recomiendo que, como mínimo, si utilizas Windows, instales un programa como PuTTY (http://putty.org/), para el acceso Telnet y SSH (recuerda que SSH es mucho más seguro que Telnet).
En un Mac, ya tienes SSH disponible. Solo tienes que seleccionar la carpeta Applications (Aplicaciones), seguida de Utilities (Utilidades), y luego iniciar Terminal. En la ventana Terminal, inicias sesión en el servidor; utiliza SSH como se indica a continuación:
ssh mylogin@server.com
donde server.com es el nombre del servidor en el que deseas iniciar sesión y mylogin es el nombre de usuario con el que iniciarás sesión. Se te pedirá la contraseña para ese nombre de usuario y, si la introduces correctamente, iniciarás sesión.
Utilización de FTP
Para transferir archivos desde y hacia el servidor web, necesitaremos un programa FTP. Si buscas en la web un buen programa, habrá tantos que podrías necesitar mucho tiempo para encontrar uno con todas las características necesarias.
Mi programa FTP preferido es el de software libre FileZilla (http://filezilla-project.org/), para Windows, Linux y macOS 10.5 o posterior (ver Figura 2-11). Las instrucciones completas sobre cómo usar FileZilla están disponibles en wiki (http://wiki.filezillaporject.org/).
IllustrationFigura 2-11. FileZilla es un programa FTP con todas las funciones
Por supuesto, si ya tienes un programa de FTP, es mejor que te aferres a lo que sabes.
Utilización del editor de programas
Aunque para editar HTML, PHP y Javascript se puede utilizar un editor de texto plano, ha habido algunas mejoras importantes en los editores de programas dedicados, que ahora incorporan características muy útiles, como el resaltado de sintaxis en color. Los editores de programas actuales son inteligentes y pueden indicar dónde tenemos errores de sintaxis incluso antes de que ejecutemos un programa. Una vez que hayas usado un editor moderno, te preguntarás cómo has podido arreglártelas sin uno.
Hay un buen número de programas disponibles, pero me he decidido por Editra (ver la Figura 2-12) porque es gratuito y está disponible en macOS, Windows y Linux/Unix, y se adapta a la forma en la que programo. Puedes descargar una copia si visitas el sitio web de Editra (http://editra.org/) y seleccionas el enlace Download (Descargar) en la parte superior de la página, donde también puedes encontrar un enlace de acceso a la documentación. Cada persona tiene diferentes estilos de programación y distintas preferencias, sin embargo, si decides no utilizarlo, hay muchos más editores de programas disponibles entre los que puedes elegir, o tal vez quieras optar directamente por un entorno de desarrollo integrado (EDI), como se describe en la siguiente sección.
IllustrationFigura 2-12. Los editores de programas (como Editra, en la foto) tienen mejores prestaciones que los editores de texto plano
Como puedes ver en la Figura 2-12, Editra resalta la sintaxis adecuadamente y emplea distintos colores para ayudar a aclarar lo que ocurre. Además, puedes colocar el cursor al lado de los corchetes o las llaves y Editra resaltará los que coincidan para que puedas comprobar si tienes demasiados o demasiado pocos. De hecho, Editra hace además muchas más cosas, que descubrirás y las disfrutarás mientras lo usas.
De nuevo, si tienes un editor de programas preferido diferente a este, úsalo; siempre es una buena idea usar programas con los que ya estés familiarizado.
Utilización del EDI
A pesar de lo convenientes que pueden ser los editores de programas dedicados para la productividad de la programación, su utilidad es insignificante cuando se los compara con entornos de desarrollo integrados, ya que estos ofrecen muchas características adicionales como son la depuración y las pruebas de programas, descripciones de funciones, etc.
La Figura 2-13 muestra el popular EDI phpDesigner con un programa PHP cargado en el marco principal de la página y el explorador de código de la derecha, que enumera las diversas clases, funciones y variables que utiliza.
IllustrationFigura 2-13. Cuando utilizamos un EDI como phpDesigner, el desarrollo en PHP es mucho más rápido y fácil
En el desarrollo con un EDI, podemos establecer puntos de interrupción y, a continuación, ejecutar todo (o partes de) el código, que se detendrá en los puntos de interrupción y nos proporcionará información sobre el estado del programa en ese momento.
Como ayuda para el aprendizaje de la programación, los ejemplos de este libro se pueden introducir y ejecutar en un EDI, sin necesidad de abrir el navegador web. Hay varios EDI disponibles para diferentes plataformas, la mayoría de los cuales son comerciales, pero también hay algunos gratis. La Tabla 2-1 contiene algunos de los EDI PHP más conocidos, junto con sus URL de descarga.
Tabla 2-1. Selección de EDI PHP
La elección de un EDI puede ser algo muy personal, así que si quieres usar uno, te aconsejo que descargues un par o más de ellos para probarlos primero. Todos tienen versiones de prueba o son de uso libre, así que no te costará nada.
Debes dedicar tiempo a la instalación de un editor de programas o un EDI con el que te sientas cómodo; entonces estarás preparado para probar los ejemplos que se muestran en los capítulos siguientes.
Armado con estas herramientas, ya puedes pasar al Capítulo 3, donde comenzaremos explorando PHP en profundidad y descubriremos cómo hacer que funcionen HTML y PHP, así como la estructura del propio lenguaje PHP. Pero antes de seguir adelante te sugiero que pruebes tus nuevos conocimientos con las siguientes preguntas.
Preguntas
1. ¿Cuál es la diferencia entre un WAMP, un MAMP y un LAMP?
2. ¿Qué tienen en común la dirección IP 127.0.0.1 y el URL http://localhost?
3. ¿Cuál es el propósito de un programa FTP?
4. Nombra la principal desventaja de trabajar en un servidor web remoto.
5. ¿Por qué es mejor utilizar un editor de programas que un editor de texto?
Consulta Respuestas del Capítulo 2
en la página 760 del Apéndice A para comprobar las respuestas a estas preguntas.
CAPÍTULO 3
Introducción a PHP
En el Capítulo1, expliqué que PHP es el lenguaje que usamos para hacer que el servidor genere una salida dinámica, salida que es potencialmente diferente cada vez que un navegador solicita una página. En este capítulo, comenzaremos a aprender este sencillo pero potente lenguaje. Durante los siguientes capítulos, hasta el Capítulo 7, trataremos este tema.
Te animo a que desarrolles tu código PHP con uno de los EDI de la lista del Capítulo 2. Te ayudará a detectar errores tipográficos y a acelerar enormemente el aprendizaje si lo comparamos con un editor con menos funciones.
Muchos de estos entornos de desarrollo te permitirán ejecutar el código PHP y ver los resultados que se comentan en este capítulo. También mostraré cómo hay que integrar PHP en un archivo HTML para que puedas apreciar cómo se ve el resultado en una página web (la forma en la que los usuarios la verán en última instancia). Pero ese paso, por muy emocionante que