Sécurisation des chaines de caractères

  Information

2 fonctions permettent de sécurité les variables contre les injections SQL et XSS avant export SQL.


Information sur les mises à jour

Dernière mise à jour :

    29 Aout 2019
    fonctionnement du code vérifié

10 541  vues
Compatibilité du code
PHP 5, PHP 7 et PHP 8
  code source classé dans   Sécurité

 
 01    
 02    
 03    
 04    
 05    
 06    
 07    
 08    
 09    
 10    
 11    
 12    
 13    
 14    
 15    
 16    
 17    
 18    
 19    
 20    
 21    
 22    
 23    
 24    
 25    
 26    
 27    
 28    
 29    
 30    
 31    
 32    
                               
/*------------------------------*/
/*
Titre : Sécurisation des chaines de caractères

Auteur : Boustifire
Date édition : 27 Avril 2008
Date mise a jour : 29 Aout 2019

Rapport de la maj:
- fonctionnement du code vérifié
*/
/*------------------------------*/

// Sécurise la chaine de caractères contre les injection XSS
function securiseChaineTxt($string) {

// On convertit les caractères spéciaux en entités HTML
$string = htmlspecialchars ($string);
// On sécurise la variable contre les injection SQL
$string = $conn->real_escape_string($string);

return $string;
}

// Sécurise un nombre (si on envoi 145APL, la fonction renvoie 145)
function securiseNombre($nombre) {
$nombre = intval ($nombre);
// On ne retourne dans la variable que les nombres

return $nombre;
}
?>

      Fonctions du code - Doc officielle PHP

Détail    php.net  
Description
Versions PHP
    htmlspecialchars
Convertit les caractères spéciaux en entités HTML
PHP 4, 5, 7 et 8
    intval
none
PHP 4, 5, 7 et 8
    return
Retourne le controle du programme au module appelant
PHP 4, 5, 7 et 8

[4]

  • avatar

    Invité

    16 Aout 2012 à 17:45

    Je ne pense pas qu'il faille supprimer le code, les commentaires donnent de bonnes pistes et relève les erreurs. Ce qui est très utile :)

  • avatar

    Matt

    01 Mai 2008 à 12:30

    Je plussoie fortement aux dires de Emacs : Aucun interet -> code a supprimer.

  • avatar

    Emacs

    01 Mai 2008 à 09:28

    Ce code n'a absolument aucun intérêt pour les raisons suivantes :

    1/ On ne fait pas de htmlspecialchars() avant insertion en BDD mais en sortie. On privilégie les données brutes en BDD. Et ce n'est pas une chaine HTML qui peut être dangereuse pour MySQL.

    2/ mysql_real_escape_string() c'est bien mais si je n'utilise pas MySQL ? Et en fin de compte, en retirant le htmlspecialchars(), il ne nous reste que mysql_real_escape_string(), donc ce n'est plus la peine de créer une fonction par dessus.

    3/ Pour le filtrage de données, il y'a l'extension Filter depuis PHP 5.2 et je te recommande d'utiliser PDO pour l'accès à la BDD. En utilisant par exemple les requêtes préparées, c'est PHP directement qui gèrera la sécurité des données.

    ++

  • avatar

    Nixi54

    28 Avril 2008 à 10:21

    Oo, 1 ptit snipet anti spam, je pense essentiellement a la fonction contre les injections SQL:mysql_real_escape_string

    Un peu short quand même ton code mais utile.


 Autres snippets qui pourraient vous intéresser

Classe multi utilisation sur les chaines de caractères

Compatibilité : PHP 7, PHP 8

Classe sur les sur les chaines de caractères regroupant des fonctions de base PHP sur les chaines. Code compatible php7 et php 8

Comparer l'égalité entre 2 chaines

Compatibilité : PHP 5, PHP 7, PHP 8

2 fonctions utiles pour comparer 2 chaines de caractères. L'une est sensible à la casse et l'autre est insensible à la casse.

Vérifie si 1 chaine ne contient aucun caractère alphanumérique

Compatibilité : PHP 5, PHP 7, PHP 8

Fonction qui vérifie si votre chaine ne contient aucun caractère alphanumérique.

* Requêtes exécutées avec Recherche Contextuelle

  Les derniers scripts PHP / MySQL

Web ERP Accounting 5.0.1

Script PHP / MySQL
Langue langue us
Date  aujourd'hui
Taille 69 Mo
Catégorie Logiciels

Dolibarr ERP 23.0.0

Script PHP / MySQL
Langue langue fr
Date  aujourd'hui
Taille 88 Mo
Catégorie Logiciels

Simple Machines Forum 2-1-7

Script PHP / MySQL
Langue langue fr
Date  aujourd'hui
Taille 4 Mo
Catégorie Forums

Forms Tools 3.1.1

Script PHP / MySQL
Langue langue en
Date  aujourd'hui
Taille 11 Mo
Catégorie Formulaires

MiniBB 3.7.1

logo miniBB
Langue langue en
Date  aujourd'hui
Taille 0.51 Mo
Catégorie Forums

Nocc 1.9.15

Script PHP / MySQL
Langue langue us
Date  hier
Taille 3 Mo
Catégorie Email-Emailing
avatar

Boustifire

  27 Avril 2008

  SOURCE   Télécharger

Information sur les mises à jour

Dernière mise à jour :

    29 Aout 2019
    fonctionnement du code vérifié

10 541 Vues
Compatibilité du code
PHP 5, PHP 7, PHP 8