La descarga está en progreso. Por favor, espere

La descarga está en progreso. Por favor, espere

Introducción a PHP. 1. INTRODUCCIÓN: Diferencias entre ASP y PHP Software propietario Free Software Plataformas Microsoft Varios lenguajes (VBScript,

Presentaciones similares


Presentación del tema: "Introducción a PHP. 1. INTRODUCCIÓN: Diferencias entre ASP y PHP Software propietario Free Software Plataformas Microsoft Varios lenguajes (VBScript,"— Transcripción de la presentación:

1 Introducción a PHP

2 1. INTRODUCCIÓN: Diferencias entre ASP y PHP Software propietario Free Software Plataformas Microsoft Varios lenguajes (VBScript, JavaScript) Multiplataforma Un solo lenguaje: PHP

3 Características de PHP Más rápido que ASP Lenguaje más fácil y potente Integración perfecta con 8 servidores HTTP Acceso a 20 tipos de Bases de Datos Diseño modular de fácil ampliación Licencia abierta

4 Historia y Desarrolladores Fechas Inicio del desarrollo en otoño de 1994 PHP Versión 1 en primavera 1995 PHP Versión PHP Versión PHP Versión 4 en el segundo trimestre de 2000 PHP Versión 5 se encuentra en etapa de planeamiento Equipo de Desarrollo (195 personas con acceso al CVS) Zeev Suraski y Andi Gutmans (Israel) Shane Caraveo (Florida) Stig Bakken (Norway) Andrei Zmievski (Lincoln, Nebraska) Sascha Schumann (Dortmund, Germany) Thies C. Arntzen (Hamburg, Germany) Jim Winstead (Los Angeles) Sam Ruby (Raleigh, NC) Rasmus Lerdorf (San Francisco)

5 Estadísticas de uso Fuente: Netcraft Agosto 2000Netcraft 3,314,634 Dominios, 637,746 Direcciones IP 19,823,296 Dominios analizados PHP instalado en el 16.7% de todos los dominios Fuente: SecuritySpace.com Septiembre 2000 Informe sobre Módulos ApacheSecuritySpace.com 1,322,329 Servidores Apache analizados 429,589 (32.49%) PHP 247,642 (18.73%) Frontpage 133,414 (10.09%) mod_perl 111,576 (8.44%) mod_ssl 78,030 (5.90%) OpenSSL 46,404 (3.51%) ApacheJServ

6 Plataformas soportadas Plataformas (actualidad): UNIX (todas las variantes) Win32 (NT/W95/W98/W2000) QNX Mac (WebTen) OS/2 BeOS Plataformas (en perparación): OS/390 AS/400 Servidores: Apache (UNIX,Win32) CGI fhttpd ISAPI (IIS, Zeus) NSAPI (Netscape iPlanet) Java servlet AOLServer Roxen Servidores (en preparación): Apache 2.0 WSAPI (O'Reilly WebSite) phttpd thttpd

7 Bases de datos soportadas SQL Adabas D Empress IBM DB2 Informix Ingres Interbase Frontbase mSQL Direct MS-SQL MySQL ODBC Oracle (OCI7,OCI8) PostgreSQL Raima Velocis Solid Sybase Otros dBase filePro (sólo lectura) dbm (ndbm, gdbm, Berkeley db)

8 2. El lenguaje PHP

9 2.1. Extensión de los Archivos.php3 Indica código PHP 3.x..php4 Indica código PHP 4.x..php Indica código PHP. Preferiremos esta extensión por ser más genérica..phtml Actualmente en desuso.

10 2.2. Delimitadores echo 'Algunos editores (como el FrontPage) Sólo entienden este método';

11 20 OR Hour(time) Buenas noches. Buenos días. 20 || Hour(time) Buenas noches. Buenos días. 20 || Hour(time)<4) { echo Buenas noches.; } else { echo Buenos días.; } ?> 2.2. Delimitadores. Ejemplo.

12 2.3. Fin de línea print( date("M d, Y H:i:s", time()) ); print ( date( "M d, Y H:i:s", time() ) ;

13 2.4. Comentarios /* Comentarios estilo C. * Pueden extenderse durante varias líneas. */ // Comentarios estilo C++. Hasta fin de línea. # Comentarios estilo Perl. Hasta fin de línea.

14 Variables. Declaración y Uso. NO hace falta declararlas Llevan delante el signo $. $var_1 = 123; $var_2 = hola; $var_3 = $var_1 * 2;

15 $mi_variable = Inicializamos como texto; $mi_variable = 3; // Entero. $mi_variable = 3.14 * $mi_variable; // Float. $mi_variable = new MiClase(); // Objeto. Variables débilmente tipadas (tipo mixed) Variables. Tipado.

16 2.5.2.Variables. Tipado. Conversión automática. PHP realiza conversiones automáticas de tipo: $mivar = 123; echo $mivar; // Se convierte a string $mivar = 3; // Se convierte a entero $mivar = 2 + $mivar; // para realizar la suma

17 2.5.2.Variables. Tipado. Conversión explícita. Operador cast: $mivar = (string)123; Cambiar el tipo de una variable: $mivar = 12; settype($mivar, "double");

18 Variables. Ámbito. En el cuerpo de un archivo, las variables son GLOBALES al archivo y archivos incluidos. En una función, son LOCALES a esa función. Dentro de una clase, sólo pueden ser accedidas a través del operador -> sobre el nombre del objeto.

19 Referencias. Se definen con el carácter &: $alias = &$variable Se puede eliminar una referencia con la función unset(): $a = 1; $b = &$a; unset ($a); // Pero $b sigue valiendo 1

20 2.6. Tipos de datos. Enteros, en decimal, octal o hexadecimal. $MiVar = 123; Punto flotante. $MiVar = 1.3e4; Arrays. $MiVar[2] = 123; Strings. $MiVar = Cadena de texto\n; Objetos: $MiVar = new MiClase();

21 Tipos de datos. Arrays. $MiArray[0] = 1; $MiArray[1] = hola!!; $MiArray[] = 3; echo $MiArray[2]; // 3

22 Tipos de datos. Arrays (2). Funcionan como vectores o tablas hash al mismo tiempo: $MiArray[nombre] = Homer; echo $MiArray[0]; // 1 echo $MiArray[nombre]; // Homer Y pueden tener más de una dimensión: $MiOtroArray[1][pepe][4] = 3 dimensiones!;

23 Tipos de datos. Arrays (3). También se pueden definir con el constructor array() : $OtroArrayMas = array( 1, hola, 5); $YOtroArray = array( 0 => 1, 1 => hola, 2 => 5, 3 => 8, nombre => Homer );

24 Tipos de datos. Strings. Comillas dobles.

25 Tipos de datos. Strings (2). Comillas simples. Si se delimitan entre comillas simples (), las variables no se expanden y además las únicas secuencias de escape que se reconocen son \\ y \' (barra invertida y comillas simples.)

26 Tipos de datos. Strings (3). Here Doc $cadena = <<

27 Tipos de datos. Strings (4). Para concatenar cadenas se utiliza el operador. : $cad = A esta cadena ; $cad = $cad. le vamos a añadir más texto.; Se puede acceder a cada carácter como si fuera un array: $cad2 = Tercer carácter de \$cad : $cad[2];

28 2.7. Constantes. define(SALUDO, Hola, mundo!); echo La constante SALUDO vale. SALUDO; Las constantes se definen con la función define(): Las constantes en PHP se diferencian de las variables en que: no llevan el símbolo del dólar delante. puede accederse a ellas desde cualquier parte del código donde han sido definidas, sin restricciones de ámbito como en las variables. no pueden ser redefinidas o borradas una vez definidas. sólo pueden contener valores escalares, no vectores.

29 2.8. Mayúsculas y minúsculas. Comportamiento mixto en variables y funciones: En las variables, las mayúsculas y minúsculas IMPORTAN. En los nombres de funciones y palabras reservadas, las mayúsculas NO IMPORTAN.

30 Operadores aritméticos.

31 Auto-incremento y auto-decremento.

32 Operadores de bits.

33 Operadores lógicos.

34 Operadores. Asignación, igualdad e identidad.

35 Operadores. Asignación, igualdad e identidad.Ejemplo. $var1 = 1;// Asignación $var2 = 1; $var3 = 1; ($var1 == $var2)// Cierto, son iguales ($var1 == $var3)// Son iguales (tras conversión) ($var1 === $var2)// Cierto, son idénticas ($var1 === $var3)// FALSO, el tipo no coincide

36 Operadores. Asignación, igualdad e identidad. Error. $var1 = 1; $var2 = 2; if( $var1 = $var2 ) { echo iguales; } else { echo distintas; }

37 Comparaciones.

38 Operadores de cadenas. $a = 1; $b = 2; $c = El resultado de. $a. +. $b. es. $a + $b;

39 Atajos en la asignación. += -= *= /= %= &= ^=.= >>= y <<= $var1 += 3;// $var1 = $var1 + 3; $var2 /= 2;// $var2 = $var2 / 2; $var3 >>= 1;// $var3 = $var3 >> 1;

40 Precedencia.

41 Estructuras de control. if … elseif … else if (expresión) { comandos } if (expresión) { comandos_cierto } else { comandos_falso }

42 Estructuras de control. if … elseif … else (2) if (expresion1) { comandos1 } elseif (expresion2) { comandos2 } elseif (expresion3) { comandos3 }... else { comandosElse }

43 while y do … while while (expresión) { comandos } do { comandos } while (expresión);

44 for for (expresión1; expresión2; expresión3) { comandos } $factorial5 = 1; for ($i = 2; $i <= 5; $i++ ) { $factorial5 *= $i; }

45 for (2) for ($factorial5 = 1, $i = 2; $i <= 5; $i++ ) { $factorial5 = $factorial5 * $i; } for ($factorial5=1, $i=2; $i<=5; $factorial5*=$i, $i++);

46 for (3). ASP. ASP // PHP

47 foreach foreach (array as variable) { comandos } $a = array (1, 2, 3, 17); foreach ($a as $v) { print "Valor actual de \$a: $v.\n"; } // Valor actual de $a: 1 // Valor actual de $a: 2 // Valor actual de $a: 3 // Valor actual de $a: 17

48 foreach (2) foreach (array as indice => variable) { comandos }

49 switch switch (variable) { case valor1: comandos1 case valor2: comandos2... case valorN: comandosN default: comandosDefault }

50 switch (2) switch ($i) { case 1: echo Código del 1; case 2: echo Código del 2; case 3: echo Código del 3; break; case 4: echo Código del 4; }

51 2.11. Cierto o falso. Valores numéricos. $x = 1; // $x if( $x ) // se evalúa a cierto $x = 0; // $x definida como el entero 0 if( $x ) // se evalúa a falso

52 2.11. Cierto o falso. Strings. $x = "hello"; // asignamos una cadena a $x if( $x ) // se evalúa a cierto $x = ""; // cadena vacía if( $x ) // evalúa a falso // Excepción: $x = "0"; // cero en una cadena if( $x ) // evalúa a falso // (se convierte a entero)

53 2.11. Cierto o falso. Arrays. $x = array(); // $x es un array vacío if( $x ) // se evalúa como falso $x = array( "a", "b", "c" ); if( $x ) // se evalúa a cierto

54 2.11. Cierto o falso. Objetos. Class Yod {} // clase vacía $x = new Yod(); if( $x ) // se evalúa a falso Class Yod { // clase no vacía var $x = 1; } $x = new Yod(); if( $x ) // se evalúa a cierto

55 2.11. Cierto o falso. Constantes. TRUE es el valor entero decimal 1. FALSE es la cadena vacía.

56 2.12. Funciones. function nombre ($arg_1, $arg_2,..., $arg_n) { comandos return $salida; }

57 2.12. Funciones. (2) Ejemplo. function factorial ($valor) { if ($valor < 0) { return –1; // Error } if ($valor == 0 ) { return 1; } if ($valor == 1 || $valor == 2) { return $valor; } $ret = 1; for ($i = 2; $i <= $valor; $i++) { $ret = $ret * $i; } return $ret; } $factorial5 = factorial(5);

58 2.12. Funciones. (3) Valores por defecto. function enlace($url = { echo Pulsa aquí ; }

59 Funciones. Argumentos por referencia. function MiFuncion(&$var) { $var++; } $a = 5; MiFuncion($a); // Aquí $a == 6

60 Funciones. Devolución por referencia. function &buscar_cliente($nombre) { //... buscamos... return $registro; } $cliente = &buscar_cliente(Juan); echo $cliente->dni;

61 2.13. include y require La sentencia include(arch) incluye y evalúa el archivo especificado. La sentencia require(arch) se sustituye a sí misma con el archivo especificadotal y como funciona la directiva #include de C. El intérprete sale del modo PHP y entra en modo HTML al principio del archivo referenciado, y vuelve de nuevo al modo PHP al final.

62 2.13. include y require Include() se re-evalúa cada vez que se encuentra (y sólo cuando está siendo ejecutada) require() siempre leerá el archivo referenciado, incluso si la línea en que está no se ejecuta nunca (condicional).

63 2.13. include y require require(cabecera.inc); If ($incluir == TRUE) { $archivos = array(uno, dos, tres); foreach ($archivos as $archivo) { include($archivo); }

64 2.14. Variables de Sistema $HTTP_USER_AGENT Nos informa principalmente sobre el sistema operativo y tipo y versión de navegador utilizado por el internauta. Su principal utilidad radica en que, a partir de esta información, podemos redireccionar nuestros usuarios hacia páginas optimizadas para su navegador o realizar cualquier otro tipo de acción en el contexto de un navegador determinado. $HTTP_ACCEPT_LANGUAGE Nos devuelve la o las abreviaciones de la lengua considerada como principal por el navegador. Esta lengua o lenguas principales pueden ser elegidas en el menú de opciones del navegador. Esta variable resulta también extremadamente útil para enviar al internauta a las páginas escritas en su lengua, si es que existen. $HTTP_REFERER Nos indica la URL desde la cual el internauta ha tenido acceso a la página. Muy interesante para generar botones de "Atrás" dinámicos o para crear nuestros propios sistemas de estadísticas de visitas.

65 2.14. Variables de Sistema $PHP_SELF Nos devuelve una cadena con la URL del script que está siendo ejecutado. Muy interesante para crear botones para recargar la página. $HTTP_GET_VARS Se trata de un array que almacena los nombres y contenidos de las variables enviadas al script por URL o por formularios GET $HTTP_POST_VARSSe trata de un array que almacena los nombres y contenidos de las variables enviadas al script por medio de un formulario POST $HTTP_COOKIES_VARS Se trata de un array que almacena los nombres y contenidos de las cookies. Veremos qué son más adelante.

66 2.14. Variables de Sistema $PHP_AUTH_USER Almacena la variable usuario cuando se efectúa la entrada a páginas de acceso restringido. Combinado con $PHP_AUTH_PW resulta ideal para controlar el acceso a las páginas internas del sitio. $PHP_AUTH_PW Almacena la variable password cuando se efectúa la entrada a páginas de acceso restringido. Combinado con $PHP_AUTH_USER resulta ideal para controlar el acceso a las páginas internas del sitio. $REMOTE_ADDR Muestra la dirección IP del visitante. $DOCUMENT_ROOT Nos devuelve el path físico en el que se encuentra alojada la página en el servidor. $PHPSESSIDGuarda el identificador de sesión del usuario. Veremos más adelante en qué consisten las sesiones.

67 3. Programando en PHP

68 Forms. Valores sencillos. Su nombre: Su edad: Hola. Tiene años.

69 Forms. Valores múltiples. Tortilla Paella Fabada Lentejas

70 Forms. Valores múltiples. (php3) Tortilla Paella Fabada Lentejas

71 Sesiones. Una sesión es una cantidad de información que se almacena dentro del servidor con un identificador único de usuario Éste id es enviado aútómaticamente al usuario por medio de cookies.

72 Sesiones. Dentro de ésta sesión se puede almacenar los valores de las variables y disponer de ellas en cualquiera de las páginas en las que se inicie una sesión. Una ventaja extra es que al cambiar el valor de las variables, automáticamente cambia su valor para la sesión

73 Sesiones. bool session_start(void); bool session_register (mixed name [, mixed...]) bool session_destroy(void); // Ejemplo, un contador session_start(); print($contador); $contador++; session_register("contador"); ">Continuar

74 3.3. Cookies. setcookie(PruebaCookie, expiraré dentro de una hora, time() ); setcookie(PruebaCookie,, time()); int setcookie (string nombre [, string valor [, int fin [, string camino [, string dominio [, int seguro]]]]])

75 3.4. Tratamiento de errores. $nombre = '/etc/shadow'; $archivo ($nombre, 'r'); if( !$archivo ) { die("No se pudo abrir el archivo ($nombre)"); }

76 Cadenas. Comparación. int strcmp (string str1, string str2) int strcasecmp (string str1, string str2) // Ejemplo: if (strcmp($a, $b) == 0) { echo iguales; }

77 Cadenas. Subcadenas. string substr (string cadena, int inicio [, int tamaño]) $str = substr('abcdef', 2, 3); // cde $str = substr('abcdef', -2); // ef $str = substr('abcdef', -2, 1); // e $str = substr('abcdef', 1, -2); // bcd

78 Cadenas. Subcadenas. Ejemplo: substr.php3

79 Cadenas. Subcadenas. (2) int strpos (string cadena, string referencia [, int inicio]) int strrpos (string cadena, char referencia) string strstr (string cadena, string referencia) $i = strpos('cadena de prueba', 'de'); // $i = 2 $i = strpos('cadena de prueba', 'de', 5); // $i = 7 $s = strrpos('cadena de prueba', 'de'); // $s = 7 $s = strstr('cadena de prueba', 'de'); // $s = dena de prueba

80 Cadenas. Subcadenas. (2) Ejemplo: cadpos.php3

81 Cadenas. Imprimir y formatear. int printf (string formato [, mixed args...]) string sprintf (string formato [, mixed args...]) 1.Relleno 2.Alineación 3.Número de caracteres 4.Precisión 5.Tipo %El carácter de tanto por ciento. bEntero en binario. cEntero como carácter ASCII. dEntero en decimal. fDouble en punto flotante. oEntero en octal. sCadena. xEntero en hexadecimal (minúsculas). XEntero en hexadecimal (mayúsculas). Secuencias de formato

82 Cadenas. Imprimir y formatear. (2) printf(%02d/%02d/%04d, $dia, $mes, $año); $pago1 = 68.75; $pago2 = 54.35; $pago = $pago1 + $pago2; // echo $pago mostraría "123.1" // Mostrar al menos un dígito entero y exactamente // dos decimales, rellenando con ceros printf ("%01.2f", $pago);

83 Escapar caracteres. SQL. $busca = DAlton; // Habrá que escapar el apóstrofe $sql = SELECT * FROM usuarios WHERE apellido = \. addslashes($busca). \;

84 Escapar caracteres. Shell. string system (string comando [, int valor_salida]) echo system(finger $usuario); ¿Qué pasa si $usuario=pepe ; apachectl stop ? string escapeshellcmd (string comando)

85 Escapar caracteres. HTML. $valor = a>b; echo ; // string nl2br (string cadena)

86 Extraer campos. array explode (string delimitador, string cadena [, int límite]) string implode (string delimitador, array campos) $cadena = implode(:, $campos); $cadena = campo1:campo2:campo3; $campos = explode(:, $cadena);

87 Extraer campos. Expresiones regulares. array split (string delimitador, string cadena [, int límite]) $fecha = "12/4 2002"; $campos = split ('[ /.-]', $fecha);

88 Recorrer un array. $arr = array(1,'cosa',1.57,'gato'=>'raton','perro'=>'gato'); current($arr);// 1 next($arr); // cosa current($arr);// cosa prev($arr); // 1 end($arr); // gato current($arr);// gato key($arr); // perro reset($arr); // 1 each($arr); // array(0,1) each($arr); // array(1,'foo') each($arr); // array(2,1.57) reset(), end(), next(), each(), current(), key()

89 Ordenar un array. sort(): Ordena el array por contenido en orden ascendente. rsort():Ordena por contenido en orden descendente. ksort():Ordena por el índice en orden ascendente. rksort():Ordena por el índice en orden descendente.

90 Otras funciones. string trim (string cadena) string ltrim (string cadena) string rtrim (string cadena) string strtoupper (string cadena) string strtolower (string cadena) string ucfirst (string cadena) Eliminar espacios en blanco: Mayúsculas y minúsculas:

91 Archivos. Abrir y cerrar. int fopen (string nombre, string modo [, int include_path]) int fclose (int identificador) Modos: rSólo lectura. Puntero al inicio. r+Lectura/escritura. Puntero al inicio. wSólo escritura. Se trunca el archivo. w+Lectura/escritura. Se trunca el archivo. aSólo escritura. Puntero al final. a+Lectura/escritura. Puntero al final.

92 Archivos. Leer y escribir. string fgets (int identificador, int tamaño) mixed fscanf (int identificador, string formato [, string var1...]) int feof (int identificador) array file (string archivo [, int include_path]) int fwrite (int identificador, string cadena [, int tamaño])

93 Archivos. Copiar / renombrar / borrar. int copy (string origen, string destino) int rename (string origen, string destino) int unlink (string archivo)

94 Directorios. int chdir (string directorio) int mkdir (string nombre, int modo) int rmdir (string nombre) int opendir (string nombre) string readdir (int identificador) void closedir (int identificador)

95 Directorio. Listado de contenidos. $direcotrio = opendir('.'); while (($archivo = readdir($directorio)) !== FALSE) { echo "$archivo\n"; } closedir($directorio);

96 Archivos. Envío.

archivo: // Contenido de recibir.php echo "Recibido el archivo: ".$archivo_name." \n"; echo "Tamaño del archivo: ".$archivo_size." \n"; echo "Tipo mime: ".$archivo_type." "; rename($archivo, $archivo_name);

97 Archivos. Envío. archivo: // Contenido de recibir1.php echo "Recibido el archivo: ".$archivo_name." \n"; echo "Tamaño del archivo: ".$archivo_size." \n"; echo "Tipo mime: ".$archivo_type." $archivo_name);

98 3.6.6 Pasar Variables por la URL Para pasar las variables de una página a otra lo podemos hacer introduciendo dicha variable dentro del enlace hipertexto de la página destino. La sintaxis sería la siguiente: Mi enlace Estas variables no poseen el símbolo $ delante. Esto es debido a que en realidad este modo de pasar variables no es específico de PHP

99 3.6.6 Pasar Variables por la URL. Ejemplo: origen.html origen.html Pasaje de variables saludo y texto a la página destino.php

100 3.6.6 Pasar Variables por la URL. Ejemplo: destino.php destino.php \n"; echo "Variable \$texto: $texto \n" ?>

101 Pasar variables por formularios Este tipo de transferencia nos permite interaccionar directamente con el usuario. El proceso es similar al explicado para las URLs. Primeramente, presentamos una primera página con el formulario clásico a rellenar y las variables son recogidas en una segunda página que las procesa

102 Pasar variables por formularios. Ejemplo: formulario.html formulario.html Nombre Apellidos

103 Pasar variables por formularios. Ejemplo: destino2.php destino2.php \n"; echo "Variable \$apellidos: $apellidos \n" ?>

104 POO. Definición de una clase. class NombreClase { var $variables; function metodos ($parametros) { codigo }

105 POO. Definición de una clase. Ejemplo. class Coche { var $velocidad; // Velocidad actual // Constructor por defecto. El coche está parado. function coche() { $this->velocidad = 0; } // Constructor que indica la velocidad inicial. function coche($vel) { $this->velocidad = $vel; } // Método acelerar. El coche va más rápido. function acelerar() { $this->velocidad++; } // Método frenar. El coche va más lento hasta frenar. function frenar() { if ($this->velocidad > 0) { $this->velocidad--; }

106 POO. Herencia. class ClaseDerivada extends ClaseBase { // definición de métodos y variables // exclusivos de ClaseDerivada, // y redefinición (especialización) // de métodos de ClaseBase }

107 POO. Herencia. Ejemplo. class CocheFantastico extends coche() { // Frenado instantáneo function frena() { $this->velocidad = 0; } // ¡El coche habla! function habla() { echo Hola, Michael.; } // ¡Salta! function salta() { echo Boing!!; } // Turbo propulsión function turbo() { $this->velocidad = 200; }

108 POO. Creación y uso de objetos. // Creación (instanciación) $MiCoche = new Coche; $MiCocheSeMueve = new Coche(10); // Uso $MiCoche->acelerar(); echo $MiCoche->velocidad; $MiCoche->frenar();

109 BD. Conexión y desconexión. int mysql_connect ([string servidor [:puerto] [:/camino/al/socket] [, string usuario [, string contraseña]]]) int mysql_close ([int identificador]) int mysql_pconnect ([string servidor [:puerto] [:/camino/al/socket] [, string usuario [, string contraseña]]]) int mysql_pclose ([int identificador])

110 BD. Conexión y desconexión. Ejemplo. $link = mysql_connect ("www.mmlabx.ua.es", "nobody", ""); if (!$link) { die ("No se pudo conectar"); } print ("Conexión realizada"); mysql_close ($link);

111 BD. Elegir una BD. int mysql_select_db (string nombre_bd [, int identificador]) if (!mysql_select_db("prueba", $link)) { die (No existe la BD); }

112 BD. Querys. int mysql_query (string query [, int identificador]) int mysql_db_query (string nombre_bd, string query [, int identificador]) int mysql_free_result (int result) $query = "SELECT codigo, nombre, descripcion, creditos, tipo FROM asignatura"; $asignaturas = mysql_query($query, $link); if (!$asignaturas) { die (Error en el query); }

113 BD. Extraer información. int mysql_affected_rows ([int identificador]) int mysql_num_rows (int resultado) array mysql_fetch_row (int resultado) array mysql_fetch_array(int resultado [, int tipo_resultado]) object mysql_fetch_object (int result) array mysql_fetch_lengths (int resultado) int mysql_data_seek (int resultado, int numero_fila)

114 BD. Extraer información. Ejemplos. while ($fila = mysql_fetch_array($asignaturas)) { echo $fila[codigo].. $fila[nombre]. \n; } while ($fila = mysql_fetch_object($asignaturas)) { echo $fila->codigo.. $fila->nombre. \n; }

115 3.9. Acceso a BD unificado. Clase ConexionGenerica. class ConexionGenerica { var $link; function connect($servidor, $usuario, $clave) { echo " El método connect ", "no está implementado en la ", "clase ".get_class($this)." "; return FALSE; } function close() {} function select_db($base_datos) {} function query($query) {} function fetch_array($resultado) {} function free_result($resultado) {} }

116 3.9. Acceso a BD unificado. Clase ConexionMySQL. require ("ConexionGenerica.inc"); class ConexionMySQL extends ConexionGenerica { function connect($servidor="localhost", $usuario="nobody", $clave="") { return $this->link = mysql_connect($servidor, $usuario, $clave); } function close() {} function select_db($base_datos) {} function query($query) {} function fetch_array($resultado) {} function free_result($resultado) {} }

117 3.9. Acceso a BD unificado. Uso. // archivo CreaConexion.inc require ("ConexionMySQL.inc"); $conexion = new ConexionMySQL(); require ("CreaConexion.inc"); $conexion->connect("localhost", "nobody"); $conexion->select_db("prueba", $link); $asignaturas = $conexion->query("SELECT codigo, nombre, descripcion, creditos, tipo FROM asignatura");


Descargar ppt "Introducción a PHP. 1. INTRODUCCIÓN: Diferencias entre ASP y PHP Software propietario Free Software Plataformas Microsoft Varios lenguajes (VBScript,"

Presentaciones similares


Anuncios Google