Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] PHP OO ¿Cómo Elimanar el uso de la comilla?

Estas en el tema de ¿Cómo Elimanar el uso de la comilla? en el foro de PHP en Foros del Web. Hola amigos, disculpen si el tema es duplicado; es la primera vez que publico. Mi pregunta es sobre lo siguiente: he creado una página utilizando ...
  #1 (permalink)  
Antiguo 03/11/2015, 17:18
 
Fecha de Ingreso: septiembre-2014
Mensajes: 10
Antigüedad: 9 años, 7 meses
Puntos: 0
¿Cómo Elimanar el uso de la comilla?

Hola amigos, disculpen si el tema es duplicado; es la primera vez que publico.
Mi pregunta es sobre lo siguiente: he creado una página utilizando php y mysqli y al consultarlo tendría que ser de la siguiente manera index.php?id=1 pero como evitar que alguien lo modifique de la siguiente manera index.php?id=1' ya que al agregar la comilla genera un error y mi intención es evitar ese error.
He buscado información y no he encontrado nada, si alguien me puede ayudar se lo agradecería.
  #2 (permalink)  
Antiguo 03/11/2015, 17:54
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: ¿Cómo Elimanar el uso de la comilla?

Cita:
ya que al agregar la comilla genera un error y mi intención es evitar ese error.
Eso es porque al momento de hacer tus consultas no tienes cuidado y no escapas apropiadamente los datos, ¿o exactamente cómo haces las cosas?

La otra, es que siendo un valor numérico le hagas type-casting para forzar el valor y evitar posibles caracteres errados:
Código PHP:
Ver original
  1. $x = "1'";
  2. $valid_x = (int) $x; // 1

Por favor, investiga acerca de SQL-Injection en el foro, hay muchos temas que hablan de lo mismo: ya que se trata de algo habitual y bien conocido.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 04/11/2015, 17:02
 
Fecha de Ingreso: septiembre-2014
Mensajes: 10
Antigüedad: 9 años, 7 meses
Puntos: 0
Respuesta: ¿Cómo Elimanar el uso de la comilla?

Soy nuevo en mysql y php, y por más que he leído no podido comprender bien como evitar la famosa "comilla", ¿Cómo sería entonces la implementación de Type-Casting?
Yo estoy llamando la información a la base de datos con el método GET es decir mi código esta de la siguiente manera:
Código PHP:
 $id=$_GET['estudios'];
    
$query="SELECT * FROM metadatos WHERE idmeta=" $id;
    
$resultado=$mysqli->query($query); 
En el navegador la url sería de la siguiente manera www.ejemplo.com/index.php?estudios=1
la cuestión es evitar cuando alguien ponga en el navegador
www.ejemplo.com/index.php?estudios=1' agregando la ( ' ) y que salga un error de mysql.
Disculpen por la molestia.
  #4 (permalink)  
Antiguo 04/11/2015, 17:11
Avatar de chronos682  
Fecha de Ingreso: febrero-2004
Ubicación: Tunja - Boyacá - Colombia
Mensajes: 627
Antigüedad: 20 años, 2 meses
Puntos: 69
Respuesta: ¿Cómo Elimanar el uso de la comilla?

Siempre que vayas a hacer una consulta a la BD escapa los caracteres que podrían ocasionar errores, problemas o ataques de inyección. Para eso mysqli dispone de una función específica. Lee esto.
__________________
Si te gustó la respuesta dale +1

HERNÁN G. SIABATO M.
[email protected]
  #5 (permalink)  
Antiguo 08/01/2016, 01:26
 
Fecha de Ingreso: septiembre-2014
Mensajes: 10
Antigüedad: 9 años, 7 meses
Puntos: 0
Respuesta: ¿Cómo Elimanar el uso de la comilla?

Muchas gracias por la ayuda, ya resolví el problema con las comillas, pero después me encontré con otro problema y es que por ejemplo yo cuento con un archivo llamado perfil.php y se consulta de la siguiente manera perfil.php?id=1 pero por ejemplo cuando alguien lo modifica y pone solo perfil.php? o perfil.php?cualquier letra, lo que hago es incluir un archivo de error si el link no cumple con los requisitos. Ahora al hacer esto me sale un pequeño error de "Notice: Undefined variable" lo único que se me ocurrió es esconder ese error pero se que no es correcto me muestra bien el include de error y todo, lo único que arriba del contenido me sale ese error.
  #6 (permalink)  
Antiguo 08/01/2016, 06:23
Avatar de chronos682  
Fecha de Ingreso: febrero-2004
Ubicación: Tunja - Boyacá - Colombia
Mensajes: 627
Antigüedad: 20 años, 2 meses
Puntos: 69
Respuesta: ¿Cómo Elimanar el uso de la comilla?

Eso es porque intentas usar una variable que no existe, en este caso al omitir id en la url se produciría ese error. Siempre debes usar isset para saber si una variable está definida o no antes de usarla.
__________________
Si te gustó la respuesta dale +1

HERNÁN G. SIABATO M.
[email protected]
  #7 (permalink)  
Antiguo 13/01/2016, 17:06
 
Fecha de Ingreso: septiembre-2014
Mensajes: 10
Antigüedad: 9 años, 7 meses
Puntos: 0
De acuerdo Respuesta: ¿Cómo Elimanar el uso de la comilla?

Muchas gracias a todos ya todo fue solucionando.
Solo una ultima pregunta, ¿Qué opinan de este código?
¿Será inseguro?

Código PHP:
if(isset($iduser)){
$ssql "SELECT * FROM datos WHERE iduser=" $iduser;
}
if(isset(
$ssql)){
$resultado $mysqli->query($ssql);
}
if(empty(
$resultado)){
echo 
"<div id=\"contenedor\"><h1>no existe ninguna fila con este nombre</h1></div>";
}else{
    include(
"scripts/table_celula/num_rows.php");
}
if(isset(
$numrows)){
   if (
$numrows>0){
    while(
$fila=$resultado->fetch_object()){
       include(
"scripts/table_celula/html.php");
    }
 }
}
if(isset(
$numrows)){
   if(
$iduser>$numrows){
  echo 
"<div id=\"contenedor\"><h1>no existe ninguna fila con este id</h1></div>";
   }
}else{
   include(
"scripts/index.php");


Etiquetas: mysql
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 00:06.