|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Apr 2006
Città: Ilê-de-France
Messaggi: 319
|
[PHP-MySQL] problemi login
salve raga ho un problema che non riesco a risolvere...
praticamente è un login semplice semplice mi interessa solo visualizzare se si può accedere o no... ma puntroppo il mio php sembra impazzito e non funziona Codice:
<?php
$conn=mysql_connect("localhost","user","user") or die ("Errore connessione Server MySQL". mysql_error());
mysql_select_db("prova") or die ("Errore connessione al database". mysql_error());
session_start();
$utente=htmlspecialchars($_POST['usr']);
$pass=md5(htmlspecialchars($_POST['psw']));
$query="SELECT nome,password FROM utenti WHERE nome='".$utente."' AND password='".$pass."';";
//ho provato anche a settare $query in questo modo ($query = sprintf("SELECT nome,password FROM utenti WHERE username = '%s' AND user_password = '%s' ;", mysql_real_escape_string($utente), mysql_real_escape_string($pass)); ) senza alcun risultato
$ris=mysql_query($query,$conn);
if(mysql_num_rows($ris))
print("Accesso eseguito correttamente!");
else
print("Nome utente o Password errati!");
?>
ho messo anche echo al posto di print ma non cambia niente
__________________
There is no cloud, it's just someone else computer |
|
|
|
|
|
#2 |
|
Member
Iscritto dal: Oct 2009
Città: In una città
Messaggi: 67
|
Anzitutto ti sconsiglio di utilizzare htmlspecialchars in md5, a meno che chiaramente anche le password in entrata non siano generate con la stessa codifica.
Inoltre htmlspecialchars non serve ad prevenire i mysql inject, piuttosto ti conviene provare ad usare addslashes, oppure mysql_real_escape_string, come hai fatto dopo. Per il resto non sembrano esserci problemi di php. Il post come lo esegui? Sei sicuro che prenda dei dati? Il database è formattato correttamente? Quei campi che richiedi esistono? |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
|
Prima modifichi la password con htmlspecialchars() e poi ne fai un hashing MD5? Rischia di modificarti la password e cambiare l'MD5 in output (anche se i caratteri interessati sono abbastanza inusuali per una password).
Se ne fai l'hashing MD5, per la password non serve proteggerti dalle SQL injections (non arriveranno mai apostrofi e schifezze varie nella query), mentre lo devi fare per il nome utente, e per quello usa mysql_real_escape_string(). ciao EDIT: d'oh, non avevo letto la parte dell'MD5 scritta anche da Fibrizio. Vabbe', un post in più per ricordartelo.
__________________
C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai! Ultima modifica di DanieleC88 : 10-06-2010 alle 10:39. |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Apr 2006
Città: Ilê-de-France
Messaggi: 319
|
grazie ad entrambi
allora sto provando ad usare direttamente il mysql_real_escape_string() i campi che richiedo esistono e sono formattati correttamente in quanto una pagina per la registrazione (quindi con l'INSERT) funziona correttamente per quanto riguarda il post dovrebbe essere fatto correttemente Codice:
<form name="accesso" action="login.php" method="post">
<table align="center" cols="2" rows="3">
<tr>
<td><b>Nome Utente</b></td>
<td><input type="text" name="usr" /></td>
</tr>
<tr>
<td><b>Password</b></td>
<td><input type="password" name="psw" /></td>
</tr>
<tr>
<td></td>
<td><input type="submit" value="Accedi!" /></td>
</tr>
</table>
</form>
__________________
There is no cloud, it's just someone else computer |
|
|
|
|
|
#5 | |
|
Member
Iscritto dal: Oct 2009
Città: In una città
Messaggi: 67
|
Quote:
Ti suggerisco di eseguire un echo su $query Codice PHP:
con ogni probabilità interroghi male il database e questo riporta 0 righe. |
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Apr 2006
Città: Ilê-de-France
Messaggi: 319
|
adesso funziona ma non ho nessun controllo per le injection...
il codice l'ho modificato come segue Codice PHP:
__________________
There is no cloud, it's just someone else computer |
|
|
|
|
|
#7 |
|
Member
Iscritto dal: Oct 2009
Città: In una città
Messaggi: 67
|
sì ti conviene usarlo così
Codice PHP:
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Apr 2006
Città: Ilê-de-France
Messaggi: 319
|
ok grazie
tutto risolto si può chiudere
__________________
There is no cloud, it's just someone else computer |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 13:57.










ho messo anche echo al posto di print ma non cambia niente 









