Diferencia entre revisiones de «Plantilla:PHP/FormulariosConceptosGenerales»
De WikiEducator
Línea 342: | Línea 342: | ||
'''se consideran valores vacíos en esta función'''.}} | '''se consideran valores vacíos en esta función'''.}} | ||
}} | }} | ||
− | *Es | + | *Es muy importante en muchas ocasiones, ver si una variable tiene o no valor. |
− | * | + | |
− | *Para ello usaremos la función ya conocida '''''isset($variable)''''', donde $variable es la variable que queremos ver si tiene valor | + | *Sirve para ver si el usuario ha insertado o no valor en un campo de texto. |
+ | *Sirve para saber si estoy cargando esta página porque he dado un click en el botón submit, o no. | ||
+ | *Para ello usaremos la función ya conocida '''''isset($variable)''''', donde $variable es la variable que queremos ver si tiene valor. | ||
</source> | </source> | ||
</div> | </div> | ||
Línea 517: | Línea 519: | ||
<div class="slide"> | <div class="slide"> | ||
;Filtrando valores | ;Filtrando valores | ||
− | *Independientemente de que el se validen/verifiquen valores en el cliente, | + | *Independientemente de que el se validen/verifiquen valores en el cliente, '''''es obligatorio''''' verificarlo siempre en el servidor. |
− | * | + | *En otro capítulo veremos temas de seguridad en los datos, pero para ver lo peligroso que puede ser, podría ser que el usuario escribiera un script en una caja de texto. Esto en principio no deberíamos de permitirlo. |
+ | *miramos el siguiente código sencillo | ||
+ | <source lang=php> | ||
+ | <?php | ||
+ | $nombre =$_GET['nombre']; | ||
+ | ?> | ||
+ | <!doctype html> | ||
+ | <html lang="en"> | ||
+ | <head> | ||
+ | <meta charset="UTF-8"> | ||
+ | <meta name="viewport" | ||
+ | content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> | ||
+ | <meta http-equiv="X-UA-Compatible" content="ie=edge"> | ||
+ | <title>Document</title> | ||
+ | </head> | ||
+ | <body> | ||
+ | <form action="seguridad1.php"> | ||
+ | <input type="text" name="nombre" id=""> | ||
+ | <input type="submit" name="enviar" id=""> | ||
+ | <?php echo $nombre ?> | ||
+ | </form> | ||
+ | </body> | ||
+ | </html> | ||
+ | </source> | ||
+ | *Ahora observamos lo que ocurre ejecutando esto en chrome y firefox escribiendo en la caja de texto | ||
+ | <script>alert "Cudado!!! esto podría ser peor!!!</source> | ||
+ | ;Escribimos en chrome: | ||
+ | [[Archivo:seguridad1_chrome_cliente.png]] | ||
+ | ;Vemos como '''''chrome''''' corta lo que considera un posible ataque '''''xss''''': | ||
+ | [[Archivo:seguridad1_chrome_servidor.png]] | ||
+ | ;Escribimos el código en firefox | ||
+ | [[Archivo:seguridad1_firefox.png]] | ||
+ | ;Vemos como en firefox sí que se puede ejecutar XSS | ||
+ | [[Archivo:seguridad1_firefox_servidor.png]] | ||
+ | |||
+ | {{Tip|Cross Site-Scripting XSS Ataques que consisten en ejecutar código de script en el cliente y obtener valores para el servidor (claves, cookies, variables de sesión o redireccionar a otras url}} | ||
+ | *Hay mucha formas de evitar esto, como htmlpurifier http://htmlpurifier.org/ que analizaremos cuando veamos seguridad en la web. | ||
+ | *De momento nos limitaremos (que ya es una buena forma de garantizar contenido correcto y evitar problemas)a usar funcions del tipo filter http://php.net/manual/es/function.filter-var.php. | ||
Tenemos la opción de filtar_var() y filter_input(). | Tenemos la opción de filtar_var() y filter_input(). | ||
;filter_var($variable, $filtro) | ;filter_var($variable, $filtro) |
Revisión de 08:53 29 oct 2017
- Por defecto los valores son pasados por GET
- Este método es fácil de ver pues se viauliza en el URL, apareciendo como parte de él separado por el signo interrogación con parejas variable=valor.
Ejemplo
| |
Tip: El name es al servidor lo mismo que el id es al cliente, con id podéis acceder a los valores de los elementos con javascript, con el name lo haremos en php
<form action="mifichero.php" method="GET"> Nombre <input type=text name = 'nombre' value='maría'> Apellido <input type=text name = 'apellido' value='Ruiz'> <br /> <input type=submit value=enviar> </form>
Dos cajas de texto y el botón submit
|