PDF de programación - Funciones de PHP

Imágen de pdf Funciones de PHP

Funciones de PHPgráfica de visualizaciones

Publicado el 5 de Junio del 2017
522 visualizaciones desde el 5 de Junio del 2017
254,5 KB
17 paginas
Creado hace 15a (01/11/2005)
Funciones de PHP

Francisco José Naranjo Abad

Area de Ingeniería Telemática

Departamento de Automática y Computación

Universidad Pública de Navarra

franciscojose.naranjo@unavarra.es

Laboratorio de Interfaces de Redes

http://www.tlm.unavarra.es/asignaturas/lir

Contenido

• Estado de la conexion con el navegador
• PHP y MySQL
• Cookies
• Sesiones
• Otras opciones

9 Nov

Funciones de PHP

1

Estado de la conexión con el navegador
• Cuando el usuario solicita una página que es en verdad un PHP éste
empieza a ejecutarse, manteniendo la conexión establecida para poder
mandar el resultado del script

• Puede que el usuario aborte la conexión (botón STOP en el

navegador)

• Para reconocer esta circunstancia un script PHP puede encontrarse en

diferentes estados:
– NORMAL: Mientras el script se ejecuta con normaliad como se ha descrito
– ABORTED: Si el usuario corta la conexión el script pasa a este estado
– TIMEOUT: Se puede configurar un máximo tiempo que puede ejecutarse el script, si

se alcanza este tiempo pasa a este estado

• Normalmente cuando el usuario corta la conexión y el script pasa al

estrado ABORTED termina abruptamente la ejecución del script

• Se puede cambiar este modo de funcionamiento para que los scripts
se ejecuten siempre hasta finalizar (por ejemplo llamando a la función
ignore_user_abort())

• El tiempo máximo típico que está configurado que pueda ejecutarse un
script sin ser abortado por TIMEOUT es de 30 segundos pero puede
cambiarse por ejemplo con la función set_time_limit()

9 Nov

Funciones de PHP

2

PHP y MySQL

• Veamos algunas funciones para conectarse y

realizar queries a un servidor de MySQL:
– mysql_connect()
– mysql_list_dbs(), mysql_select_db()
– mysql_select_db()
– mysql_query()
– mysql_fetch_array()
– mysql_num_rows(), mysql_insert_id()
– mysql_error(), mysql_errno()

9 Nov

Funciones de PHP

3

mysql_connect()

• Establecer una conexión con un servidor MySQL

resource mysql_connect ( [string server [, string username [,

string password [, bool new_link [, int client_flags]]]]])

• Devuelve un recurso que identifica a esa conexión si

se lleva a cabo con éxito, si no devuelve FALSE

• Ejemplo:

$link = mysql_connect("localhost", "mysql_user", "mysql_password");

• Para cerrar esa conexión se usa mysql_close(),
aunque no es necesario puesto que se cerrará al
terminar el script de PHP. Es recomendable cerrarla.

9 Nov

Funciones de PHP

4

mysql_list_dbs()

• Lista las bases de datos disponibles en el servidor (si se tiene

permiso)
resource mysql_list_dbs ( [resource link_identifier])

• El argumento es el recurso que identifica a la conexión con la base

de datos ($link en el ejemplo anterior)

• El resultado se puede recorrer como cualquier resultado de un query

select__dbdb()()

mysql__select
mysql
Selecciona una base de datos para todos los queries
Selecciona una base de datos para todos los
name [, [, resource
bool mysql__select
bool mysql
Si se le pasa el segundo argumento (la conexión a la BD), pasa a
Si se le pasa el segundo argumento (la conexión a la BD), pasa a
estar activa la base de datos seleccionada en el resource
estar activa la base de datos seleccionada en el
Sin segundo argumento, activa esa base de datos en la conexión más
Sin segundo argumento, activa esa base de datos en la conexión más
reciente al servidor
reciente al servidor

queries siguientes
siguientes
link_identifier

select__db db (( string database

string database__name

resource link_

identifier])])

resource dado
dado

9 Nov

Funciones de PHP

5

mysql_query()

• Envía una query al servidor

resource mysql_query ( string query [, resource link_identifier])

• Envía una query (primer argumento) al servidor al
que hace referencia el segundo argumento, a la base
de datos que tenga activa

• Si no hay segundo argumento se emplea la última

conexión con base de datos que se haya creado

• Para SELECT, SHOW, EXPLAIN y DESCRIBE devuelve un

identificador de recurso o FALSE

• Para otras sentencias SQL devuelve TRUE o FALSE

9 Nov

Funciones de PHP

6

mysql_fetch_array()

• Extrae una fila del resultado de una query
array mysql_fetch_array ( resource result [, int result_type])
• El primer argumento es el resultado de la query
• El segundo argumento nos permite especificar cómo

queremos que nos devuelva la fila:
– MYSQL_ASSOC para que sea un array asociativo cuyas claves

son los nombres de las columnas

– MYSQL_NUM para que sea un array indexado por el número

de columna

– MYSQL_BOTH para que tenga ambas claves (nombres e

índice)

• Cada vez que se llama a la función devuelve la

siguiente fila del resultado

• Devuelve FALSE cuando no quedan más filas

9 Nov

Funciones de PHP

7

mysql_num_rows()

• Devuelve el número de filas que tiene el resultado de

una query de tipo SELECT

int mysql_num_rows ( resource result)

• El argumento es el resultado de la query

mysql__insert
mysql

insert_id()
_id()

Si la última operación de tipo INSERT fue en una tabla
Si la última operación de tipo INSERT fue en una tabla
con una columna con el atributo AUTO_INCREMENT
con una columna con el atributo AUTO_INCREMENT
devuelve el ID nuevo que se le asignó
devuelve el ID nuevo que se le asignó

insert_id

_id ( [( [resource

resource link_

mysql__insert

int mysql
identifier])])
int
El argumento es la conexión con la base de datos y si no
El argumento es la conexión con la base de datos y si no
se especifica se empleará el último que se haya creado.
se especifica se empleará el último que se haya creado.

link_identifier

9 Nov

Funciones de PHP

8

mysql_error()

• Devuelve el texto asociado al error que produjo

la última función de MySQL
string mysql_error ( [resource link_identifier])
• Si no se produjo un error devuelve la cadena

vacía.

mysql__errno
mysql

errno()()

Devuelve el código numérico del error que produjo la
Devuelve el código numérico del error que produjo la
última función de MySQL
MySQL
última función de

int mysql
int

mysql__errno

errno ( [( [resource

resource link_

link_identifier

identifier])])

9 Nov

Funciones de PHP

9

Persistent Client State HTTP Cookies
• Una de las limitaciones de la Web a la hora del desarrollo de
aplicaciones/interfaces es que su funcionamiento es sin estado
• Cada petición de un URI es independiente de los anteriores y
hay poca o ninguna información de lo que ha hecho el usuario
anteriormente

• Eso quiere decir que formularios que ocupen varias páginas

HTML son difíciles de implementar

• Un técnica clásica ha sido, al generar un CGI una página como
resultado de un formulario esconder en esa página, en el
siguiente formulario, la información que se quiere conservar...

Formulario

El CGI que procesa ese
formulario crea el siguiente
y esconde en él (atributo
hidden) valores del anterior

se

envía
de
se

el
Cuando
este
contenido
está
formulario
enviando
también
información del anterior
que se escondió en él

9 Nov

Funciones de PHP

10





Persistent Client State HTTP Cookies
Las Cookies son el mecanismo más cómodo para

almacenar información de estado en el cliente
Al enviar una página Web el servidor puede indicar al
cliente que almacene cierta información
Ese cliente, cuando solicite otras páginas de ese servidor
enviará en la solicitud esa información que se le pidió
almacenar (la cookie)
Cuando el cliente solicita un URL envía las cookies que
pertenezcan a ese dominio y dentro del camino (path)
especificado
Las cookies se envían al servidor como parte de la
cabecera HTTP





Cookie: NAME1=OPAQUE_STRING1 ;NAME2=OPAQUE_STRING2 ...

9 Nov

Funciones de PHP

11

Persistent Client State HTTP Cookies
Se introduce una cookie en el cliente mediante

Set-Cookie en la cabecera HTTP:
Set-Cookie: NAME =VALUE ; expires= DATE ;path= PATH ;










domain= DOMAIN_NAME ; secure
El contenido de la cookie sigue el formato NAME=VALUE (ni
punto-y-coma ni coma ni espacios). El único atributo
obligatorio
Se le puede indicar una fecha máxima de validez a la cookie
Si se ha indicado el atributo domain el cliente, cuando haga
una petición, enviará la cookie solo si en el URL al que se le
solicita el nombre de dominio de la máquina está dentro de
ese dominio
Con el atributo path se puede restringir el subconjunto de
URLs del dominio a los que se les enviará la cookie al
solicitar una página
Si se indica el atributo secure esta cookie solo se enviará si
la conexión es segura (sobre SSL)

9 Nov

Funciones de PHP

12

Sesiones en PHP

• Sucede lo mismo con los scripts PHP que con CGIs: no se guarda

estado

• PHP nos permite guardar el contenido de unas variables asociándolas

a una sesión

• En realidad lo que hará será guardar esas variables localmente y
mandar al usuario un identificador de sesión asociado a ese conjunto
de variables en forma de una cookie

• Cuando el cliente solicita otro script PHP envía su cookie con el

identificador de sesión

• Se accede al fichero correspondiente recuperando esas variables de
forma que parece que conservar el contenido asignado por el anterior
script...

script

guarda

Un
la
información obtenida del
usuario en la pagina anterior
en variables de sesión. Al
mandar la pagina siguiente
manda una cookie con el ID
de la sesión

Al llamar a un nuevo script
se le pasa el ID de la sesión
con
lo que este puede
recuperar
variables
guardadas

las

9 Nov

Funciones de PHP

13

Variables y algunas funciones
$_SESSION
– Variable superglobal
– Array con las variables que se guardan en la sesión (la clave es el nombre

de la variable)

bool session_start(void)
– Crea una nueva sesión o recupera las variables de una
– En sesiones implementadas con cookies hay que llamar a e
  • Links de descarga
http://lwp-l.com/pdf4201

Comentarios de: Funciones de PHP (0)


No hay comentarios
 

Comentar...

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad