Précédent   Forum des professionnels en informatique > PHP > Langage > Sessions
Sessions Forum d'entraide sur les sessions avec PHP. Avant de poster -> FAQ sessions, Cours sessions et Sources sécurité
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 03/02/2012, 12h49   #1
Invité régulier
 
Inscription : avril 2004
Messages : 17
Détails du profil
Informations forums :
Inscription : avril 2004
Messages : 17
Points : 6
Points : 6
Par défaut Se protéger des injections sql

Bonjour,

l'un de mes sites a été victime d'un piratage, par injection d'une requête php.
ça ne m'était jamais arrivé auparavant, je cherche donc une solution pour sécuriser tout ça.

l'injection a permis d'accéder aux identifiants de connexions de la base de donnée.

ma question est donc la suivante :
si je remplace ma page de connexion par un htacces htpasswd, cela permettra donc de ne plus donner l'accès à la base de donnée des identifiants. est-ce que cela sera suffisant ?

dois-je revoir d'autres pages dans mon admin aussi ?

d'avance merci
elizabeth est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/02/2012, 13h00   #2
Membre éclairé
 
Avatar de hariman
 
Homme Luc Hariman RANDRIANOMENJANAHARY
Développeur Java
Inscription : janvier 2008
Messages : 175
Détails du profil
Informations personnelles :
Nom : Homme Luc Hariman RANDRIANOMENJANAHARY
Localisation : Ile Maurice

Informations professionnelles :
Activité : Développeur Java
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : janvier 2008
Messages : 175
Points : 349
Points : 349
Envoyer un message via MSN à hariman Envoyer un message via Skype™ à hariman
Bonjour,

Utilise la fonction mysql_real_escape_string() sur les valeurs obtenues à partir d'un formulaire. Cela permet d'éviter l'insertion de codes sql dans les valeurs d'un formulaire.
__________________
Les boutons et adorent être cliqués, donc ne les oubliez pas
hariman est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/02/2012, 03h11   #3
Futur Membre du Club
 
Mamadou Saliou DIALLO
Administrateur systèmes et réseaux
Inscription : juillet 2011
Messages : 71
Détails du profil
Informations personnelles :
Nom : Mamadou Saliou DIALLO
Localisation : Guinée

Informations professionnelles :
Activité : Administrateur systèmes et réseaux
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : juillet 2011
Messages : 71
Points : 17
Points : 17
Exemples

Code :
1
2
3
4
5
6
7
8
9
 
//connexion à la base donnée
	$connexion=mysql_connect("localhost", "root", "" )or die("cannot connect" );
	mysql_select_db("basedugenie" )or die("cannot select DB" );
	mysql_query("SET NAMES 'utf8'" );
 
$pseudo=mysql_real_escape_string($_POST["Pseudo"]);
		$email=mysql_real_escape_string($_POST["Email"]);
		$motdep=mysql_real_escape_string($_POST["pwd1"]);
onesat est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/02/2012, 17h45   #4
Membre éclairé
 
Inscription : mai 2008
Messages : 359
Détails du profil
Informations forums :
Inscription : mai 2008
Messages : 359
Points : 397
Points : 397
Il vaut mieux éviter les fonctions mysql_* désormais, préferez à la place PDO ou mysqi, et utilisez des requêtes préparées. Zéro risque d'injection dans ce cas.

Et pour nettoyer ou valider les données au besoin, utilisez les filters.
Tsilefy est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h15.


 
 
 
 
Partenaires

Hébergement Web