Foros del Web » Programando para Internet » PHP »

Permitir solo numeros y letras

Estas en el tema de Permitir solo numeros y letras en el foro de PHP en Foros del Web. Buenos días, Estoy intentando limitar la entrada de caracteres en los textbox pero no lo consigo. Lo que quiero es que solo se puedan introducir ...
  #1 (permalink)  
Antiguo 21/03/2009, 02:50
Avatar de rafaconpu  
Fecha de Ingreso: febrero-2006
Mensajes: 331
Antigüedad: 18 años, 1 mes
Puntos: 3
Pregunta Permitir solo numeros y letras

Buenos días,

Estoy intentando limitar la entrada de caracteres en los textbox pero no lo consigo.

Lo que quiero es que solo se puedan introducir numeros (del 0 al 9) y/o letras (a - z y A - Z, mayúsculas y minúsculas)

Evitar que el resto de caracteres se puedan introducir, por ejemplo "" $ Ç []{}' etc..

¿Porqué quiero esto? Imaginemos que alguien abispado decide hacer una inyección de código en un campo para obtener resultados y que lo consigue. Le estaríamos dando las llaves de nuestra casa y únicamente debería buscarla y probar a abrir.

El querer hacerlo desde PHP es por seguridad puesto que el código PHP no se muestra en la página web si deseas ver el código fuente, mientras que javascript si que lo muestra.

¿Existe alguna función que permita hacer esto? ¿Se debe tener en cuenta el código ASCII para indicarle qué deseas se pueda escribir en el textbox y que el resto no te permita?

Gracias de antemano y espero que sea posible hacer esto.
Un saludo.
  #2 (permalink)  
Antiguo 21/03/2009, 07:09
Avatar de the_web_saint  
Fecha de Ingreso: mayo-2008
Ubicación: localhost/tierra/america/panama
Mensajes: 1.229
Antigüedad: 15 años, 11 meses
Puntos: 43
Respuesta: Permitir solo numeros y letras

Para hacer que no se pueda escribir otros caracteres, se puede, pero con javascript.
Para lo que haces deberás validar con php luego del envio del formulario.

Saludos
__________________
..::The Saint::..
El pesimista se queja del viento; el optimista espera que cambie; el realista ajusta las velas.
  #3 (permalink)  
Antiguo 21/03/2009, 09:12
Avatar de jakoujan  
Fecha de Ingreso: septiembre-2005
Ubicación: Mexico DF
Mensajes: 26
Antigüedad: 18 años, 6 meses
Puntos: 1
Respuesta: Permitir solo numeros y letras

Exacto asi como dice the_web_saint yo tengo este script para evitar inyeccion

Código PHP:
<?
// Evitamos la inyeccion SQL

// Modificamos las variables pasadas por URL
foreach( $_GET as $variable => $valor ){
$_GET $variable ] = str_replace "'" "" $_GET $variable ]);
$_GET $variable ] = str_replace "\"" "" $_GET $variable ]);
}
// Modificamos las variables de formularios
foreach( $_POST as $variable => $valor ){
$_POST $variable ] = str_replace "'" "" $_POST $variable ]);
$_POST $variable ] = str_replace "\"" "" $_POST $variable ]);
$_POST $variable ] = str_replace "á" "&aacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "é" "&eacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "í" "&iacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "ó" "&oacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "ú" "&uacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "Á" "&Aacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "É" "&Eacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "Í" "&Iacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "Ó" "&Oacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "Ú" "&Uacute;" $_POST $variable ]);
$_POST $variable ] = str_replace "ñ" "&ntilde;" $_POST $variable ]);
$_POST $variable ] = str_replace "Ñ" "&Ntilde;" $_POST $variable ]);
}
?>
a parte que nos resuelve el problema de las letras tildadas y las Ñ ñ ahi puedes cambiar datos o incluso podrias poner un script con expresiones regulares para eliminar los datos y caracteres que no te sirvan.

Saludos.
  #4 (permalink)  
Antiguo 21/03/2009, 09:15
 
Fecha de Ingreso: diciembre-2007
Ubicación: Por ahi.
Mensajes: 13
Antigüedad: 16 años, 4 meses
Puntos: 0
Respuesta: Permitir solo numeros y letras

Puedes usar la funcion ereg() haciendo algo asi mas o menos:

Código PHP:
<?php
// La cadena puede tener caracteres de la a-z (mayusculas o minusculas) o numeros del 0-9
// y debe tener 3 caracteres o mas 
$cadena "Hola5000";
if(
ereg("^[A-Za-z0-9]{3,}$"$cadena)){
echo 
true;
}
?>
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 18:59.