|
Publicité ' | |||||||||||||||||||||||
|
|
#1 | ||
|
Nouveau Membre du Club
![]() Inscription : juin 2004 Messages : 156 ![]() |
Bonjour, j'ai un probleme de sécurité que je n'arrive pas à résoudre, certains utilisateur du site se plaigne qu'ils se connecte sur un autre compte que le leur quand il arrive sur mon site. Voici le code source, si vous pouviez m'aider ca me serait vraiement utile merci @ tous
Code :
|
||
|
|
00
|
|
|
#2 |
|
Membre Expert
![]() ![]() Inscription : janvier 2004 Messages : 1 238 ![]() |
C'est un peu compliqué, mais voici deja quelques remarques :
* Quand tu récupere des resultats d'une requete avec "email = ... AND password = ... " ou avec "ID = ..." tu t'attends a avoir UN SEUL resultat. Or, tout tes tests sont if (mysql_num_rows() > 0). Donc si tu as une faille dans la requete et qu'on réussi a retourner toutes les lignes de la table, ca prendra le 1er enregistrement. Je serais donc pour filtrer avec if (mysql_num_rows() == 1), du coup tu peux enlever les while inutile derriere. * nbchars() est une fonction a toi qui va verifier que "code_validation" existe ? c'est pas un peu leger ? tu veux pas comparer le contenu également ? * tout tes tests == false ou == true, je les remplacerais par === false et === true, surtout pour un formulaire d'identification... c'est plus sur. * $ID_project[FONT=monospace] a l'air d'etre utilisé avant d'avoir été défini, en tout cas on voit pas sa définition. * Est-tu sur de ne pas affecter ailleurs sur ton site la variable de session ID ? * Est-ce toujours sur les memes comptes que les utilisateurs se retrouvent loggé ? * As-tu pu le reproduire chez toi ? et sinon, demande plus d'information a tes utilisateurs (navigateur, procedure *exacte*, configuration (acceptation des cookies))
__________________
PHP : Regle n°1 : mysql_query(...), mysql_connect(...) et mysq_select_db(...) doivent EN DEBUG etre suivies de or die(mysql_error()); (mais jamais en production) Regle n°2 : Mieux encore : mysql_query($requete) or die("$requete<br/>".mysql_error()); Regle n°3 : echo '<pre>';var_dump($var);echo '</pre>'; affiche le contenu et le type d'une variable. Publiez vos textes de fantasy et de science-fiction sur http://www.cercledefaeries.com/concours/ |
|
|
00
|
|
|
#3 |
![]() ![]() Jean-Pierre Inscription : août 2005 Messages : 333 ![]() |
Bonjour,
Quelques commentaires dans ton code n'auraient pas été de trop, d'autant plus que c'est très mal codé, de mon point de vu. (Je te le dis franchement). La seule chose qui me saute aux yeux (grand classique) et qui donne envie d'hurler , c'est que les variables ne sont pas échapées avant d'être utilisées dans tes requêtes MySQL. Pour échapper tes variables dans une requête MySQL, il y'a la fonction mysql_real_escape_string(). Spécialement dédiée. N.B : addslashes() n'est plus d'actualité, ou en tout cas pas dans ce contexte là. Présentement, il est facile pour tes utilisateurs de forger tes requêtes SQL comme bon leurs semble... Et d'accèder aux autres comptes (volontairement ou non !)... Et j'en passe... Un conseil : Recommence tout. Analyse, comprends et test ce que tu codes. Ca t'éviteras des résultats étranges. |
|
|
00
|
Copyright © 2000-2012 - www.developpez.com