Manual Programacion PHP
Manual Programacion PHP
www.desarrolloweb.com
Programacin en PHP
Principios bsicos para la programacin en PHP, el popular lenguaje del lado del servidor.
Manual asequible para no programadores que sienta los fundamentos bsicos de este lenguaje.
Continuacin lgica del manual de pginas dinmicas.
Daniel Lpez
Jorge Ramos
Brian Hernndez
Redactor de DesarrolloWeb.com
http://www.desarrolloweb.com
(24 captulos)
http://pichongol.blogspot.com
(1 captulo)
(1 captulo)
Me he permitido comenzar con una frase que dudo haber sido el primero en pronunciar, y por la que muchos de
vosotros pensaris que me he puesto "mstico" innecesariamente. Pero tiene su razn de ser. Cuando te pones a estudiar
un nuevo lenguaje de programacin ests invirtiendo tu tiempo, ese bien tan preciado que tienes y, por supuesto,
debemos escoger correctamente a qu lenguaje apostar nuestras cartas.
PHP es el lenguaje que hoy puede resultar ms interesante de aprender por muchas razones, y de ello trata este artculo,
que sirve de resumen del contenido ofrecido durante el programa #phpIO del 15 de enero de 2013. A continuacin te
ofrecemos el listado de razones destacadas por los distintos ponentes que participaron en este evento, animando a todos
los espectadores a aprender PHP:
"PHP es la evolucin lgica en el aprendizaje de todo desarrollador web"
Jos Dimas Lujn @josedlujan
Aprender PHP es idneo porque es el lenguaje ms indicado para cualquier persona que haya explorado previamente
otros lenguajes web ms bsicos, como pueden ser HTML, CSS o Javascript. Todo desarrollador web que se precie ha
pasado por PHP, por diversas razones, entre las que destaca su facilidad de aprendizaje y las capacidades de PHP de
realizar tareas clave que necesitan implementar la mayora de las aplicaciones o sitios web.
Tal como nos indic Jos, de los #androidIO, PHP es sencillo porque se desprende de muchas de las dificultades o
rigideces de los lenguajes de programacin. Podemos hacer un uso sencillo de PHP, pero tambin tiene frmulas para
un uso avanzado. Es un trmino medio entre un lenguaje "marciano" y un lenguaje "humano".
"Si t desarrollas web, pero no pasaste por PHP, te perdiste un aprendizaje muy bonito, muy divertido y la posibilidad
de hacer las cosas sencillas".
"La comunidad hace grandes a los lenguajes de programacin"
Claudio Morales @pronuer
Bajo la experiencia de Claudio, fundador de @programasPHP, la comunidad de PHPeros de Mxico, la comunidad es
uno de los puntos que hacen fuertes a PHP. Existe mucho trabajo bien hecho por las personas que hacen o trabajan con
PHP y que provoca que este lenguaje tenga una larga vida. En pocas horas una persona puede empezar a programar en
PHP y eso facilita que la comunidad no pare de crecer y cada vez PHP sea ms utilizado.
Por otra parte, destac Claudio, la mayora de soluciones de hospedaje incluyen PHP como opcin principal y ms
econmica. Esto provoca que las personas al final quieran usar ms el lenguaje y las tecnologas que lo rodean.
PHP es un lenguaje de la comunidad, hecho por una enorme comunidad y utilizado por decenas de millones de
desarrolladores en todo el mundo. Tantos millones de profesionales no pueden estar equivocados al mismo tiempo.
"Aprender PHP es como remar contra corriente, si no se hace, se retrocede".
"Puedes desarrollar muy rpido aplicaciones web utilizando frameworks"
Reinaldo Aguilera @reiaguilera
La curva de aprendizaje de PHP es sencilla, y ests en el sistema operativo que ests, puedes instalar PHP y empezar a
programar. PHP es muy poderoso y est presente en la mayora de los servidores pblicos de Internet. Todas esas son
razones suficientes para escoger PHP como lenguaje de programacin del lado del servidor, pero hay un motivo que
todava gana ms fuerza en la actualidad, los frameworks.
Parte 1:
Qu es PHP
Captulos introductorios donde hablaremos sobre los lenguajes de desarrollo del lado del
servidor en general para explicar PHP en particular y que se entienda cul es su modo de
funcionamiento y los tipos de cosas que se pueden hacer con este lenguaje.
PHP, aunque multiplataforma, ha sido concebido inicialmente para entornos UNIX y es en este sistema
operativo donde se pueden aprovechar mejor sus prestaciones. ASP, siendo una tecnologa Microsoft, esta
orientado hacia sistemas Windows, especialmente NT.
Las tareas fundamentales que puede realizar directamente el lenguaje son definidas en PHP como funciones
mientras que ASP invoca ms frecuentemente los objetos. Por supuesto, esto no es ms que una simple
cuestin de forma ya que ambos lenguajes soportan igualmente ambos procedimientos.
ASP realiza numerosas tareas sirvindose de componentes (objetos) que deben ser comprados a determinadas
empresas especializadas (o programados por nosotros mismos en otros lenguajes). PHP presenta una filosofa
totalmente diferente y, con un espritu ms generoso, es progresivamente construido por colaboradores
desinteresados que implementan nuevas funciones en nuevas versiones del lenguaje.
Este manual va destinado a aquellos que quieren comenzar de cero el aprendizaje de este lenguaje y que buscan en l la
aplicacin directa a su proyecto de sitio o a la mejora de su sitio HTML. Los captulos son extremadamente simples,
sino simplistas, buscando ser accesibles a la mayora. Ellos pueden ser complementados posteriormente con otros
artculos de mayor nivel destinados a gente ms experimentada.
La forma en la que hemos redactado este manual lo hace accesible a cualquier persona no familiarizada con la
programacin. Sin embargo, es posible que en determinados momentos alguien que no haya programado nunca pueda
verse un poco desorientado. Nuestro consejo es el de no querer entender todo antes de pasar al siguiente captulo sino
intentar asimilar algunos conceptos y volver atrs en cuanto una duda surja o hayamos olvidado algn detalle. Nunca
viene mal leer varias veces lo mismo hasta que quede bien grabado y asimilado.
Antes de comenzar a leer este manual es altamente aconsejable, sino imprescindible, haber ledo previamente el manual
sobre manual sobre pginas dinmicas en el cual se explica a grandes rasgos qu es el PHP, algunos conceptos tiles
sobre el modo de trabajar con pginas dinmicas al mismo tiempo que nos introduce algunos elementos bsicos de la
programacin como pueden ser las variables y las funciones.
Otra referencia a la cual haremos alusin es el tutorial de SQL que nos ser de gran ayuda para el tratamiento de bases
de datos y a MySQL, del que podremos aprender muchas cosas en el Taller de MySQL.
Para todos los lectores, pero aun ms para las personas ms inexpertas y con ms dificultades de aprendizaje, tenemos
adems una recomendacin que puede ayudarles mucho. Se trata del Videotutorial de PHP que estamos publicando
con diversos vdeos que explican con gran detalle la programacin en PHP.
Esperamos que este manual resulte de vuestro agrado y que corresponda a nuestras expectativas: El poder acercar PHP a
todos aquellos amantes del desarrollo de webs que quieren dar el paso hacia las webs "profesionales".
Los scripts que usamos en estos primeros ejemplos pueden ser descargados aqu.
Artculo por
Rubn Alvarez
Rubn Alvarez
Parte 2:
2.1.5.- Conclusin
En cualquier caso, para fines de desarrollo en local, podemos contentarnos en un principio de trabajar con cualquier
sistema. Solamente en casos de programacin realmente avanzada podremos confrontarnos con problemas relacionados
con el sistema operativo utilizado o el servidor en el que hacemos correr nuestras pginas. Hay que pensar tambin que,
en casos puntuales para los que nuestro PC pueda quedarse corto, podemos hacer directamente nuestras pruebas en el
servidor donde alojamos nuestro sitio el cual ser muy probablemente, como hemos dicho, un Unix o Linux
funcionando con Apache.
Referencia: En DesarrolloWeb hemos publicado diversos manuales y artculos que pueden ser una buena referencia para la instalacin
de PHP. Algunos se pueden ver a continuacin:
Artculo por
Rubn Alvarez
Existen dos formas de configurar PHP para trabajar con Apache, instalar como un mdulo o instalar como un CGI. En
este artculo vamos a ver cmo instalarlo com CGI, aunque disponemos de otro artculo para instalar PHP como mdulo
en Apache.
2.2.1.- Para instalar PHP como un CGI hay que seguir los siguientes pasos:
En primer lugar, hay que descargarse PHP desde la pgina de php.net. Existen dos versiones, una que tiene un
instalador, y otra que es un fichero ZIP. Hay que descargarse esta ltima.
Una vez descargado, hay que descomprimirlo dentro de una carpeta, esta no tiene que estar bajo el rbol de directorios
de Apache. El artculo asumir que se descomprime dentro de la carpeta C:PHP. Comprobar que los contenidos del
archivo ZIP no quedan en un subdirectorio de la carptea C:PHP, sino directamente en dicha carpeta.
Dentro de la carpeta c:PHP se encuentra un fichero llamado PHP4ts.dll, hay que mover el fichero dentro de la carpeta:
c:windowssystem c:winntsystem
En este fichero se encuentra toda la configuracin de PHP, y las modificaciones en la configuracin de PHP (mostrar
Errores, variables globales etc...) se encuentra dentro del mismo.
Es muy recomendable cambiar la directiva display_errors que por defecto esta en OFF, y pornerla en ON, para poder
ver los errores que se producen en las pginas durante el desarrollo. Para un servidor en produccin en conveniente
dejarla en OFF.
Una vez se han hecho estos cambios, queda indicarle al Apache, donde se encuentra instalado el PHP, para ello hay que
editar el fichero httpd.conf que se encuentra dentro de la carpeta conf, en la carpeta de instalacin del apache (por
defecto c:archivos de programaapache groupapache2conf)
Abrir el fichero, y situarse al final del mismo, y escribir las siguientes lneas:
ScriptAlias /php/ "c:/php/"
AddType application/x-httpd-php .php
Action application/x-httpd-php "/php/php.exe"
En ellas se indica donde se encuentra el ejecutable de php, y lo asocia a los ficheros .php que se encuentren dentro de
apache.
10
Luego lo guardamosdentro de la carpeta raz de documentos del Apache (por defecto c:archivos de programaapache
groupapache2htdocs ), con un nombre terminado en .php, por ejemplo info.php
Para ejecutarlo, a travs de un navegador, escribir la direccin http://localhost/info.php.
Debera aparecer una pantalla como la que se muestra a continuacin.
Si la vemos correctamente es que todo ha ido bien y que tenemos perfectamente instalado PHP en nuestro servidor
Apache.
Nota: Este tipo de instalacin de PHP sobre Apache es poco recomendada por motivos de seguridad. Podemos seguirla para configurar
PHP en local, con intencin de desarrollar nuestras pginas web, pero nunca si vamos a utilizar el servidor en un entorno de produccin,
es decir, en un servidor que se encuentre permanentemente conectado a Internet sirviendo pginas a todo tipo de usuarios.
Sera necesario instalar PHP como un mdulo de Apache, en lugar de CGI, para dotar al sistema de una mayor seguridad, y tambin ms
potencia.
Referencia: En esta FAQ damos otras opciones para la instalacin de PHP, utilizando programas que permiten instalar y configurar
Apache + PHP + MySQL en un sencillo paso, accesible para todos los usuarios: Cmo instalar PHP en Windows.
Artculo por
11
12
El lugar adecuado para aadir esas lneas es en el bloque de carga de mdulos, que podemos encontrar si buscamos por
el texto "LoadModule". Podemos aadir las lneas de carga del mdulo PHP despus de la carga de los otros mdulos
que vienen ya configurados en archivo httpd.conf de Apache.
Si no instalamos PHP en el directorio c:php, debemos editar las lneas a colocar en el httpd.conf para colocar la ruta
correcta al directorio donde est la librera php4apache2.dll.
Otra configuracin que podemos aplicar al archivo httpd.conf es definir tambin como documento por defecto el
archivo index.php en nuestro servidor Apache. El documento por defecto es generalmente index.html, pero lo
habitual si vamos a programar con PHP es que tambin necesitemos definir index.php como documento a
mostrar si no se indica otro documento del directorio al que se est accediendo.
El documento por defecto se define con la variable DirectoryIndex. Nos quedar una deninicin como esta:
DirectoryIndex index.html index.html.var index.php
Esta funcin simplemente crear una pgina de muestra de las configuraciones definidas para PHP en ese servidor.
Para acceder al archivo creado desde nuestro explorador, escribiremos en la barra de direcciones esta URL:
http://localhost/prueba.php
13
Referencia: En esta FAQ damos otras opciones para la instalacin de PHP, utilizando programas que permiten instalar y configurar
Apache + PHP + MySQL en un sencillo paso, accesible para todos los usuarios: Cmo instalar PHP en Windows.
Artculo por
Debe haber decenas de maneras de instalar Apache, PHP y MySQL sobre GNU/Linux y en Internet encontraremos una
gran cantidad de informacin a este respecto. Nosotros vamos a destacar una a continuacin que nos ha funcionado
siempre bien, con algunos detalles adicionales que nos pueden facilitar diversas labores de desarrollo en nuestros
sistemas. Adems, complementaremos la informacin comentando los pasos para instalar otra herramienta fundamental,
como es el PhpMyAdmin.
14
Conviene decir que esta receta la hemos obtenido del sitio web HowtoForge. Yo la he traducido libremente y la he
complementado con explicaciones adicionales y algunos pasos extra que he considerado de inters.
Como un primer paso, podemos lanzar un comando para obtener los privilegios de root para la administracin a travs
de la lnea de comandos.
sudo su
Nos pedir la clave de nuestro usuario, que es la misma clave que usamos al arrancar el equipo.
Durante el proceso de instalacin tendrs que introducir la clave que deseas configurar al usuario root de MySQL.
En este punto, una vez instalado Apache, puedes hacer una primera comprobacin, que nos permitir saber si el servidor
web est funcionado correctamente. Para ello abre un navegador cualquiera e introduce la URL de localhost o la IP
local de tu ordenador:
http://localhost
O bien:
http://192.168.0.55 (sustituye esa IP por la IP de tu mquina)
Nota: Si no sabes cul es tu IP de red local, tienes a tu disposicin en Linux el comando ifconfig.
Al acceder a cualquiera de esas dos URL debera salirte el mensaje de Apache diciendo que est funcionado (It works!)
Para tu informacin, el directorio predeterminado donde se guardan los documentos del servidor web en Apache es
/var/www y el fichero de configuracin del servidor est en /etc/apache2/apache2.conf. Otras configuraciones estn
almacenadas en otros subdirectorios de /etc/apache2 como /etc/apache2/mods-enabled para los mdulos habilitados,
/etc/apache2/sites-enabled para los "virtual hosts" y /etc/apache2/conf.d para las configuraciones globales que afectarn
a todos los virtual host.
Nota: Existe en DesarrolloWeb.com un manual sobre la instalacin de Apache en Windows, que no te ayudar mucho si ests en Linux,
pero que tiene mucha informacin sobre la configuracin de Apache. Te servir de ayuda puesto que la mayora de los archivos de
configuracin funcionan exactamente igual y las variables de configuracin son exactamente las mismas.
15
Despus de la instalacin de PHP5 como mdulo de Apache, debemos reiniciar el servidor web y para ello lanzamos
este otro comando.
/etc/init.d/apache2 restart
Como puedes ver, hacemos un "restart", pero tambin podras hacer primero un "stop" y luego un "start".
Llegado este punto, podemos crear ya un documento web que nos sirva para comprobar si PHP est correctamente
instalado en nuestro sistema y para ello podemos utilizar la lnea de comandos y el editor que prefieras. A algunas
personas les gusta el editor llamado Vi, pero yo soy de los que prefiere otros ms sencillos como el Joe.
Nota: Para conocer ms acerca del programa Joe, puedes visitar la FAQ: Sabis de una alternativa a Vi?
En cualquier caso, tendrs que crear un archivo en la ruta por defecto de publicacin del Apache, que ya dijimos es
/var/www. Puedes llamarle como desees, por ejemplo info.php, en el que colocars las siguientes lneas de cdigo.
<?php
phpinfo();
?>
Esa funcin de PHP phpinfo() te mostrar mucha informacin til sobre la instalacin de PHP que tienes en tu mquina,
como mdulos incluidos y diferentes configuraciones en funcionamiento.
Nota: para crear el archivo PHP tambin puedes utilizar el editor grfico que desees, que te ser incluso ms cmodo que cualquier
programa que trabaje con el terminal. El nico detalle es aplicarle los permisos necesarios a la carpeta /var/www para que sea propiedad
de tu usuario y puedas ciertas cosas con ella.
Ten en cuenta que ponerse como usuario dueo de la carpeta se recomienda solo sitios que no estn en produccin. Lo haras con el
comando:
sudo chown -R $USER:$USER /var/www
Si lo deseas, tambin puedes hacer el comando :
echo $USER
Para ver el nombre del usuario en el que ests y el que vas a poner como duelo de la carpeta /var/www .
Una vez creado el archivo de texto info.php con el cdigo indicado, podemos acceder a l desde un navegador
con una URL como esta:
http://localhost/info.php
Si ves toda una serie de informacin de tu instalacin PHP, como en la imagen anterior, es que has podido instalar PHP
en correctas condiciones.
16
Podrs encontrar el listado de extensiones de PHP disponibles en los repositorios, puedes elegir aquellos que desees e
instalarlos con la lnea:
apt-get install php5-mysql php5-curl php5-gd php-pear php5-imagick php5-sqlite php5-tidy php5-xmlrpc
php5-xsl
A continuacin debes reiniciar el servidor para que los cambios tengan efecto.
/etc/init.d/apache2 restart
Si refrescas la pgina del phpinfo() podrs encontrar los nuevos mdulos instalados.
Vers a continuacin una serie de preguntas, como tu servidor web. Una vez instalado puedes acceder al gestor por
medio de una URL como esta:
http://localhost/phpmyadmin/
2.4.7.- Conclusin
Con este proceso tendrs a tu disposicin todos los materiales para comenzar a desarrollar con PHP en tu Linux.
Simplemente sealar un detalle importante, que ya se apunt de refiln, pero que quiero remarcar. Es posible que en
esta instalacin de Apache y PHP quieras desarrollar sitios web y utilizar para programar dichos sitios un editor para
programadores con interfaz grfica como Komodo Edit o Eclipse. En este caso recuerda que, para editar o crear
archivos en la carpeta /var/www desde esos programas, tendrs que poner tu usuario como dueo de la carpeta, con
chown. Eso se explic en una nota anterior.
Referencia: Para optimizar la configuracin de tu Apache en Linux de una manera muy prctica para tu servidor de desarrollo, te
aconsejamos la lectura del artculo Configuracin de Apache en Linux con carpetas externas.
17
Instruccin
Show databases;
Descripcin
Muestra el conjunto de bases de datos
presentes en el servidor
Use nombre_de_la_base
Create Database
nombre_de_la_base;
Drop Database
nombre_de_la_base;
Show tables;
Describe
nombre_de_la_tabla;
Drop Table
nombre_de_la_tabla;
18
nombre_de_la_tabla;
Quit
Para evitarnos el tener que editar nuestras tablas directamente sobre archivos de texto, puede resultar muy prctico usar
cualquier otra base de datos con un editor y exportar a continuacin la tabla en un archivo de texto configurado para
dejar tabulaciones entre cada campo. Esto es posible en Access por ejemplo pinchando con el botn derecho sobre la
tabla que queremos convertir y eligiendo la opcin exportar. Una ventana de dialogo aparecer en la que elegiremos
guardar el archivo en tipo texto. El paso siguiente ser elegir un formato delimitado por tabulaciones sin cualificador de
texto.
Otra posibilidad que puede resultar muy prctica y que nos evita trabajar continuamente tecleando rdenes al estilo de
antao es servirse de programas en PHP o Perl ya existentes y descargables en la red. El ms popular sin duda es
phpMyAdmin. Este tipo de scripts son ejecutados desde un navegador y pueden ser por tanto albergados en nuestro
servidor o empleados en local para, a partir de ellos, administrar MySQL de una forma menos sufrida.
Asimismo, dentro del directorio bin de MySQL, podemos encontrar una pequea aplicacin llamada MySqlManager.
Se trata de una interface windows, ms agradable a la vista y al uso que la que obtenemos ejecutando el archivo mysql.
En este caso, las sentencias SQL deben realizarse sin el punto y coma final.
Artculo por
Rubn Alvarez
Agregar ruta de del directorio php y las extenciones en la opcion de Environment Variable de windows2003
19
7.
Configuracin en IIS
20
21
22
9. Probando PHP
Crear archivo index.php en C:Inetpubwwwroot
23
2. Abrir IE6 y poner la direccin http://localhost/index.php, si le da error verificar los pasos de la instalacin.
Si no da error saldra una pantalla con informacin sobre la versin de php.
Artculo por
Jorge Ramos
24
Parte 3:
Este ultimo modo est principalmente aconsejado a aquellos que tengan el valor de trabajar con Front Page ya que,
usando cualquier otro tipo de etiqueta, corremos el riesgo de que la aplicacin nos la borre sin ms debido a que se trata
de un cdigo incomprensible para ella.
El modo de funcionamiento de una pgina PHP, a grandes rasgos, no difiere del clsico para una pgina dinmica de
lado servidor: El servidor va a reconocer la extensin correspondiente a la pgina PHP (phtml, php, php4,...) y antes de
enviarla al navegador va a encargarse de interpretar y ejecutar todo aquello que se encuentre entre las etiquetas
correspondientes al lenguaje PHP. El resto, lo enviara sin ms ya que, asumir que se trata de cdigo HTML
absolutamente comprensible por el navegador.
Otra caracterstica general de los scripts en PHP es la forma de separar las distintas instrucciones. Para hacerlo, hay que
acabar cada instruccin con un punto y coma ";". Para la ultima expresin, la que va antes del cierre de etiqueta, este
formalismo no es necesario.
Incluimos tambin en este capitulo la sintaxis de comentarios. Un comentario, para aquellos que no lo sepan, es una
frase o palabra que nosotros incluimos en el cdigo para comprenderlo ms fcilmente al volverlo a leer un tiempo
25
Ejecutar script
Si usamos doble barra (//) o el smbolo # podemos introducir comentarios de una lnea. Mediante /* y */ creamos
comentarios multilnea. Por supuesto, nada nos impide de usar estos ltimos en una sola lnea.
No os preocupis si no comprendis el texto entre las etiquetas, todo llegar. Os adelantamos que las variables en PHP
se definen anteponiendo un smbolo de dlar ($) y que la instruccin echo sirve para sacar en pantalla lo que hay escrito
a continuacin.
Recordamos que todo el texto insertado en forma de comentario es completamente ignorado por el servidor. Resulta
importante acostumbrarse a dejar comentarios, es algo que se agradece con el tiempo.
Artculo por
Rubn Alvarez
Variables numricas
Almacenan cifras
Enteros
$entero=2002;
Real
$real=3.14159;
Variables alfanumricas
Almacenan textos compuestos de nmeros y/o cifras
26
$cadena="Hola amigo";
Tablas
Almacenan series de informaciones numricas y/o alfanumricas
$sentido[1]="ver";
$sentido[2]="tocar";
$sentido[3]="oir";
$sentido[4]="gusto";
$sentido[5]="oler";
Objetos
Se trata de conjuntos de variables y funciones asociadas. Presentan una
complejidad mayor que las variables vistas hasta ahora pero su utilidad es
ms que interesante.
A diferencia de otros lenguajes, PHP posee una gran flexibilidad a la hora de operar con variables. En efecto, cuando
definimos una variable asignndole un valor, el ordenador le atribuye un tipo. Si por ejemplo definimos una variable
entre comillas, la variable ser considerada de tipo cadena:
$variable="5"; //esto es una cadena
Sin embargo si pedimos en nuestro script realizar una operacin matemtica con esta variable, no obtendremos un
mensaje de error sino que la variable cadena ser asimilada a numrica:
<?
$cadena="5"; //esto es una cadena
$entero=3; //esto es un entero
echo $cadena+$entero
?>
Ejecutar script
Este script dar como resultado "8". La variable cadena ha sido asimilada en entero (aunque su tipo sigue siendo
cadena) para poder realizar la operacin matemtica. Del mismo modo, podemos operar entre variables tipo entero y
real. No debemos preocuparnos de nada, PHP se encarga durante la ejecucin de interpretar el tipo de variable necesario
para el buen funcionamiento del programa.
Sin embargo, en contraste, hay que tener cuidado en no cambiar maysculas por minsculas ya que, en este sentido,
PHP es sensible. Conviene por lo tanto trabajar ya sea siempre en maysculas o siempre en minsculas para evitar este
tipo de malentendidos a veces muy difciles de localizar.
Variables asignadas por referencia
En PHP tambin podemos asignar variables por referencia. En ese caso no se les asigna un valor, sino otra variable, de
tal modo que las dos varialbles comparten espacio en memoria para el mismo dato.
La notacin para asignar por referencia es colocar un "&" antes del nombre de la variable.
<?php
$foo = 'Bob'; // Asigna el valor 'Bob' a $foo
$bar = &$foo; // Referencia $foo va $bar.
$bar = "Mi nombre es $bar"; // Modifica $bar...
echo $foo; // $foo tambin se modifica.
echo $bar;
?>
Esto dar como resultado la visualizacin dos veces del string "Mi nombre es Bob". Algo como:
27
Artculo por
Rubn Alvarez
$a = "1";
//$a es una cadena
$a[0] = "f";
//Estamos editando el ndice de la cadena o forzando a array?
3.3.1.- Forzado
En cualquier caso, podemos forzar una variable para que cambie de tipo con la funcin setType().
setType($variable,"nuevo_tipo");
la funcin setType() actualiza el tipo de $variable a "nuevo_tipo" y devuelve un boleano indicando si hubo xito o no en
la conversin.
Entre "nuevo_tipo" tenemos:
"integer"
"double"
"string"
"array"
"object"
Tambin podemos hacer que una variable se comporte como un tipo determinado forzndola, de la misma manera a
como se hace en el lenguaje C.
$variable = "23";
$variable = (int) $variable;
Los forzados permitidos son:
28
Variable
Descripcin
Nos devuelve una cadena con la URL del script que est
siendo ejecutado. Muy interesante para crear botones
29
No todas estas variables estn disponibles en la totalidad de servidores o en determinadas versiones de un mismo
servidor. adems, algunas de ellas han de ser previamente activadas o definidas por medio de algn acontecimiento. As,
por ejemplo, la variable $HTTP_REFERER no estar definida a menos que el internauta acceda al script a partir de un
enlace desde otra pgina.
30
3.4.2.- $GLOBALS
Contiene una referencia a cada variable disponible en el espectro de las variables del script. Las llaves de esta matriz
son los nombres de las variables globales. $GLOBALS existe dese PHP 3.
$_SERVER
Variables definidas por el servidor web directamente relacionadas con el entorno en don el script se esta ejecutando.
Anloga a la antigua matriz $HTTP_SERVER_VARS (la cual est todava disponible, aunque no se use).
$_GET
Variables proporcionadas al script por medio de HTTP GET. Anloga a la antigua matriz $HTTP_GET_VARS (la cual
est todava disponible, aunque no se use).
$_POST
Variables proporcionadas al script por medio de HTTP POST. Anloga a la antigua matriz $HTTP_POST_VARS (la
cual est todava disponible, aunque no se use).
$_COOKIE
Variables proporcionadas al script por medio de HTTP cookies. Anloga a la antigua matriz $HTTP_COOKIE_VARS
(la cual est todava disponible, aunque no se use).
$_FILES
Variables proporcionadas al script por medio de la subida de ficheros via HTTP . Anloga a la antigua matriz
$HTTP_POST_FILES (la cual est todava disponible, aunque no se use). Vea tambin Subiendo ficheros por mtodo
POST para ms informacin.
$_ENV
Variables proporcionadas al script por medio del entorno. Anloga a la antigua matriz $HTTP_ENV_VARS (la cual est
todava disponible, aunque no se use).
$_REQUEST
Variables proporcionadas al script por medio de cuaquier mecanismo de entrada del usuario y por lo tanto no se puede
confiar en ellas. La presencia y el orden en que aparecen las variables en esta matriz es definido por la directiva de
configuracin variables_order. Esta matriz no tiene un anlogo en versiones anteriores a PHP 4.1.0. Vea tambin
import_request_variables().
$_SESSION
Variables registradas en la sesin del script. Anloga a la antigua matriz $HTTP_SESSION_VARS (la cual est todava
disponible, aunque no se use). Vea tambin la seccin Funciones para el manejo de sessiones para ms informacin.
Artculo por
Rubn Alvarez
31
Entonces, si queremos utilizar una variable global a la pgina dentro de una funcin, tenemos que especificar de alguna
manera que esa variable que vamos a utilizar es una global. Existen en PHP un par de maneras de utilizar variables
globales a la pgina dentro de una funcin. Son las siguientes:
Matriz GLOBALS
Existe un array en PHP llamado $GLOBALS, que guarda una referencia a todas las variables creadas de manera global
a la pgina. Es una matriz o array asociativo, de los que en lugar de ndices numricos utilizan ndices de texto, donde
cada ndice es el nombre que hemos dado a la variable y cada valor es el contenido de cada variable.
Supongamos que tenemos esta declaracin de variables globales a la pgina, es decir, fuera de cualquier funcin:
$mivariable = "pepe";
$otravariable = 1234;
Si queremos acceder a esas variables dentro de una funcin utilizando el array $GLOBALS tendramos este cdigo:
function mifuncion(){
//estoy dentro de la funcin, para aceder a las variables utilizo $GLOBALS
echo $GLOBALS["mivariable"];
echo $GLOBALS["otravariable"];
}
Como se puede ver, se accede al contenido de las variables globales con el array $GLOBALS, utilizando como ndices
de la matriz los nombres de variables que deseamos mostrar.
Esto imprimira por pantalla el texto "pepe1234", el valor de las dos variables uno detrs del otro.
Declaracin de uso de variables globales dentro de una funcin
Otra cosa que podemos hacer para acceder a variables globales dentro de una funcin es especificar al comienzo de
dicha funcin la lista de variables que vamos a utilizar dentro. Para especificar esas variables utilizamos la palabra
"global" seguida de la lista de variables que se van a utilizar del entorno global.
function mifuncion(){
global $mivariable, $otravariable
//con esa lnea dentro de la funcin, declaramos el uso de variables globales
echo $mivariable;
echo $otravariable;
}
Como vemos, con "global" se especifica que vamos a utilizar unas variables que fueron declaradas como globales a la
pgina. Una vez hecho esto, ya podemos acceder a esas variables globales como si estuvieran declaradas dentro de la
funcin.
Cualquier alteracin que hagamos a las variables dentro de la funcin permanecer cuando se haya salido de la funcin,
tanto si accedemos a travs del array $GLOBALS o declarando con "global" el uso de esas variables.
Artculo por
32
3.6.- Operadores
Lista descriptiva de los operadores ms frecuentemente utilizados
Las variables, como base de informacin de un lenguaje, pueden ser creadas, modificadas y comparadas con otras por
medio de los llamados operadores. En los captulos anteriores hemos utilizado en nuestros ejemplos algunos de ellos.
En este captulo pretendemos listar los ms importantes y as dar constancia de ellos para futuros ejemplos.
Suma
Resta
Multiplicacin
Divisin
Devuelve el resto de la
divisin
Referencia: El operador aritmtico que puede resultar ms desconocido para los lectores es el operador %. Explicamos con mayor
detenimiento su funcionamiento y un ejemplo en el que es til en el taller: Listas de elementos con colores alternos en PHP.
== Igualdad
!= Desigual
< Menor que
<= Menor igual que
> Mayor que
33
And
Or
No
++$variable
Aumenta de 1 el valor de
$variable
--$variable
$variable += 10
Suma 10 a $variable
$variable -= 10
Resta 10 a $variable
$variable .=
"aado"
Rubn Alvarez
34
Parte 4:
Arrays y cadenas
Nos detenemos para ver cmo son los arrays en PHP, la estructura de datos ms esencial
que existe. Adems aprenderemos a trabajar con cadenas en PHP.
En este caso este array cataloga sus elementos, comunmente llamados valores, por nmeros. Los nmeros del 1 al 5 son
por lo tanto las claves y los sentidos son los valores asociados. Nada nos impide emplear nombres (cadenas) para
clasificarlos. Lo nico que deberemos hacer es entrecomillarlos:
<?
$moneda["espana"]="Peseta";
$moneda["francia"]="Franco";
$moneda["usa"]="Dolar";
?>
Otra forma de definir idnticamente este mismo array y que nos puede ayudar para la creacin de arrays ms complejos
es la siguiente sintaxis:
<?
$moneda=array("espana"=> "Peseta","francia" => "Franco","usa" => "Dolar");
?>
Una forma muy practica de almacenar datos es mediante la creacin de arrays multidimensionales (tablas). Pongamos el
ejemplo siguiente: Queremos almacenar dentro de una misma tabla el nombre, moneda y lengua hablada en cada pas.
Para hacerlo podemos emplear un array llamado pas que vendr definido por estas tres caractersticas (claves). Para
crearlo, deberamos escribir una expresin del mismo tipo que la vista anteriormente en la que meteremos una array
dentro del otro. Este proceso de incluir una instruccion dentro de otra se llama anidar y es muy corriente en
programacin:
<?
$pais=array
(
"espana" =>array
(
35
Ejecutar script
Antes de entrar en el detalle de este pequeo script, comentemos algunos puntos referentes a la sintaxis. Como puede
verse, en esta secuencia de script, no hemos introducido punto y coma ";" al final de cada lnea. Esto es simplemente
debido a que lo que hemos escrito puede ser considerado como una sola instruccin. En realidad, somos nosotros
quienes decidimos cortarla en varias lneas para, as, facilitar su lectura. La verdadera instruccin acabara una vez
definido completamente el array y es precisamente ah donde hemos colocado el nico punto y coma. Por otra parte,
podis observar cmo hemos jugado con el tabulador para separar unas lneas ms que otras del principio. Esto tambin
lo hacemos por cuestiones de claridad, ya que nos permite ver qu partes del cdigo estn incluidas dentro de otras. Es
importante acostumbrarse a escribir de esta forma del mismo modo que a introducir los comentarios ya que la claridad
de los scripts es fundamental a la hora de depurarlos. Un poco de esfuerzo a la hora de crearlos puede ahorrarnos
muchas horas a la hora de corregirlos o modificarlos meses ms tarde.
Pasando ya al comentario del programa, como podis ver, ste nos permite almacenar tablas y, a partir de una simple
peticin, visualizarlas un determinado valor en pantalla.
Lo que es interesante es que la utilidad de los arrays no acaba aqu, sino que tambin podemos utilizar toda una serie de
funciones creadas para ordenarlos por orden alfabtico directo o inverso, por claves, contar el numero de elementos que
componen el array adems de poder movernos por dentro de l hacia delante o atrs.
Muchas son las funciones propuestas por PHP para el tratamiento de arrays, no vamos a entrar aqu en una descripcin
de las mismas. Slo incluiremos esta pequea tabla que puede ser complementada, si necesario, con la documentacin
que ya hemos mencionado.
Funcin
array_values (mi_array)
Descripcin
Lista los valores contenidos en mi_array
asort(mi_array) y
arsort(mi_array)
count(mi_array)
ksort(mi_array) y
krsort(mi_array)
list ($variable1,
$variable2...)=mi_array
36
next(mi_array), prev(mi_array), Nos permiten movernos por dentro del array con un
reset(mi_array) y end(mi_array) puntero hacia delante, atras y al principio y al final.
each(mi_array)
De gran utilidad es tambin el bucle foreach que recorre de forma secuencial el array de principio a fin.
Para complementar esta informacin resultar de gran inters el artculo Trabajo con tablas o arrays en PHP y para los
que prefieran la formacin en vdeo, recomendamos ver los videotutoriales sobre los arrays en PHP.
Artculo por
Rubn Alvarez
37
38
39
En arrays asociativos:
$estadios_futbol = array("Valencia" => "Mestalla","Real Sociedad" => "Anoeta");
$estadios_futbol["Barcelona"]= "Nou Camp";
Artculo por
40
Si queremos ver en pantalla el valor de una variable o bien un mensaje cualquiera usaremos la instruccin echo como ya
lo hemos visto anteriormente:
echo $cadena; //sacara "Esta es la informacin de mi variable"
Ejecutar script
Tambin podemos introducir variables dentro de nuestra cadena lo cual nos puede ayudar mucho en el desarrollo de
nuestros scripts. Lo que veremos no es el nombre, sino el valor de la variable:
<?
$a=55;
$mensaje="Tengo $a aos";
echo $mensaje; //El resultado es: "Tengo 55 aos"
?>
Ejecutar script
La pregunta que nos podemos plantear ahora es...Cmo hago entonces para que en vez del valor "55" me salga el texto
"$a"? En otras palabras, cmo se hace para que el smbolo $ no defina una variable sino que sea tomado tal cual. Esta
pregunta es tanto ms interesante cuanto que en algunos de scripts este smbolo debe ser utilizado por una simple razn
comercial (pago en dlares por ejemplo) y si lo escribimos tal cual, el ordenador va a pensar que lo que viene detrs es
una variable siendo que no lo es.
Pues bien, para meter ste y otros caracteres utilizados por el lenguaje dentro de las cadenas y no confundirlos, lo que
hay que hacer es escribir una contrabarra delante:
Carc
ter
$
Efecto en la cadena
Escribe dlar en la cadena
41
"
8/2
Escribe 8/2 y no 4 en la
cadena
Adems, existen otras utilidades de esta contrabarra que nos permiten introducir en nuestro documento HTML
determinados eventos:
Carc
ter
Efecto en la cadena
Cambiamos de lnea
Retorno de carro
Estos cambios de lnea y tabulaciones tienen nicamente efecto en el cdigo y no en el texto ejecutado por el navegador.
En otras palabras, si queremos que nuestro texto ejecutado cambie de lnea hemos de introducir un echo "<br>" y no
echo "n" ya que este ultimo slo cambia de lnea en el archivo HTML creado y enviado al navegador cuando la pgina
es ejecutada en el servidor. La diferencia entre estos dos elementos puede ser fcilmente comprendida mirando el
cdigo fuente producido al ejecutar este script:
<HTML>
<HEAD>
<TITLE>cambiolinea.php</TITLE>
</HEAD>
<BODY>
<?
echo "Hola, n sigo en la misma lnea ejecutada pero no en cdigo fuente.<br>Ahora cambio de lnea
ejecutada pero continuo en la misma en el cdigo fuente."
?>
</BODY>
</HTML>
Ejecutar script
Echar un vistazo al codigo fuente del navegador
42
Las cadenas pueden asimismo ser tratadas por medio de funciones de todo tipo. Veremos estas funciones ms adelante
con ms detalle. Tan slo debemos retener que existen muchas posibles acciones que podemos realizar sobre ellas:
Dividirlas en palabras, eliminar espacios sobrantes, localizar secuencias, remplazar caracteres especiales por su
correspondiente en HTML o incluso extraer las etiquetas META de una pgina web.
Artculo por
Rubn Alvarez
Parte 5:
Funciones en PHP
Las funciones son esenciales para poder realizar cdigo de calidad, tanto en PHP como
en muchos otros lenguajes de programacin. En estos captulos del Manual de PHP
aprenderemos a definir funciones, trabajar con parmetros y retornar valores.
43
Esta funcin podra ser llamada al principio de todas nuestras pginas de la siguiente forma:
$titulo="Mi web";
hacer_encabezado($titulo);
De esta forma automatizamos el proceso de creacin de nuestro documento. Podramos por ejemplo incluir en la
funcin otras variables que nos ayudasen a construir la etiquetas meta y de esta forma, con un esfuerzo mnimo,
crearamos los encabezados personalizados para cada una de nuestras pginas. De este mismo modo nos es posible crear
cierres de documento o formatos diversos para nuestros textos como si se tratase de hojas de estilo que tendran la
ventaja de ser reconocidas por todos los navegadores.
Por supuesto, la funcin ha de ser definida dentro del script ya que no se encuentra integrada en PHP sino que la hemos
creado nosotros. Esto en realidad no pone ninguna pega ya que puede ser incluida desde un archivo en el que iremos
almacenando las definiciones de las funciones que vayamos creando o recopilando.
Estos archivos en los que se guardan las funciones se llaman libreras. La forma de incluirlos en nuestro script es a
partir de la instruccin require o include:
require("libreria.php") o include("libreria.php")
En resumen, la cosa quedara as:
Tendramos un archivo libreria.php como sigue
<?
//funcin de encabezado y colocacin del titulo
function hacer_encabezado($titulo)
{
$encabezado="<html>n<head>nt<title>$titulo</title>n</head>n";
echo $encabezado;
}
?>
Por otra parte tendramos nuestro script principal pgina.php (por ejemplo):
<?
include("libreria.php");
$titulo="Mi Web";
hacer_encabezado($titulo);
?>
<body>
El cuerpo de la pgina
</body>
</html>
Ejecutar script
Echar un vistazo al codigo fuente del navegador
Podemos meter todas las funciones que vayamos encontrando dentro de un mismo archivo pero resulta muchsimo ms
ventajoso ir clasificndolas en distintos archivos por temtica: Funciones de conexin a bases de datos, funciones
comerciales, funciones generales, etc. Esto nos ayudara a poder localizarlas antes para corregirlas o modificarlas, nos
permite tambin cargar nicamente el tipo de funcin que necesitamos para el script sin recargar ste en exceso adems
de permitirnos utilizar un determinado tipo de librera para varios sitios webs distintos.
Tambin puede resultar muy prctico el utilizar una nomenclatura sistemtica a la hora de nombrarlas: Las funciones
comerciales podran ser llamadas com_loquesea, las de bases de datos bd_loquesea, las de tratamiento de archivos
file_loquesea. Esto nos permitir reconocerlas enseguida cuando leamos el script sin tener que recurrir a nuestra
oxidada memoria para descubrir su utilidad.
No obstante, antes de lanzarnos a crear nuestra propia funcin, merece la pena echar un vistazo a la documentacin
para ver si dicha funcin ya existe o podemos aprovecharnos de alguna de las existentes para aligerar nuestro trabajo.
As, por ejemplo, existe una funcin llamada header que crea un encabezado HTML configurable lo cual nos evita tener
44
La manera de realizar esta funcin ser recorrer el string, caracter a caracter, para imprimir cada uno de los caracteres,
seguido de el signo "-". Recorreremos el string con un bucle for, desde el carater 0 hasta el nmero de caracteres total de
la cadena.
El nmero de caracteres de una cadena se obtiene con la funcin predefinida en PHP strlen(), que recibe el string entre
parntesis y devuelve el nmero de los caracteres que tenga.
<html>
<head>
<title>funcion 1</title>
</head>
<body>
<?
function escribe_separa($cadena){
for ($i=0;$i<strlen($cadena);$i++){
echo $cadena[$i];
if ($i<strlen($cadena)-1)
echo "-";
}
}
escribe_separa ("hola");
echo "<p>";
escribe_separa ("Texto ms largo, a ver lo que hace");
?>
</body>
</html>
La funcin que hemos creado se llama escribe_separa y recibe como parmetro la cadena que hay que escribir con el
separador "-". El bucle for nos sirve para recorrer la cadena, desde el primer al ltimo carcter. Luego, dentro del bucle,
se imprime cada carcter separado del signo "-". El if que hay dentro del bucle for comprueba que el actual no sea el
ltimo carcter, porque en ese caso no habra que escribir el signo "-" (queremos conseguir "h-o-l-a" y si no estuviera el
if obtendramos "h-o-l-a-").
En el cdigo mostrado se hacen un par de llamadas a la funcin para ver el resultado obtenido con diferentes cadenas
como parmetro. Podemos ver el script en marcha.
Artculo por
Rubn Alvarez
45
As definimos una funcin llamada f1 que recibe dos parmetros. Como se puede observar, no se tiene que definir el
tipo de datos de cada parmetro.
Los parmetros tienen validez durante la ejecucin de la funcin, es decir, tienen un mbito local a la funcin donde se
estn recibiendo. Cuando la funcin se termina, los parmetros dejan de existir.
Los parmetros se pasan por valor
El paso de parmetros en PHP se realiza por valor. "Por valor" es una manera tpica de pasar parmetros en funciones,
quiere decir que el cambio de un dato de un parmetro no actualiza el dato de la variable que se pas a la funcin. Por
ejemplo, cuando invocamos una funcin pasando una variable como parmetro, a pesar de que cambiemos el valor del
parmetro dentro de la funcin, la variable original no se ve afectada por ese cambio. Puede que se vea mejor con un
ejemplo:
function porvalor ($parametro1){
$parametro1="hola";
echo "<br>" . $parametro1; //imprime "hola"
}
$mivariable = "esto no cambia";
porvalor ($mivariable);
echo "<br>" . $mivariable; //imprime "esto no cambia"
46
Para la definicin de funcin anterior, $parametro1 tiene como valor por defecto "pepe", mientras que $parametro2
tiene 3 como valor por defecto.
Si llamamos a la funcin sin indicar valores a los parmetros, estos tomarn los valores asignados por defecto:
pordefecto () // $parametro1 vale "pepe" y $parametro2 vale 3
Si llamamos a la funcin indicando un valor, este ser tenido en cuenta para el primer parmetro.
pordefecto ("hola") // $parametro1 vale "hola" y $parametro2 vale 3
Atencin, estamos obligados a declarar todos los parmetros con valores por defecto al final.
Artculo por
47
Si se han entendido bien los conceptos, este ejemplo no puede resultar difcil. La funcin recibe un parmetro llamado
$porcentaje con 16 como valor por defecto. Devuelve el porcentaje dado aplicado a la base tambin indicada por
parmetro.
As pues, en la primera ejecucin de la funcin, como no se indica el porcentaje, se mostrar el 16% de 1000. En la
segunda, se muestra el 7% de mil y en la tercera, el 0% de 10.
Puede verse el resultado en una pgina aparte. http://www.desarrolloweb.com/articulos/ejemplos/php/ej_iva.php
Retornar mltiples valores
Una funcin devuelve un nico valor. Si queremos hacer que se puedan devolver varios valores distintos tenemos que
recurrir a un truco que consiste en devolver un array.
function small_numbers()
{
return array (0, 1, 2);
}
list ($zero, $one, $two) = small_numbers();
list() se usa para asignar una lista de variables en una sola operacin. Despus de esa operacin, $zero valdr 0, $one
valdr 1 y $two valdr 2.
Artculo por
48
Parte 6:
Estructuras de
control en PHP
Vemos una a una las distintas estructuras de control del flujo de los programas
disponibles en el lenguaje de programacin PHP: condicionales y bucles.
1;
2;
A;
B;
Llegados a este punto, el programa verificar el cumplimiento o no de la condicin. Si la condicin es cierta las
49
De este modo podramos introducir tantas condiciones como queramos dentro de una condicin principal.
De gran ayuda es la instruccin elseif que permite en una sola lnea introducir una condicin adicional. Este tipo de
instruccin simpifica ligeramente la sintaxis que acabamos de ver:
if (condicin1)
{
Instruccin 1;
Instruccin 2;
...
}
elseif (condicin2)
{
Instruccin A;
Instruccin B;
...
}
else
{
Instruccin X
...
}
El uso de esta herramienta resultar claro con un poco de prctica. Pongamos un ejemplo sencillo de utilizacin de
condiciones. El siguiente programa permitira detectar la lengua empleada por el navegador y visualizar un mensaje en
dicha lengua.
<HTML>
<HEAD>
<TITLE>Detector de Lengua</TITLE>
</HEAD>
<BODY>
<?
//Antes de nada introducimos mensajes en forma de variables
$espanol="Hola";
$ingles="Hello";
$frances="Bonjour";
//Ahora leemos del navegador cul es su lengua oficial
$idioma=substr($HTTP_ACCEPT_LANGUAGE,0,2);
//Formulamos las posibilidades que se pueden dar
if ($idioma == "es")
50
Ejecutar script
Para poder ver el funcionamiento de este script es necesario cambiar el idioma preferido lo cual puede ser realizado a
partir del men de opciones del navegador.
Para leer la lengua aceptada por el navegador lo que hacemos es definir una variable ($idioma) y, mediante la funcin
substr, recogemos las dos primeras letras del cdigo correspondiente al idioma aceptado por el navegador
($HTTP_ACCEPT_LANGUAGE).
La tercera parte de script se encarga de ver si el navegador est en espaol (es), francs (fr) o en cualquier otro idioma
que no sea ninguno de estos dos y de imprimir el mensaje que proceda en cada caso.
A notar que, cuando se trata de comparar variables, ponemos un doble igual "==" en lugar de un simple "=". Este ltimo
queda reservado exclusivamente para asignar valores a variables
Referencia: Hemos publicado un vdeo para mostrar la creacin y el funcionamiento de las estructuras IF: Estructuras de control, Vdeo
1: condicional if
Artculo por
Rubn Alvarez
Un ejemplo sencillo es este bucle que aumenta el tamao de la fuente en una unidad a cada nueva vuelta por el bucle:
<?
$size=1;
While ($size<=6)
{
echo"<font size=$size>Tamao $size</font><br>n";
51
Ejecutar script
A modo de explicacin, diremos que, antes de nada, hemos de definir el valor de la variable que vamos a evaluar en la
condicin. Algo absolutamente obvio pero fcil de olvidar. En este caso le hemos atribuido un valor de 1 que
corresponde a la letra ms pequea.
El paso siguiente es crear el bucle en el que imponemos la condicin que la variable no exceda el valor de 6.
La instruccin a ejecutar ser imprimir en nuestro documento un cdigo HTML en el que la etiqueta font y el mensaje
que contiene varan a medida que $size cambia su valor.
El siguiente paso es incrementar en una unidad el valor de $size. Esto se puede hacer con una expresin como la
mostrada en el bucle ($size++) que en realidad es sinnima de:
$size=$size+1
Veremos otras de estas abreviaciones ms adelante.
En este ejemplo se define una cadena con el valor "hola a todo el mundo". Posteriormente se recorre esa cadena hasta el
final de la cadena o hasta encontrar el caracter "m", utilizando una variable $i que lleva la cuenta de los caracteres
recorridos.
Al final del bucle while, si se sali porque se encontr el caracter "m", la variable $i valdr un nmero menor que la
longitud de la cadema. Si se sali por llegar al final de la cadena, la variable $i valdr lo mismo que la longitud en
caracteres de esa cadena. En el condicional simplemente se comprueba si $i vale o no lo mismo que la longitud de la
cadena, mostrando los mensajes adecuados en cada caso.
Podemos ver el ejemplo en funcionamiento.
52
instruccion1;
instruccion2;
...
}
while (condicin)
La diferencia con respecto a los bucles while es que este tipo de bucle evala la condicin al final con lo que, incluso
siendo falsa desde el principio, ste se ejecuta al menos una vez.
Referencia: Para una ayuda prctica sobre estos bucles ver el siguiente videotutorial Estructuras de control, Vdeo 2: bucles for, while y
do-while. Adems, las explicaciones sobre estructuras de control se complementan con el videotutorial de Switch y las instrucciones
break y continue.
Artculo por
Rubn Alvarez
Ejecutar script
Las expresiones dentro del parntesis definen respectivamente:
-Inicializacin de la variable. Valida para la primera vuelta del bucle.
-Condicin de evaluacin a cada vuelta. Si es cierta, el bucle continua.
-Accin a realizar al final de cada vuelta de bucle.
53
;
}
Un ejemplo prctico es la lectura de un array lo cual podra hacerse del siguiente modo:
<?
$moneda=array("Espaa"=> "Peseta","Francia" => "Franco","USA" => "Dolar");
Foreach ($moneda as $clave=>$valor)
{
echo "Pais: $clave Moneda: $valor<br>";
}
?>
Ejecutar script
Este script se encargara de mostrarnos por pantalla el contenido del array $moneda. No resultara mala idea crear una
funcin propia basada en este bucle que nos permitiese visualizar arrays monodimensionales y almacenarla en nuestra
librera. Esta funcin podra ser definida de esta forma:
Function mostrar_array ($array)
{
Foreach ($array as $clave=>$valor)
{echo "$clave=>$valor<br>";}
}
Artculo por
Rubn Alvarez
54
Parte 7:
Aplicaciones web:
paso de variables y
memoria de
estados
En los siguientes captulos veremos diversas maneras que existen en PHP para conseguir
que un conjunto de pginas y scripts se comporten como una aplicacin web. Veremos
cmo pasar datos de unas pginas a otras, por POST y GET, cmo memorizar datos
asociados a un usuario a lo largo de toda la sesin y cmo memorizar datos en cookies,
que perdurarn entre varias sesiones.
55
Para aclarar posibles dudas, veamos esto en forma de ejemplo. Tendremos pues dos pginas, origen.html (no es
necesario darle extensin PHP puesto que no hay ningn tipo de cdigo) y destino.php:
<HTML>
<HEAD>
<TITLE>origen.html</TITLE>
</HEAD>
<BODY>
<a href="destino.php?saludo=hola&texto=Esto es una variable texto">Paso variables saludo y texto a
la pgina destino.php</a>
</BODY>
</HTML>
<HTML>
<HEAD>
<TITLE>destino.php</TITLE>
</HEAD>
<BODY>
<?
echo "Variable $saludo: $saludo <br>n";
echo "Variable $texto: $texto <br>n"
?>
</BODY>
</HTML>
Ejecutar ejemplo
7.1.2.- $HTTP_GET_VARS
Recordamos que es posible recopilar en una variable tipo array el conjunto de variables que han sido enviadas al script
por este mtodo a partir de la variable de sistema $HTTP_GET_VARS, que es un array asociativo. Utilizndolo
quedara as:
<?
echo "Variable $saludo: $HTTP_GET_VARS["saludo"] <br>n";
echo "Variable $texto: $HTTP_GET_VARS["texto"] <br>n"
?>
Nota: Aunque podamos recoger variables con este array asociativo o utilizar directamente las variables que se definen en nuestra pgina,
resulta ms seguro utilizar $HTTP_GET_VARS por dos razones, la primera que as nos aseguramos que esa varible viene realmente de
la URL y la segunda, que as nuestro cdigo ser ms claro cuando lo volvamos a leer, porque quedar especificado que esa variable
estamos recibindola por la URL.
7.1.3.- $_GET
A partir de la versin 4.1.0 de PHP se ha introducido el array asociativo $_GET, que es idntico a $HTTP_GET_VARS,
aunque un poco ms corto de escribir.
56
Artculo por
Rubn Alvarez
Ejecutar ejemplo
7.2.1.- $HTTP_POST_VARS
Recordamos que es posible recopilar en una variable tipo array el conjunto de variables que han sido enviadas al script
57
7.2.2.- $_POST
A partir de PHP 4.1.0 se pueden recoger las variables de formulario utilizando tambin el array asociativo $_POST, que
es el mismo que $HTTP_POST_VARS, pero ms corto de escribir.
Esta es una pgina sin ningn cdigo PHP, simplemente tiene un formulario. Fijmonos en el action del formulario, que
est dirigido hacia una pgina llamada edad2.php, que es la que recibir el dato de la edad y mostrar un contenido u
otro dependiendo de ese valor. Su cdigo es el siguiente:
<html>
<head>
<title>Restringir por edad</title>
</head>
<body>
<?
$edad = $_POST["edad"];
echo "Tu edad: $edad<p>";
if ($edad < 18) {
echo "No puedes entrar";
}else{
echo "Bienvenido";
}
?>
</body>
</html>
58
Rubn Alvarez
Comentarios
Variables y tipos
Operadores, aritmticos, de cadena, comparacin, asignacin
Estructuras de control para toma de decisiones
Bucles
59
*/
Esto es un comentario
de muchas
lneas
$contador = 5 + 5;
$contador = $contador + 10;
echo $contador;
// estructuras de control
$edad = 34;
if($edad < 18){
echo "Si es menor de 18";
}
// repeticiones o bucles
while($contador < 100){
// todo esto se repetir
echo "contador vale " . $contador;
echo "<br>";
$contador = $contador + 7;
}
?>
</body>
</html>
60
Toda la parte de PHP se queda simplemente en la recepcin de los datos de ese formulario y su procesamiento, que en
este ejemplo se realiz en una pgina y archivo aparte. El procesamiento que se implement es muy sencillo,
simplemente para darnos cuenta de que bsicamente con PHP podemos acceder a los datos del formulario de una
manera muy sencilla, a travs de los arrays $_POST y mencionando sus "hermanos" $_GET o $_REQUEST.
El ejemplo es muy simple, aunque poco a poco fuimos complicando un poco para introducir diversos mtodos de
integrar cdigo PHP en una pgina HTML, por lo que el listado a continuacin puede parecer un poco complejo en un
primer vistazo, aunque en la clase se explica todo perfectamente y paso a paso.
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>recibo datos del form</title>
</head>
<body>
<?php
//recibo
$nombre_usuario = $_POST["nombre"];
$edad_usuario = $_POST["edad"];
//valido los datos
//echo "Hola " . $nombre_usuario . " tu edad es " . $edad_usuario;
// toma de decisin en funcin de la edad
if($edad_usuario >= 18){
?>
<div style="color: blue;">
<b>
<?php
echo "Hola $nombre_usuario, como tu edad es $edad_usuario, puedes ver este contenido!!";
?>
</b></div>
<?php
}else{
//parte negativa
echo '<span style="color: red;">';
echo "Lo siento $nombre_usuario, no puedes ver esta pgina!!! Adis!";
echo "</span>";
}
?>
</body>
</html>
61
Artculo por
62
En el ejemplo, el primer paso es conocer si se estn recibiendo o no datos por un formulario. Para ello se comprueba
con un enunciado if si existe o no una variable $_POST.
En concreto if (!$_POST) querra decir algo como "Si no existen datos venidos de un formulario". En caso de que no
existan, muestro el formulario. En caso de que s existan, recojo los datos y los imprimo en la pgina.
Se puede ver el ejemplo en funcionamiento en una pgina aparte.
Para paso de variables por URL
La idea es la misma. Comprobar con un enunciado if si se reciben o no datos desde una URL. Veamos el cdigo a
continuacin. Se trata de una pgina que muestra una serie de enlaces para ver las tablas de multiplicar de el 1 hasta el
10. Cada uno de los enlaces muestra una tabla de multiplicar. Pulsando el primer enlace podemos ver la tabla del 1,
pulsando el segundo la tabla del 2, etc.
Recordemos que la pgina se llama a si misma. Para comprenderla ms fcilmente ser interesante verla en
funcionamiento.
<html>
<head>
</head>
<title>Tablas de multiplicar</title>
<body>
<?
if (!$_GET){
for ($i=1;$i<=10;$i++){
echo "<br><a href='ver_tabla.php?tabla=$i'>Ver la tabla del $i</a>\n";
}
} else {
$tabla=$_GET["tabla"];
?>
<table align=center border=1 cellpadding="1">
<?
for ($i=0;$i<=10;$i++){
echo "<tr><td>$tabla X $i</td><td>=</td><td>" . $tabla * $i . "</td></tr>\n";
}
?>
</table>
<?
}
?>
</body>
</html>
Este cdigo es un poco ms complicado, porque hace un poco ms de cosas que el anterior, pero para el asunto que nos
ocupa que es la autollamada de pginas, todo sigue igual de simple.
Hay que fijarse en el if que comprueba si se reciben o no datos por URL: if (!$_GET), que querra decir algo como "Si
no se reciben variables por la URL".
En caso positivo (no se reciben datos por URL) se muestran los enlaces para ver cada una de las tablas y en caso de que
s se reciban datos, se muestra la tabla de multiplicar del nmero que se est recibiendo en la URL.
Para hacer para mostrar los enlaces y las tablas de multiplicar se utilizan bucles for, que esperamos que no resulten
desconocidos para el lector. Puede conocerse algo ms sobre los bucles for en Control del flujo en PHP: Bucles II.
63
Es posible, por supuesto, ver estos archivos. Para abrirlos hay que ir al directorio C:WindowsCookies para los usuarios
de IE 4+ o a C:...NetscapeUsersdefaultuser para usuarios de Netscape. Como podris comprobar, en la mayora de los
casos la informacin que se puede obtener es indescifrable.
La utilidad principal de las cookies es la de poder identificar al navegador una vez ste visita el sitio por segunda vez y
as, en funcin del perfil del cliente dado en su primera visita, el sitio puede adaptarse dinmicamente a sus preferencias
(lengua utilizada, colores de pantalla, formularios rellenados total o parcialmente, redireccin a determinadas
pginas...).
Para crear cookies con PHP, modificar o generar una nueva cookie lo podemos hacer a partir de la funcin SetCookie:
setcookie("nombre_de_la_cookie",valor,expiracion);
Pongamos un ejemplo sencillo. Imaginemos que queremos introducir en una variable cookie el nombre del visitante. El
nombre ha podido ser previamente recogido por un formulario tal y como hemos visto:
setcookie("persona",$nombre,time()+86400*365);
De este modo hemos creado una cookie php llamada persona que tiene como valor el contenido de la variable $nombre
y tendr una duracin de 1 ao a partir de su creacin (el tiempo time() actual en segundos sumado a un ao en
segundos).
Es importante que la creacin de la cookie sea previa a la apertura del documento HTML. En otras palabras, las
llamadas a la funcin setcookie() deben ser colocadas antes de la etiqueta HTML.
Por otra parte, es interesante sealar que el hecho de que definir una cookie ya existente implica el borrado de la
antigua. Del mismo modo, el crear una primera cookie conlleva la generacin automtica del archivo texto.
Para utilizar el valor de la cookie en nuestros scripts tan slo tendremos que llamar la variable que define la cookie.
Realmente sencillo!
Hay que tener cuidado sin embargo de no definir variables en nuestro script con el mismo nombre que las cookies
puesto que PHP privilegiar el contenido de la variable local con respecto a la cookie y no dar un mensaje de error.
Esto nos puede conducir a errores realmente difciles de detectar.
Recordamos que es posible recopilar en una variable tipo array el conjunto de cookies almacenadas en el disco duro del
internauta mediante la variable de servidor $HTTP_COOKIE_VARS
Las cookies son una herramienta fantstica para personalizar nuestra pgina pero hay que ser cautos ya que, por una
parte, no todos los navegadores las aceptan y por otra, se puede deliberadamente impedir al navegador la creacin de
cookies. Es por ello que resultan un complemento y no una fuente de variables infalible para nuestro sitio. Como has
podido ver, las Cookies son muy sencillas de utilizar en PHP.
Puedes profundizar ms en la creacin de cookies en el siguiente articulo: Cookies en PHP. Adems, tambin te
64
Rubn Alvarez
65
Pero atencin en un asunto: Para enviar una cookie al navegador se debe hacer antes de haber enviado las cabeceras del
http al cliente, es decir, antes de haber escrito cualquier texto en la pgina. Si no, PHP podr lanzar un error de headers
already sent (cabeceras ya enviadas).
Recuperar cookies con PHP
Por otra parte, para recibir las cookies que el navegador del usuario pueda tener creadas en el sistema se utiliza el array
asociativo $_COOKIE. En este array estn todas las cookies que tiene disponible la pgina PHP en el dominio y el
directorio donde est colocado.
Por medio del nombre de la cookie accedemos a su valor:
$_COOKIE["migalleta"];
$_COOKIE["cookie2"];
Para ver un ejemplo de uso de cookies PHP acceder al taller de PHP Estilos CSS distintos a una pgina con PHP y
cookies o al Videotutorial sobre las Cookies en PHP.
Artculo por
7.7.- Sesiones I
Nos introducimos al concepto de sesin y aprendemos su manejo y funcionamiento.
En los programas que hemos visto hasta ahora, hemos utilizado variables que slo existan en el archivo que era
ejecutado. Cuando cargbamos otra pgina distinta, los valores de estas variables se perdan a menos que nos
tomsemos la molestia de pasarlos por la URL o inscribirlos en las cookies o en un formulario para su posterior
explotacin. Estos mtodos, aunque tiles, no son todo lo prcticos que podran en determinados casos en los que la
variable que queremos conservar ha de ser utilizada en varios scripts diferentes y distantes los unos de los otros.
Podramos pensar que ese problema puede quedar resuelto con las cookies ya que se trata de variables que pueden ser
invocadas en cualquier momento. El problema, ya lo hemos dicho, es que las cookies no son aceptadas ni por la
totalidad de los usuarios ni por la totalidad de los navegadores lo cual implica que una aplicacin que se sirviera de las
cookies para pasar variables de un archivo a otro no sera 100% infalible. Es importante a veces pensar en "la inmensa
minora", sobre todo en aplicaciones de comercio electrnico donde debemos captar la mayor cantidad de clientes
posibles y nuestros scripts deben estar preparados ante cualquier eventual deficiencia del navegador del cliente.
Nos resulta pues necesario el poder declarar ciertas variables que puedan ser reutilizadas tantas veces como queramos
dentro de una misma sesin. Imaginemos un sitio multilinge en el que cada vez que queremos imprimir un mensaje en
cualquier pgina necesitamos saber en qu idioma debe hacerse. Podramos introducir un script identificador de la
lengua del navegador en cada uno de los archivos o bien declarar una variable que fuese valida para toda la sesin y que
tuviese como valor el idioma reconocido en un primer momento.
Pensemos tambin en un carrito de la compra de una tienda virtual donde el cliente va navegando por las pginas del
sitio y aadiendo los artculos que quiere comprar a un carrito. Este carrito podra ser perfectamente una variable de tipo
array (tabla) que almacena para cada referencia la cantidad de artculos contenidos en el carrito. Esta variable debera
66
Rubn Alvarez
67
Nota: Si en el php.ini se ha definido la variable session.auto_start = 1 se inicializa automticamente la sesin en cada pgina que visita
un usuario, sin que se tenga que hacer el session_start()
Una vez inicializada la sesin con session_start() podemos a partir de ahora utilizar variables de sesin, es decir,
almacenar datos para ese usuario, que se conserven durante toda su visita o recuperar datos almacenados en pginas que
haya podido visitar.
La sesin se tiene que inicializar antes de escribir cualquier texto en la pgina. Esto es importante y de no hacerlo as
corremos el riesgo de recibir un error, porque al iniciar la sesin se deben leer las cookies del usuario, algo que no se
puede hacer si ya se han enviado las cabeceras del HTTP.
Nota: si se intenta abrir una sesin despus de haber enviado texto de la pgina al cliente se obtendr el siguiente mensaje:
Warning: session_start(): Cannot send session cache limiter - headers already sent (output started at )
Una vez iniciada la sesin podemos utilizar variables de sesin a travs de $_SESSION, que es un array asociativo,
donde se accede a cada variable a partir de su nombre, de este modo:
$_SESSION["nombre_de_variable"]
Nota: $_SESSION es una variable global que existe a partir de PHP 4.1.0. Lo normal es que podamos acceder a esa variable
normalmente, pero si nuestra versin de PHP no est actualizada podemos intentarlo con $HTTP_SESSION_VARS, que es tambin un
array asociativo, aunque no es de mbito global. Si $HTTP_SESSION_VARS tampoco funciona tendremos que registrar cada variable
por separado con la funcin session_register(), envindo por parmetro los nombres de las variables de sesin que desea utilizar desde
PHP.
Existen otras dos configuraciones del php.ini que afectan al trabajo con variables de sesin, que son track_vars y
register_globals. Por defecto track_vars est activado y register_globals est desactivado. Este es el caso normal y el
que suponemos tendr el servidor donde programes, pero si esas variables cambian podra cambiar alguna cosita, como
que las variables se tengan que registrar explcitamente con session_register().
Ejemplo de cdigo para definir una variable de sesin:
<?
session_start();
?>
<html>
<head>
<title>Generar variable de sesin</title>
</head>
<body>
<?
$_SESSION["mivariabledesesion"] = "Hola este es el valor de la variable de sesin";
?>
</body>
</html>
Como se puede ver, es importante inicializar la sesin antes de hacer otra cosa en la pgina. Luego podremos definir
variables de sesin en culquier lugar del cdigo PHP de la pgina.
Para leer una variable de sesin se hace a travs del mismo array asociativo $_SESSION. Es tan sencillo como
haramos para utilizar cualquier otra variable, lo nico es que tenemos que haber inicializado la sesin previamente. Y
por supuesto, que la variable que deseamos acceder exista previamente.
<?
session_start();
?>
<html>
<head>
<title>Leo variable se sesin</title>
</head>
<body>
Muestro esa variable:
<?
68
Como se puede ver, al inicio del cdigo hemos inicializado la sesin y luego en cualquier parte del cdigo podramos
acceder a las variables de sesin que tuvisemos creadas.
Nota: si intentamos acceder a una variable de sesin con $_SESSION que no ha sido creada obtendremos otro mensaje de error: Notice:
Undefined index: mivariabledesesion, que es el mismo que si intentamos acceder a cualquier elemento de un array que no existe.
Ejecutar script
La condicin if tiene en cuenta la posibilidad de que la variable $contador no haya sido todava inicializada. La funcin
isset se encarga de dar un valor cero cuando una variable no ha sido inicializada.
69
Funcin
Session_id()
Session_destroy()
Descripcin
Nos devuelve el identificador de la sesin
Da por abandonada la sesin eliminando variables e
identificador.
Session_unregister('variabl
Abandona una variable sesin
e')
Para aprender ms sobre las sesiones, concretamente para ver una aplicacin que gestiona un carrito de compra por
medio de variables sesin visita nuestro articulo del taller de PHP.
Si buscas ms funciones o informacin adicional sobre las sesiones, consulta el manual oficial de PHP.
Artculo por
Rubn Alvarez
Parte 8:
Bases de datos en
PHP
Entramos en una de las partes ms interesantes del manual de PHP, con los captulos que
tratan las bases de datos. Trabajaremos con MySQL y mostraremos cmo hacer todas las
operaciones tpicas con una base de datos, como acceso a registros, insercin,
modificacin y borrado.
70
8.1.1.- Configurar la base de datos que vamos a utilizar para los ejemplos de este
manual
Una vez instalado MySQL y antes de poder comenzar con nuestros ejemplos, ser necesario llevar a cabo las siguientes
operaciones:
-Introducidos dentro de MySQL, crearemos la base de datos ejemplo con la siguiente sentencia:
create database ejemplo;
Ahora ya disponemos de nuestra tabla vaca. Slo queda comenzar a llenarla con los datos que iremos insertando.
El conjunto de scripts utilizados para el bloque de bases de datos puede ser descargado aqu.
Insercin de registros
Seleccin de registros
Actualizacin de registros
Borrado de registros
71
Rubn Alvarez
Llegados a la pgina destino del formulario (insertar.php), lo primero que habr que hacer es establecer un vnculo entre
el programa y la base de datos. Esta conexin se lleva a cabo con la funcin mysql_connect. A continuacin, deberemos
generar una orden de insercin del registro en lenguaje SQL. Esta orden ser ejecutada por medio de la funcin
mysql_db_query. En esta funcin especificaremos primeramente la base de datos sobre la que queremos actuar y a
continuacin introduciremos la sentencia SQL:
<HTML>
<HEAD>
<TITLE>Insertar.php</TITLE>
</HEAD>
<BODY>
<?
//Conexion con la base
mysql_connect("localhost","tu_user","tu_password");
//seleccin de la base de datos con la que vamos a trabajar
mysql_select_db("mi_base_datos");
//Ejecucion de la sentencia SQL
mysql_query("insert into clientes (nombre,telefono) values ('$nombre','$telefono')");
?>
<h1><div align="center">Registro Insertado</div></h1>
72
Ejecutar ejemplo
Los parametros user y password son definidos por el creador de la base. Es conveniente en un principio, al crear
nuestras bases, trabajar sin ellos con lo cual dejaremos las cadenas correspondientes vacias: "".
Adems de la propia insercin, el programa avisa de la introduccin del registro y ofrece un enlace hacia una pgina de
lectura la cual ser comentada a continuacin.
No entraremos en la descripcin de la orden SQL, para comprender ms acerca de cmo introducir registros, refererirse
al tutorial de SQL.
Artculo por
Rubn Alvarez
73
Ejecutar script
Los pasos a realizar son, en un principio, los vistos para la insercin de un registro: Conexin a la base y ejecucin de la
sentencia. Esta vez, la informacin de dicha ejecucin ser almacenada en una variable ($result).
El siguiente paso ser plasmar en pantalla la informacin recogida en $result. Esto lo haremos mediante la funcin
mysql_fetch_array que devuelve una variable array con los contenidos de un registro a la vez que se posiciona sobre el
siguiente. El bucle while nos permite leer e imprimir secuencialmente cada uno de los registros.
La funcin mysql_free_result se encarga de liberar la memoria utilizada para llevar a cabo la consulta. Aunque no es
necesaria su utilizacin, resulta altamente aconsejable.
Artculo por
Rubn Alvarez
74
La manera de operar para construir el men desplegable es la misma que para visualizar la tabla. De nuevo empleamos
un bucle while en combinacin con la funcin mysql_fetch_array lo que nos permite mostrar cada una de las opciones.
El script de actualizacin ser muy parecido al de insercin:
Nota: Para quien desee una referencia completa sobre cmo se hacen las sentencias UPDATE en el lenguaje SQL, recomendamos leer el
artculo Actualizacin de registros con UPDATE en SQL.
<HTML>
<HEAD>
<TITLE>Actualizar2.php</TITLE>
</HEAD>
<BODY>
<?
//Conexion con la base
mysql_connect("localhost","tu_user","tu_password");
//seleccin de la base de datos con la que vamos a trabajar
mysql_select_db("mi_base_datos");
//Creamos la sentencia SQL y la ejecutamos
$sSQL="Update Clientes Set telefono='$telefono' Where nombre='$nombre'";
mysql_query($sSQL);
?>
<h1><div align="center">Registro Actualizado</div></h1>
<div align="center"><a href="lectura.php">Visualizar el contenido de la base</a></div>
</BODY>
</HTML>
Como habis podido comprobar, la operacin UPDATE no tiene demasiada complejidad. Sin embargo, para afianzar
estos conocimientos recomendamos ver el vdeo sobre la actualizacin de registros en MySQL con PHP.
Artculo por
Rubn Alvarez
75
</select>
<br>
<INPUT TYPE="SUBMIT" value="Borrar">
</FORM>
</div>
</BODY>
</HTML>
El siguiente paso es hacer efectiva la operacin a partir de la ejecucin de la sentencia SQL que construimos a partir de
los datos del formulario:
<HTML>
<HEAD>
<TITLE>Borrar2.php</TITLE>
</HEAD>
<BODY>
<?
//Conexion con la base
mysql_connect("localhost","tu_user","tu_password");
//seleccin de la base de datos con la que vamos a trabajar
mysql_select_db("mi_base_datos");
Con este captulo cerramos el bloque de accesos a bases de datos con PHP. Para mas informacin relacionada podis
referiros al taller de PHP donde podris encontrar algn que otro artculo interesante al respecto. Asimismo, para los
que prefieran el vdeo como material didctico, recomendamos ver el Videotutorial sobre las bases de datos con PHP.
76
Artculo por
Rubn Alvarez
PHP est en constante evolucin y prueba de ello son las novedades que venimos a comentar en este artculo. Se trata de
las nuevas funciones de acceso a bases de datos MySQL que estn disponibles desde PHP 5, con nombres diferentes a
las funciones disponibles en el pasado y que tambin tienen algunos cambios en el modo de trabajar. Las nuevas
funciones estn creadas para dar respuesta a diversas mejoras que el sistema gestor de bases de datos MySQL ha
incorporado recientemente.
Este es un tema fundamental, sobre todo para las personas que conocen PHP desde hace tiempo, que como yo,
estbamos acostumbrados a usar un juego de funciones que a da de hoy se encuentra obsoleto y que no se recomienda
utilizar. Realmente, en el momento de escribir este artculo las funciones de MySQL antiguas todava, se pueden usar,
pero la previsin es que se eliminen en PHP 5.5, por lo que resulta imprescindible actualizar nuestros conocimientos.
Afortunadamente, es bastante sencillo el paso a las nuevas funciones de MySQL, puesto que el esquema de
funcionamiento es prcticamente el mismo, as como los nuevos nombres de funciones, que tienen muy pocas
variaciones. Por lo tanto, si te has ledo el Manual de PHP de DesarrolloWeb.com y has aprendido con nosotros a
trabajar con las bases de datos, no tendrs realmente muchos problemas en aprender las novedades que paso a relatar a
continuacin.
8.6.1.- Dos tipos de funciones para acceso a las bases de datos MySQL
Una de las novedades que PHP nos ofrece en las recientes funciones de PHP es la incorporacin de dos tipos
aproximaciones al trabajo con MySQL, que ahora se puede hacer por procedimientos (funciones normales de toda la
vida) y por objetos.
Nota: Antes slo podamos acceder a MySQL por funciones comunes, pero ahora tambin podemos acceder por medio de clases y
objetos de programacin orientada a objetos (POO). La incorporacin en el API de mtodos basados en POO hace patente que PHP est
teniendo muy presente este paradigma de desarrollo dentro de su ncleo y que la tendencia en las nuevas versiones de PHP ser la de
potenciarlo aun ms.
Funciones basadas en procedimientos: Como venimos haciendo toda la vida con PHP.
Funciones normales y corrientes, que reciben parmetros y que devuelven valores.
Funciones basadas en POO: Realmente son constructores para obtener objetos y mtodos a los que podemos acceder
dentro de esos objetos para realizar las operaciones con la base de datos.
Hay que aclarar que ambas aproximaciones son perfectamente vlidas y que no cambian las cosas que se pueden hacer
desde una u otra. Por tanto, decantarnos por uno u otro modo no implicar ninguna ventaja en funcionalidad, ni tan
siquiera de rendimiento. De hecho, ambos modos de trabajo son el "mismo perro con distinto collar". Por tanto, es tan
vlida una eleccin como la otra y nuestra preferencia ser ms bien por gustos o costumbres a la hora de desarrollar.
Nota: Lo que no se recomienda es en un mismo proyecto cambiar de uno a otro estilo de acceso a base de datos MySQL de manera
arbitraria. Debemos tener en cuenta que realmente esa recomendacin no es debido a que no te vaya a funcionar tu programa, o puedas
tener algn problema determinado, sino ms bien es una cuestin de estilo y claridad a la hora de mantener el cdigo de tu proyecto.
77
Otra aspecto interesante es que nos devuelve un valor que puede ser, o bien un booleano para saber si la consulta se
ejecut con xito, como en el caso de un "insert" o "delete", o bien un objeto resultado con un conjunto de registros en
el caso de un "select".
Extraer un registro del conjunto de resultados: mysqli_fetch_array()
Esta funcin es exactamente igual, recibe el conjunto de resultados del que queremos sacar un registro. Devuelve en
este caso un "array", pero est igualmente mysqli_fetch_object() que devolvera un objeto.
$fila = mysqli_fetch_array($resultado);
8.6.3.- Conclusin
En general, como ests pudiendo comprobar, el sistema no vara mucho de lo que ya conoces en el pasado. Cambian
nombres de funciones mnimamente y algn parmetro suelto aqu y all.
Creo que el paso para usar las nuevas funciones MySQL es tan rpido que no tiene sentido seguir usando las funciones
antiguas y adems en breve el cambio ser obligado porque los accesos antiguos que hacamos a MySQL dejarn de
funcionar.
Artculo por
78
Parte 9:
Subir una
aplicacin web al
servidor
Una vez que hemos terminado una aplicacin web en local, tenemos que ponerla en
produccin en un servidor de Internet. Mostramos cmo subir todas las pginas a un
servidor y algunas de las posibles tareas que nos tocar realizar para subir tambin la
base de datos.
79
Referencia:por si alguien no sabe lo que es el FTP, hablamos ms sobre ello en el manual de Publicar en Internet, concretamente en el
artculo Subir los archivos al servidor.
Al conectarnos al servidor con los datos del FTP, que deben ser proporcionados por nuestro proveedor, accederemos a
un directorio. Este directorio podra ser el de publicacin, aunque generalmente no es as, sino que suele ser un
subdirectorio llamado "HTML" o "docs" o algo similar, que cuelga del directorio de inicio en nuestra conexin FTP.
Como deca, este directorio puede tener nombres distintos en proveedores distintos, aunque, en cualquier caso, con una
simple pregunta a nuestro proveedor resolveremos esa duda.
Los archivos se deben subir al directorio de publicacin, o a cualquier subdirectorio de este. En definitiva, los
tendremos que alojar por ah dentro y para acceder a ellos bastara con escribir el nombre del dominio o URL de nuestro
alojamiento, seguido del nombre del archivo. Si tuvisemos un archivo llamado hola.php y nuestro alojamiento se ha
contratado para el dominio www.midominio.com, deberamos subir ese archivo al directorio de publicacin y
accederamos al archivo escribiendo:
http://www.midominio.com/hola.php
Si creamos subdirectorios dentro del directorio de publicacin podremos acceder a ellos escribiendo el nombre del
dominio o URL de nuestro alojamiento, seguido del nombre del directorio y el nombre del archivo. Por ejemplo, si
creamos un subdirectorio llamado paginas y tenemos dentro un archivo llamado pag1.php, podramos acceder a l de la
siguiente manera.
http://www.midominio.com/paginas/pag1.php
Referencia:hay otro concepto interesante que deberamos conocer llegados a este punto, que es el "documento por defecto". ste no es
ms que el archivo que se enva al navegador si en la URL accedida no se especificaba ningn archivo. Suele llamarse index.html o
index.php (o index.asp si nuestro servidor soporta programacin en ASP), aunque puede variar de un proveedor a otro. Hablamos ms
sobre el documento por defecto en nuestro manual de Publicar en Internet.
Artculo por
No sera posible salir del directorio de publicacin con una URL como esta, por mucho que utilicemos el operador ..
(que sirve para acceder al directorio padre).
http://www.midominio.com/../funciones_php/archivo_inalcanzable.php
Sin embargo, colocar algunos contenidos fuera del directorio de publicacin puede ser muy til. Por ejemplo,
podramos colocar all copias de seguridad de algunos archivos o documentos que simplemente queremos guardar en el
servidor para acceder a ellos desde cualquier parte y con nuestro programa de FTP.
80
Desde PHP s que podemos acceder a los archivos que se encuentran fuera del directorio de publicacin. Para ello
especificamos la ruta adecuada, en la que utilizamos el operador .. para bajar al directorio padre.
Nada ms que decir sobre la colocacin de los archivos: una vez situados en el directorio de publicacin se podr
acceder a ellos con nuestro navegador y se deberan ejecutar perfectamente. Aunque cabe sealar que, tanto PHP como
el servidor donde trabajemos, pueden tener configuraciones distintas y puede que algn detalle de la programacin de
nuestras pginas no funcione correctamente.
Por ejemplo, nuestro PHP puede declarar o no automticamente las variables que llegan a travs de un formulario. Si en
local si que estaba configurado para hacer esto y en remoto no, deberamos localizar los lugares donde recogemos las
variables y utilizar las variables de entorno correctas (mirar artculo sobre Procesar variables de formularios y los
comentarios al pie para saber ms de esta posible fuente de errores).
Aunque este no es un caso habitual, podemos ponernos en contacto con nuestro proveedor de alojamiento para ver si
pueden ayudarnos configurando el sistema o indicando los pasos a seguir para solventar en nuestros scripts el asunto.
Comentario: el siguiente script calcula el nivel de directorio de los scripts que queremos incluir en la pgina actual.
// Hallamos el nivel de directorio en que est ubicada la pgina
1. Se hace un recuento de los caracteres que contiene el nombre del script
actual.
$Chars = count_chars($PHP_SELF,1);
2. Exploramos la tabla de los caracteres devueltos buscando el carcter ('/'
Cdigo 47 ) de directorio (carpeta) que devuelve Apache.
foreach ($Chars as $Char=>$nChars){
if ($Char==47) {$n=$nChars;break;}
}
3. Generamos una cadena de n-1 veces con la subcandena "../" que nos da el
nivel de directorio en que se encuentra el script.
if ($n==0) $PathString=""; else $PathString=str_pad("",($n-1)*3,"../");
Artculo por
81
Es muy corriente que nuestro proveedor de hosting ofrezca junto con PHP la base de datos MySQL, as que las notas
para subir esa base de datos al servidor de este artculo van encaminadas a ofrecer soluciones para esa base de datos.
La base de datos MySQL no se puede subir por FTP, como que se haca con los archivos del cdigo PHP. Para subirla
tendremos que utilizar otros mecanismos. Voy a distinguir entre tres casos distintos en los que nos podramos encontrar
en este momento:
1. La base de datos que pretendemos subir est vaca. Tan slo hemos creado las tablas, pero no hemos
introducido datos en ellas o, a lo sumo, tienen algn dato que hemos introducido de pruebas.
2. La base de datos que queremos subir est completa y es una base de datos MySQL. En este caso tenemos
creada la base de datos en local y con toda la informacin dentro y, por supuesto, queremos que esa
informacin quede tambin en la base de datos remota.
3. La base de datos est completa (como el caso anterior), pero no es una base de datos MySQL. En este caso
estaramos haciendo una migracin de la base de datos de un sistema gestor a otro.
Veremos los tres casos por separado en adelante, aunque, antes de ello, vamos a mostrar unas herramientas que nos
servirn de mucha ayuda para la administracin de cualquier base de datos remota.
Las herramientas en concreto se relatan en el manual Taller de MySQL, son las siguientes:
PhpMyAdmin. Una aplicacin creada en PHP que podemos instalar en nuestro espacio de alojamiento para
administrar la base de datos.
Mysql Control Center (en adelante MyCC). Una aplicacin Windows que permite contectarse a mltiples
bases de datos MySQL, que se encuentren en local o en remoto.
Access. Tambin permite administrar una base de datos MySQL conectada en local o en remoto. En este caso
se utiliza una interfaz que muchos ya conocen, como es Access, para administrar una base de datos que nada
tiene que ver con dicho programa.
En los tres casos lo que nos permite realizar el software de administracin son tareas sobre la base de datos de todo tipo,
como pueden ser crear tablas, modificarlas, insertar datos, borrarlos, editarlos. Modificar o borrar tablas o campos de las
mismas, etc.
La eleccin de una herramieta o de otra pasa por los recursos que nos permitan utilizar en nuestro proveedor.
Bsicamente, lo que nos puede decantar a una opcin u otra, es si permiten o no conectar de manera remota la base de
datos MySQL. Conozco alojamientos donde se permite esa conexin remota y donde no.
Si no permiten conectarnos remotamente nos decantaremos por PhpMyAdmin, pues es una aplicacin PHP que se
conecta en local y a la que se accede desde una pgina web y eso lo permiten todos los proveedores, incluso hay
muchos que tienen instalado ya este software para administrar las bases de datos.
En caso de que s nos permitan conectarnos remotamente con la base de datos, eligiremos MyCC o Access, que son
aplicaciones Windows mucho ms potentes y rpidas que las que utilizan interfaz web, como PhpMyAdmin. Es
preferible utilizar MyCC porque est especialmente desarrollado para conectar y operar con bases de datos MySQL.
Artculo por
82
Lo que tenemos que hacer en este caso es un backup de la estructura de la base de datos, es decir, los "create tables" o
sentencias SQL para crear las tablas. Sera un montn de sentencias con esta forma:
# -------------------------------------------------------#
# Table structure for table 'comentario'
#
CREATE TABLE comentario (
id_comentario int(5) unsigned NOT NULL auto_increment,
id_articulo int(4) DEFAULT '0' NOT NULL,
comentario text NOT NULL,
83
);
Para restaurar estas sentencias tenemos opciones tanto dentro de PhpMyAdmin como de MyCC. En ambos casos lo que
tenemos que hacer es ejecutar estas sentencias en el servidor MySQL remoto. En PhpMyAdmin tenemos un campo para
introducir sentencias SQL y tambin otro campo para seleccionar un archivo de texto con todas las sentencias SQL,
para ejecutarlas una detrs de otra. En MyCC tenemos un botn que nos permite abrir una consola donde introducir una
o varias sentencias SQL y ejecutarlas.
Herramienta de backup y restauracin de PhpMyAdmin
Repetimos, esto slo nos servir para subir la estructura de la base de datos y no los datos que contenga. Si deseamos
subir tambin la informacin de la base de datos entonces debemos utilizar otras estrategias, relatadas prximamente.
Artculo por
84
Nota: Estas recomendaciones estn pensadas para subir una base de datos MySQL que podamos tener en local a una base de datos
MySQL que hayamos contratado en remoto. Si la base origen no es MySQL estaramos hablando de una migracin de bases de datos,
pero esto lo veremos en un artculo ms adelante.
En este caso el procedimiento sera muy parecido al de subir una base de datos vaca, relatado anteriormente, con la
salvedad de que ahora debemos extraer no solo la estructura de la base de datos, sino tambin los registros que contiene.
Para ello podemos utilizar mysqldump, segn se relata en este artculo, o bien PhpMyAdmin, seleccionando la opcin
que indica que el backup contenga la estructura y los datos (Structure and data en versiones en ingls).
La estructura y los datos vendrn en un fichero de texto con una serie de sentencias SQL para crear las tablas y los
insert necesarios para introducir cada uno de los datos.
Para restaurar la base de datos lo haremos tal como se ha relatado para el caso de que la base de datos estuviera vaca,
con la ayuda de una instalacin de PhpMyAdmin en remoto o un MyCC que se conecte a la base de datos contratada en
el servidor de Internet.
Si tenemos problemas para subir el fichero de backup de la base de datos es posible que en nuestro proveedor de
alojamiento nos pueda ayudar a subir el fichero y restaurarlo. Como el proveedor dispone de los servidores en sus
propias instalaciones, tiene muchas ms posibilidades que nosotros para trabajar con las bases de datos, sin temor a que
las lentas comunicaciones por Internet arrojen errores en la restauracin de los datos.
Si nuestro proveedor no puede ayudarnos, seguramente disponga y nos indique algn mecanismo para realizar la tarea
sin lugar a errores. Puede ocurrinos con algn proveedor que nos diga que se encarga de todo pero nos exija el pago de
las horas de trabajo del informtico que va a restaurar el backup de la base de datos. Si no pone facilidades ni siquiera
en esto posiblemente sea mejor ir pidindoles que nos devuelvan el dinero invertido porque su servicio no sera muy
bueno.
Artculo por
85
Accediendo a ese enlace podremos ver un formulario donde introducir las caractersticas del fichero de texto, como el
carcter utilizado como separador de campos, o el terminador de lneas, etc, junto con el propio archivo con los datos, y
PhpMyAdmin se encargar de todo el trabajo de incluir esos datos en la tabla.
86
Como se habr supuesto, es necesario tener creada la tabla en remoto para que podamos introducirle los datos del
fichero de texto.
87
Parte 10:
Introduccin a la
programacin
orientada a objetos
en PHP 4
Captulos sobre la programacin orientada a objetos que se puede realizar en PHP 4. Es
una primera aproximacin a la orientacin a objetos, tal como se realizaba en esa
versin de PHP.
88
En este ejemplo se ha creado la clase Caja, indicando como atributos el ancho, alto y largo de la caja, as como el color
y el contenido. Se han creado, para empezar, un par de mtodos, uno para introducir un elemento en la caja y otro para
mostrar el contenido.
Si nos fijamos, los atributos se definen declarando unas variables al principio de la clase. Los mtodos se definen
declarando funciones dentro de la clase. La variable $this, utilizada dentro de los mtodos la explicaremos un poco ms
abajo.
Con esto hemos creado, o mejor dicho, instanciado, un objeto de la clase Caja llamado $micaja.
$micaja->introduce("algo");
$micaja->muestra_contenido();
Con estas dos sentencias estamos introduciendo "algo" en la caja y luego estamos mostrando ese contendido en el texto
de la pgina. Nos fijamos que los mtodos de un objeto se llaman utilizando el cdigo "->".
nombre_del_objeto->nombre_de_metodo()
Para acceder a los atributos de una clase tambin se accede con el cdigo "->". De esta forma:
nombre_del_objeto->nombre_del_atributo
89
En este constructor recibimos por parmetro todos los atributos que hay que definir en una caja.
Es muy til definir unos valores por defecto en los parmetros que recibe el constructor, igualando el parmetro a un
valor dentro de la declaracin de parmetros de la funcin constructora, pues as, aunque se llame al constructor sin
proporcionar parmetros, se inicializar con los valores por defecto que se hayan definido.
Es importante sealar que en los constructores no se tienen por qu recibir todos los valores para inicializar el objeto.
Hay algunos valores que pueden inicializarse a vaco o a cualquier otro valor fijo, como en este caso el contenido de la
caja, que inicialmente hemos supuesto que estar vaca.
Artculo por
90
function define_tema($nuevo_tema){
$this->tema = $nuevo_tema;
}
}
En esta clase heredamos de Caja, con lo que tenemos a nuestra disposicin todos los atributos y mtodos de la clase
base. Adems, se ha definido un nuevo atributo, llamado $tema, y un mtodo, llamado define_tema(), que recibe el
tema con el que se desea etiquetar la caja.
Podramos utilizar la clase Caja_tematica de manera similar a como lo hacamos con la clase Caja original.
$micaja_tematica = new Caja_tematica();
$micaja_tematica->define_tema("Cables y contectores");
$micaja_tematica->introduce("Cable de red");
$micaja_tematica->introduce("Conector RJ45");
$micaja_tematica->muestra_contenido();
En este caso, el resultado que se obtiene es parecido al que se obtiene para la clase base. Sin embargo, cuando se
muestra el contenido de una caja, lo ms interesante sera que se indicara tambin el tipo de objetos que contiene la caja
temtica. Para ello, tenemos que redefinir el mtodo muestra_contenido().
En este ejemplo hemos codificado de nuevo el mtodo entero para mostrar los datos completos.
En algunas ocasiones es muy til apoyarse en la definicin de un mtodo de la clase base para realizar las acciones de la
clase extendida. Por ejemplo, para este ejemplo, tenemos que definir un constructor para la clase Caja_tematica, en el
que tambin se inicialice el tema de la caja. Como ya existe un mtodo constructor en la clase base, no merece la pena
reescribir el cdigo de ste, lo mejor es llamar al constructor que haba definido en la clase Caja original, con lo que se
inicializarn todos los datos de la clase base, y luego realizar la inicializacin para los atributos de la propia clase
extendida.
Para llamar a un mtodo de la clase padre dentro del cdigo de un mtodo que estamos redefiniendo, utilizamos una
sintaxis como esta:
function Caja_tematica($alto=1,$ancho=1,$largo=1,$color="negro",$tema="Sin clasificacin"){
parent::Caja($alto,$ancho,$largo,$color);
$this->tema=$tema;
}
Aqu vemos la redefinicin del constructor, de la clase Caja, para la clase Caja_tematica. El constructor hace primero
una llamada al constructor de la clase base, a travs de una referencia a "parent". Luego inicializa el valor del atributo
$tema, que es especfico de la Caja_tematica.
En la misma lnea de trabajo, podemos redefinir el mtodo muestra_contenido() apoyndonos en el que fue declarado
en la clase base. El cdigo quedara como sigue:
function muestra_contenido(){
echo "Contenido de la caja de <b>" . $this->tema . "</b>: ";
91
Parte 11:
Eplogos al Manual
de PHP
Diversos artculos que finalizan este manual de PHP y ofrecen introducciones a diversos
asuntos que son interesantes para conocer sobre este lenguaje de programacin.
Introducciones a algunas herramientas especialmente tiles, que pueden ayudarnos a
desarrollar pginas web.
92
function getNombre() {
return $this->nombre;
}
}
function Algo($p) {
$persona->setNombre("Daniel");
}
1 $persona = new Persona();
2 $persona->setNombre("Pichongol");
3 Algo($persona);
4 echo $persona->getNombre();
?>
La variable $cadena pasada como argumento a la funcin ejemplo, es copiada para su uso local dentro de dicha funcin.
Es lo que se conoce como paso de parmetros por valor.
El Zend Engine 1.0 hace exactamente esto para todas las funciones, inclusive para las que estn dentro de una clase, las
cuales en ese caso actan como mtodos:
<?
function Algo($persona) {
$persona->setNombre("Daniel");
}
?>,
Volviendo al ejemplo inicial de la clase persona, el mtodo Algo recibe una copia (un clon) del objeto Persona.
La segunda razn viene emparejada con la primera, siendo consecuencia de esta.
Cualquier modificacin del objeto Persona que se produzca dentro del mtodo Algo, solo tendr alcance local, y no se
ver reflejado cuando la funcin retorne.
<?
Algo($persona);
echo $persona->getNombre();
?>
En ese caso la modificacin del nombre que hace la funcin Algo al objeto Persona no se ve reflejada cuando hacemos
93
11.1.4.- Newbie
En el planteo de esta discusin, podramos decir que es la situacin ideal, o por lo menos la ms beneficiosa. Si eres una
persona que quiere arrancar en PHP, no lo dudes, PHP5 es para ti. Tus aplicaciones gozaran de las nuevas capacidades
en OOP, obtendrs el beneficio de una mejor performance de ejecucin (esta comprobado experimentalmente que PHP5
corre un 25% ms rpido que PHP4) y tu cdigo estar muy bien acondicionado en cuanto a la compatibilidad con el
nuevo hijo que asoma: PHP6.
Por cierto, no todo es color de rosas. Una de los mayores beneficios a la hora de elegir PHP para trabajar en nuestro
proyecto es la gran cantidad de cdigo que podemos encontrar en Internet, y utilizarlo para nuestros trabajos. Tenemos
una gran probabilidad de que ante alguna tarea que se nos plantea, podamos encontrar algn script que nos solucione la
vida, obviamente adaptndolo a nuestras necesidades.
Ahora bien, no todo el cdigo que vamos a encontrar es compatible con PHP5. De hecho la gran mayora todava no se
ha adaptado. Es cierto que con algn setting en nuestro php.ini podemos ayudar a darle mayor compatibilidad, pero
como contrapartida muchas de estas settings se eliminaran en PHP6.
Qu queda? Hacerlo compatible modificando el cdigo, una tarea que para un desarrollador que se inicia no siempre es
sencillo. De todas formas a no alarmarse, que los grandes proyectos (PHPNuke, PHPBB, etc.) ofrecen compatibilidad.
11.1.5.- Experimentado
En este caso, el optar por quedarse con PHP4 o pasar a PHP5 depende de nuestra aplicacin.
Las interrogantes que el desarrollador se puede plantear podran ser:
- Mi aplicacin usa clases y objetos?
- Mi motor de Base de datos es MySQL?
- Utilizo un hosting externo?
- Mi aplicacin sufre modificaciones en cuanto a los requerimientos y lgica de negocios?
Pasemos a discutir ventajas y desventajas en cada uno de los interrogantes:
94
Daniel Lpez
95
Con la funcin header() de PHP enviamos informacin en la cabeceras del http. En este caso hemos enviado una
cabecera 404 Not Found. Atencin, porque la funcin header() debe invocarse antes de haber escrito nada en la pgina,
osea, antes de haber enviado ninguna informacin al navegador.
Pero dependiendo de la configuracin de nuestro servidor esto puede funcionar o no.
La mejor manera de saber qu estamos enviando por las cabeceras del http es utilizar un programa que nos muestre las
cabeceras que se generan tanto en el cliente como en el servidor. Existen varios programas que nos podran servir, pero
nosotros vamos a recomendar aqu una extensin de Firefox que hemos comentado ya en otro artculo: Ver cabeceras
HTTP con LiveHttpHeaders.
Veremos que en algunas ocasiones enviando esta cabecera el navegador recibe un cdigo de error como este:
HTTP/1.x 404 OK
Eso es algo que tenemos que evitar, porque es ambiguo. La cabecera deseable sera:
HTTP/1.x 404 Not Found
Pues bien, cuando la cabecera que generamos es HTTP/1.x 404 OK tenemos que hacer lo siguiente para conseguir el
deseado HTTP/1.x 404 Not Found.
<?
header("HTTP/1.0 404 Not Found");
header("Status: 404 Not Found");
?>
Primero le indicamos la cabecera del http como 404 y luego lanzamos otra cabecera indicando que el estatus que tiene
que enviar es "Not Found". Esto debera funcionar en todos los casos. Es posible que con una sola de las dos cabeceras
enviadas nos enve ya el error 404 Not Found, depende de la configuracin de nuestro servidor que necesitemos una u
otra. Pero si indicamos las dos en las pruebas que he hecho con varios servidores siempre he recibido el cdigo de error
correcto.
Insisto en que lo bueno es que veamos qu cabeceras del HTTP estamos enviando con un producto como
LiveHttpHeaders . As podremos estar seguros de qu cabeceras tenemos que enviar y qu cdigo PHP es el correcto en
nuestro caso.
96
97
Existe un artculo muy interesante, aunque en ingls, que compara las diversas libreras existentes para usar JSON
desde PHP, que contiene diversas informaciones tcnicas, requisitos y un anlisis del desempeo de cada una.
En el prximo artculo explicaremos cmo utilizar las funciones JSON en PHP por medio de las funciones nativas del
lenguaje.
Artculo por
11.4.- CodeIgniter
CodeIgniter es un framework PHP para la creacin rpida de aplicaciones web. Presentacin general del
framework y primeras notas para empezar a usarlo.
Probablemente ya sepamos que un framework es un programa para desarrollar otros programas, CodeIgniter, por tanto,
es un programa o aplicacin web desarrollada en PHP para la creacin de cualquier tipo de aplicacin web bajo PHP. Es
un producto de cdigo libre, libre de uso para cualquier aplicacin.
Como cualquier otro framework, Codeigniter contiene una serie de libreras que sirven para el desarrollo de
aplicaciones web y adems propone una manera de desarrollarlas que debemos seguir para obtener provecho de la
aplicacin. Esto es, marca una manera especfica de codificar las pginas web y clasificar sus diferentes scripts, que
sirve para que el cdigo est organizado y sea ms fcil de crear y mantener. CodeIgniter implementa el proceso de
desarrollo llamado Model View Controller (MVC), que es un estndar de programacin de aplicaciones, utilizado tanto
para hacer sitios web como programas tradicionales. Este sistema tiene sus caractersticas, que veremos en artculos
siguientes.
98
Facilidad de instalacin: No es necesario ms que una cuenta de FTP para subir CodeIgniter al servidor y su
configuracin se realiza con apenas la edicin de un archivo, donde debemos escribir cosas como el acceso a la base de
datos. Durante la configuracin no necesitaremos acceso a herramientas como la lnea de comandos, que no suelen estar
disponibles en todos los alojamientos.
Flexibilidad: CodeIgniter es bastante menos rgido que otros frameworks. Define una manera de trabajar especfica,
pero en muchos de los casos podemos seguirla o no y sus reglas de codificacin muchas veces nos las podemos saltar
para trabajar como ms a gusto encontremos. Algunos mdulos como el uso de plantillas son totalmente opcionales.
Esto ayuda muchas veces tambin a que la curva de aprendizaje sea ms sencilla al principio.
Ligereza: El ncleo de CodeIgniter es bastante ligero, lo que permite que el servidor no se sobrecargue interpretando o
ejecutando grandes porciones de cdigo. La mayora de los mdulos o clases que ofrece se pueden cargar de manera
opcional, slo cuando se van a utilizar realmente.
Documentacin tutorializada: La documentacin de CodeIgniter es fcil de seguir y de asimilar, porque est escrita en
modo de tutorial. Esto no facilita mucho la referencia rpida, cuando ya sabemos acerca del framework y queremos
consultar sobre una funcin o un mtodo en concreto, pero para iniciarnos sin duda se agradece mucho.
Sin duda, lo ms destacable de CodeIgniter es su accesibilidad, ya que podemos utilizarlo en la mayor gama de
entornos. Esta es la razn por la que en DesarrolloWeb.com hemos elegido este framework PHP para comenzar un
manual que explicar cmo utilizarlo para desarrollar nuestras propias aplicaciones web. En siguientes artculos iremos
contando diferentes aspectos de este framework y lo utilizaremos para crear una primera aplicacin web. Para continuar
puedes leer el artculo Instalacin y configuracin de CodeIgniter. Tambin puedes ir al Manual de Codeigniter que
estamos publicando.
Artculo por
99
Debido a los avances en nuestro medio tecnolgico, nos encontramos con situaciones que nos amargan la existencia,
como por ejemplo: cuando nuestras webs se caen, ingreso de virus a nuestro PC, spam en nuestros correos, etc.
El trmino se empez a utilizar en el ao 2000 por Luis von Ahn, Manuel Blum y Nicholas J. Hopper de la Carnegie
Mellon University, y John Langford de IBM.
El sistema Captcha tiene las siguientes caractersticas por definicin:
Son completamente automatizados, es decir, no es necesario ningn tipo de mantenimiento ni de intervencin humana
para su realizacin. Esto supone grandes beneficios en cuanto a fiabilidad y coste.
El algoritmo utilizado es pblico. De esta forma, la ruptura de un captcha pasa a ser un problema de inteligencia
artificial y no la ruptura de un algoritmo secreto.
Pues habiendo visto un poco lo que es captcha Completely Automated Public T uring test to tell Computers and
Humans Apart (Prueba de Turing pblica y automtica para diferenciar a mquinas y humanos).
En este escenario, podramos encontrarnos con dos situaciones bien diferentes:
Escape de las entradas. Para muchos la manera ideal de proteger un site. Como ya hemos visto en alguno de los casos,
no nos es til. Los ms habituales son el uso de:
addslashes() / stripslashes()
htmlentities($string, ENT_QUOTES)
htmlspecialchars()
mysql_real_string()
Teniendo activadas las magic_quotes_gpc en nuestro php.ini, que nos pondr por defecto un slash en todos los
strings (evitando los tediosos "addslashes()"). En todo caso, el uso de dichos elementos nos podr salvar de muchos
de los ataques.
Evitar, salvo en casos necesarios, que los formularios POST se llamen desde otro dominio que no sea el del propio
servidor. En este caso, nos evitaremos que un atacante avezado utilice un script a tal efecto para ir bloqueando nuestro
servidor y llenndolo de datos intiles.
Vamos a ver, qu clase de configuracin sera la ptima para que un sistema PHP fuera ms seguro contra todo
tipo de ataques?
Estas directivas seran:
Openbase_dir
Esta directiva bien configurada evitar los ataques "trasversal directories", debido a que limita ejecucin de ficheros al
entorno que escojamos.
Allow_furl_open off
Es importante que esta directiva est en OFF para evitar "Remote File Inclusion", ya que la inhabilitacin de esta
directiva no permitir a la aplicacin hacer include remotos.
Register_globals off
Como ya hemos explicado, quiz la ms malfica (y obsoleta) forma de que nuestros atacantes desplieguen todo su
100
safe mode:
safe_mode_gid
safe_mode_include_dir
safe_mode_exec_dir
safe_mode_allowed_env_vars
safe_mode_protected_env_vars
Por ltimo, unas funciones que, segn la casustica de nuestro aplicativo pudiera evitarnos algn susto por la ejecucin
de comandos sensibles que no queremos (y no debemos) utilizar:
Escaneo de puertos Una manera de evitar ataques a todo sistema operativo, ya sea mediante web o mediante cualquier
otro tipo de vulnerabilidad, sera mediante la ejecucin de cdigo remoto o inyeccin de cdigo no deseado en servicios
que puedan tener relacin con nuestro sistema.
Para ello se recomienda ejecutar un escaneo de puertos de nuestra mquina (no nicamente puerto 80-http o 443-SSL)
para averiguar las posibles vulnerabilidades o exploits que puedan afectar a nuestro sistema y servidor web:
Los ms conocidos son nmap y nessus. El funcionamiento de nmap puede llegar a ser sencillo, aunque tiene un
despliegue de opciones que, a buen seguro, mucha gente encontrar interesante.
Una ejecucin de este programa puede dar lugar a un resultado como este:
Starting Nmap 4.53 ( http://insecure.org ) at
20080603
12:05 CEST
Interesting ports on 192.168.1.1:
Not shown: 1711 closed ports
PORT STATE SERVICE
21/tcp open ftp
23/tcp open telnet
80/tcp open http
MAC Address: 00:02:CF:81:6F:89 (ZyGate
Communications)
Nessus, en cambio, nos ofrecer una herramienta cliente/servidor que utilizar una base de datos con las
vulnerabilidades que estadsticamente han podido ocasionar desastres y nos avisa mediante este escaneo.
La interfaz, adems, es bastante ms amigable y nos mostrar unas estadsticas de los procesos ejecutados.
101
Ms en consonancia con el objetivo de este artculo, estn los escaneos de vulnerabilidades propiamente web. Estos
escaneos se pueden basar en varias premisas, empleando sistemas de conocimiento, funciones heursticas e incluso
tcnicas fuzz, que veremos ms adelante. Una buena combinacin de estos elementos puede darnos muchas pistas a la
hora de proteger nuestro site y llegar donde nosotros no alcanzamos. Empecemos por los escaneadores automticos ms
empleados y populares.
11.5.2.- Acunetix
Acunetix, que goza de una versin Free Edition (slo para HTML Injection), pero con una gran variante de sistemas
de inyeccin, una base de datos amplia y una interfaz muy amigable. Los procesos por los que puede atacarse pueden
ser varios y los perfiles de ataque si se tiene la versin de pago de los ms variopintos, muchos de ellos ya los
hemos visto aqu.
PHP-IDS es un sistema basado en PHP que acta como IDS (Intrusion Detect System) y que se aplica a todos nuestros
archivos buscando algn tipo de inyeccin o vulnerabilidad. Puede detectar desde XSS, SQL Injection, RFI y ataques
LDAP Injection y tiene incluso hasta mdulos especializados para distintos tipos de CMS.
102
11.5.7.- Conclusin
No es un caso trivial tener que proteger un site web, tanto si ya est hecho como si lo tenemos que desarrollar de nuevo.
La nica forma de obstaculizar el ejercicio de estos atacantes ser conocer cules son sus tcnicas, mantenerse
actualizado regularmente de las vulnerabilidades de nuestro entorno (Sistema Operativo, Lenguaje, base de datos y
mdulos y libreras asociados), en caso de ser un programa conocido (como un WordPress, Joomla!, PostNuke)
mantenerse alerta a los bugs que, altruistamente, algunos atacantes publican en webs.
Adems, con un sistema IDS que nos pueda ir comunicando qu pasa con nuestros logs, la evolucin de estos mismos y
la constante evaluacin de las vulnerabilidades de nuestro sistema, junto con un escaneo automtico, tcnicas fuzz y
una programacin slida, y algn mdulo destinado a la seguridad harn de nuestro servidor web una fortaleza (casi)
inexpugnable.
Artculo por
Brian Hernndez
103