Accueil > > > SÉCURISATION DE FORMULAIRE
SÉCURISATION DE FORMULAIRE
Information sur la source
Description
Bonjour, j'ai lu sur divers forums que l'injection sql peut etre dangereux si on sécurise mal le traitement des données d'un formulaire vers la page de traitement. J'ai lu qu'il fallait faire un "mysql_real_escape_string" sur les données postée pour empécher des injections de code du genre "OR a = a" , ou \' OR \'a\'=\'a .. Je vais partager une partie du code que j'ai mis en place pour renforcer un peu plus la sécurité, dites moi ce que vous en pensez, et si c'est une mauvaise méthode..! Cette méthode consiste à éviter les "=" ou "<" ou ">" ou "?" ou "+" dans les chaines postées. Pour un formulaire classique de connection : <form method="post" name="form_connect" action="traitement_du_fichier.php"> <input type="text" name="pseudo"/> <input type="password" name="pass" /> <input type="submit" value="ok" name="envoi" /> </form>
Source
- if(isset($_POST['pseudo'])){
- $chaine_a_tester=$_POST['nom_du_client'].$_POST['password_du_client'];
- $error="";
- // caracteres interdit: = < > + ?
- // Si un de ces caractere est dans le $chaine_a_tester, alors on rajoute le chiffre de sa position dans la chaine, dans la variable $error qui ne sera plus vierge: strpos() renvoie ce chiffre.
- $caractere_interdit="=";
- $error.=strpos($chaine_a_tester,$caractere_interdit);
- $caractere_interdit="<";
- $error.=strpos($chaine_a_tester,$caractere_interdit);
- $caractere_interdit=">";
- $error.=strpos($chaine_a_tester,$caractere_interdit);
- $caractere_interdit="?";
- $error.=strpos($chaine_a_tester,$caractere_interdit);
- $caractere_interdit="+";
- $error.=strpos($chaine_a_tester,$caractere_interdit);
- // Si $error est toujours vierge, alors tout est, on peut tester si le pseudo et le password correspondent
- if($error==""){
- $login=mysql_real_escape_string($_POST['nom_du_client']);
- $pass=mysql_real_escape_string($_POST['password_du_client']);
- $sql = "SELECT login,password FROM login WHERE login='".$login."' AND password = '".$pass."'";
- $sql2=mysql_query($sql) or die(mysql_error());
- $slq3=mysql_num_rows($sql2);
- if($sql3==1){
- echo "Login et mot de passe valide";
- }else{
- echo "Login ou mot de passe invalide";
- }
-
- }else{
- // Si la variable $error n'est pas vierge, c'est que les caractere interdits ont été rentrés, peut etre tentative de piratage?!
- echo "Certains champs sont interdit car trop dangereux, et votre pseudo ou mot de pass sont incorrects!";
- }
- }
if(isset($_POST['pseudo'])){
$chaine_a_tester=$_POST['nom_du_client'].$_POST['password_du_client'];
$error="";
// caracteres interdit: = < > + ?
// Si un de ces caractere est dans le $chaine_a_tester, alors on rajoute le chiffre de sa position dans la chaine, dans la variable $error qui ne sera plus vierge: strpos() renvoie ce chiffre.
$caractere_interdit="=";
$error.=strpos($chaine_a_tester,$caractere_interdit);
$caractere_interdit="<";
$error.=strpos($chaine_a_tester,$caractere_interdit);
$caractere_interdit=">";
$error.=strpos($chaine_a_tester,$caractere_interdit);
$caractere_interdit="?";
$error.=strpos($chaine_a_tester,$caractere_interdit);
$caractere_interdit="+";
$error.=strpos($chaine_a_tester,$caractere_interdit);
// Si $error est toujours vierge, alors tout est, on peut tester si le pseudo et le password correspondent
if($error==""){
$login=mysql_real_escape_string($_POST['nom_du_client']);
$pass=mysql_real_escape_string($_POST['password_du_client']);
$sql = "SELECT login,password FROM login WHERE login='".$login."' AND password = '".$pass."'";
$sql2=mysql_query($sql) or die(mysql_error());
$slq3=mysql_num_rows($sql2);
if($sql3==1){
echo "Login et mot de passe valide";
}else{
echo "Login ou mot de passe invalide";
}
}else{
// Si la variable $error n'est pas vierge, c'est que les caractere interdits ont été rentrés, peut etre tentative de piratage?!
echo "Certains champs sont interdit car trop dangereux, et votre pseudo ou mot de pass sont incorrects!";
}
}
Conclusion
Il est aussi possible de tester si un champ email est valide avec ce code par exemple:
$adresse=$_POST['pseudo']; $carac_obligatoire= "@"; $carac_arobas=strpos($adresse,$carac_obligat oire); $carac_obligatoire2="."; $carac_point=str pos($adresse,$carac_obligatoire2); if($carac_aro bas<0 && $carac_point<0){ echo "Email valide"; }else{ echo "email invalide"; }
Historique
- 16 juin 2010 01:55:05 :
- Rajout de
$caractere_interdit="?";
$error.=strpos($chaine_a_tester,$caractere_interdit);
$caractere_interdit="+";
$error.=strpos($chaine_a_tester,$caractere_interdit);
- 16 juin 2010 01:55:31 :
- Rajout de
$caractere_interdit="?";
$error.=strpos($chaine_a_tester,$caractere_interdit);
$caractere_interdit="+";
$error.=strpos($chaine_a_tester,$caractere_interdit);
- 16 juin 2010 08:09:17 :
- Amélioration de la requete SqL suite au commentaire
Sources de la même categorie
RÉCUPÉRER LES MINIATURES D'UNE VIDÉO YOUTUBERÉCUPÉRER LES MINIATURES D'UNE VIDÉO YOUTUBE Le code est simple, il permet depuis une url youtube de récupérer son identifiant et de se connecter au serveur de miniatures pour en récupérer les im...
par tefa24600
CONVERTISSEUR DE NOMBRES EN TEXTECONVERTISSEUR DE NOMBRES EN TEXTEQu'est-ce ? Un convertisseur de nombre en texte.
Ses particularités?
- pas de limitation sur la taille du nombre (traitement en string, et non en ...
par macruz
CODAGE TEXTE >HTML, ISO, SPECIALCHARS, URL ET DECODAGECODAGE TEXTE >HTML, ISO, SPECIALCHARS, URL ET DECODAGECe script php permet, comme son nom l'indique de coder un texte pour remplacer les caractères spéciaux, ou apprendre à comprendre les htmlentities, sp...
par Salva9473
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
recuperation de chaine avec espaces dans un formulaire [ par blero91 ]
warning : debutantj'ai cree un formulaire avec un select.dans le select, j'ai mis des chaines avec espaces.lorsque je fait un get, je ne recupere que
Formulaire et sécurité [ par ivanmac ]
Bonjour, Depuis quelques temps un petit malin s'amuse avec le formulaire d'inscription à la newsletter d'un site dont je m'occupe. N'étant pas un exp
Delimiteur de chaine de caracteres [ par phpwankenobi ]
Bonjour,Je ne sais pas comment utiliser le dlimiteur "\" pour delimiter les chaines de caracteres, en clair je souhaite recuperer et/ou passer correct
sécurité d'une formulaire [ par paibafall ]
Bonjours je suis vraiment content d'etre un membre.je suis enterain d'utiliser un script qui permet de sécuriser et de gerer les utilisatreurs par mot
Sécurité formulaire, problème réinitilisation token, cache navigateur [ par nhefti ]
Bonjour,J'utilise pour sécuriser l'envoi de mes formulaires un système de token que je stocke d'une part dans une variable de SESSION de l'autre dans
tableau qui est vide ou qui ne veut pas se créer [ par kifouillou ]
Bonjour à tous,j'ai déjà posé le problème, mais comme je n'avance pas je me permets de relancer. J'ai 2 pages, une avec un formulaire avec des cases à
Envoie d'une chaine de caractère dans l'url [ par hopenot666 ]
Bonjour à tous, J'ai fabriqué un petit formulaire qui me permettrai d'envoyer une chaine de caractères dans l'url mais je voudrai y insérer que le te
Sécurité sur un document [ par venver ]
Bonjour à tous, J'ai fait un script d'instant gagnant en php avec un décompteur et quand ce décompteur est à zero il affiche une formulaire de contac
Sécurité Formulaire php. Dangereux ou pas? [ par KcHeY ]
Bonjour all, J'ai entendu parler de faille(s) php et j'aurai souhaiter savoir si j'était concerné. J'ai un formulaire et un bouton (sur une page html
récupération des données [ par saritazw ]
Salut, je suis entrain de créer un formulaire dans une page html. Le problème que j'ai pas pu récupérer les données que j'ai entré. J'utilise Wampserv
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|