IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Comment encrypter solidement les données sensibles utilisateurs et les stocker dans un Nouveau Fichier PHP ?


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2013
    Messages
    452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2013
    Messages : 452
    Points : 66
    Points
    66
    Par défaut Comment encrypter solidement les données sensibles utilisateurs et les stocker dans un Nouveau Fichier PHP ?
    BONJOUR.

    Voici les codes concernés:


    CODE HTML DU FORMULAIRE :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
                <form method="post" action="pract.php">
     
                <input placeholder="CC Number" type="text" name="number">
                    <input placeholder="Full name" type="text" name="name">
                    <input placeholder="MM/YY" type="text" name="expiry">
                    <input placeholder="CVC" type="text" name="cvc">
    		<input name="submitButton" type="submit" id="submitButton" value="Add Card" />
                </form>

    Ensuite le Code PHP de l'Action du Formulaire (pract.php) de HASH que j'ai fait pour hasher les Numéros CC récupérés et entrés par les Utilisateurs :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    <?php
     
     
     
    // On récupère le Numéro CC entré par l'utilisateur
     
    $num = $_POST["number"]; 
     
    	$name = $_POST["name"];
     
    	$expiry = $_POST["expiry"];
     
    	$cvc = $_POST["cvc"];
     
    	      $id	= $_POST['id'];
     
     
     
    // On prends la longueur de la chaine
     
    $code = strlen($num);
     
    // On fait quelques opérations
     
    $code = ($code * 4)*($code/3);
     
    // Le premier sel correspond à la longueur du Numero
     
    $sel = strlen($num);
     
    // Le deuxième sel est égal à la longueur des chaines $code et $mdp
     
    $sel2 = strlen($code.$num);
     
    // On termine en beauté avec quelques hashs
     
    $texte_hash = sha1($sel.$num.$sel2);
     
    $texte_hash_2 = md5($texte_hash.$sel2);
     
     
    // On assemble tout ça pour obtenir une chaine de 82 caractères
     
    $final = $texte_hash.$texte_hash_2;
     
    // On supprime 2 caractère pour brouiller les pistes (ici 7 et 8)
     
    substr($final , 7, 8);
     
    // On finit par tout mettre en majuscule
     
    $final = strtoupper($final);
     
     
    ?>

    Mon objectif est :

    1- D'encrypter solidement les données du Formulaires HTML ci-dessous et de les afficher après sous la forme "1234 **** **** 5678" soit le Numéro incomplet dont les étoiles au milieu.

    2- Je n'aimerais pas les stocker dans la Base de Données en procédant à la Requête INSERT INTO mais plutôt je souhaiterais les enregistrer dans un Nouveau Fichier PHP (infoscard.php) du Script lui-même pour après les afficher.

    3- Sachant que le Numéro est de 16 Chiffres dont 4 x 4, comment réussir à les afficher dans l'espace Utilisateur sous la forme de "1234 **** **** 5678" et selon le Numéro qui convient à Chaque Utilisateur connecté un peu comme si je pouvais afficher les informations des utilisateurs en utilisant $_SESSION ???

    Merci de m'aider s'il vous.

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Hum... si je comprends bien, tu es en train de faire un système d'enregistrement de carte bancaire, que je suppose être couplé avec un système de paiement en ligne.

    Attention ! les données bancaires sont extrêmement sensibles. Tu ne peux pas stocker n'importe quoi, n'importe comment :
    Les sites marchands peuvent conserver ces données à condition qu'ils aient recueilli votre accord exprès et qu’ils vous informent de l’objectif poursuivi. Cet accord nécessite une démarche active de votre part. Pour la matérialiser sur une boutique en ligne, il est conseillé d'utiliser par exemple une case à cocher. Par défaut, cette case doit être décochée.
    La conservation du numéro de carte bancaire ne doit pas constituer une condition d'utilisation du service. Le fait pour un client de refuser qu'un site marchand conserve ses coordonnées bancaires ne doit pas l'empêcher d'accéder aux services proposés par le site
    Dans le but de se prémunir contre les fraudes, un site marchand peut vous demander le cryptogramme visuel de votre carte bancaire. Le but est de vérifier que vous êtes bien le titulaire de la carte . Ce cryptogramme visuel ne doit en aucun cas être conservé.
    La CNIL exige que les données bancaires soient cryptées par l’intermédiaire d’un algorithme de chiffrement dit "fort". Cela signifie que les données bancaires sont rendues incompréhensibles sauf pour l’éditeur du site internet. L’accès au fichier contenant ces données doit également être restreint au sein du personnel du site internet. Les accès et les liaisons au site marchand doivent être également sécurisés. Cela signifie que l’adresse des pages des formulaires de paiement doit être en https par exemple, ce que vous pouvez vérifier en regardant l’adresse du site.
    CNIL - Un site marchand peut-il conserver mes données bancaires ?
    CNIL - Utilisation des cartes bancaires pour le paiement à distance

    Cela étant dit, dans quel but veux-tu conserver ces données ? pour pouvoir réutiliser la même carte pour un autre achat ?
    Dans ce cas, tu peux stocker le numéro de carte et la date de validite (pas le cryptogramme).
    Je n'y connais pas grand chose en chiffrage, mais il te faut un chiffrage fort et réversible, si tu veux pouvoir réutiliser les données sans qu l'utilisateur ait à les re-taper. Un hash ne convient que si tu veux pouvoir faire une comparaison avec quelque chose que l'utilisateur fournit.
    Personellement, je stockerais également une version tronquée du numéro pour l'affichage, histoire de n'accéder au numéro complet que lorsque j'en ai vraiment besoin.

    Une raison pour laquelle tu ne veux pas utiliser de base de données ? Il va bien falloir que tu relies les données de cette carte avec les utilisateurs de ton site...

  3. #3
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 230
    Points
    20 230
    Par défaut
    C'est bien joli de hasher tes numéros mais tu en fais quoi de ce hash après ? Tu ne pourra jamais retrouver la valeur originale et d'après ce que je comprend tu souhaites réutiliser les données saisie par l'utilisateur..

    Un simple chiffrement à l'aide d'un standard tel que AES me semble plus adapté (ou alors j'ai pas compris ton besoin)

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Au passage "embrouiller les pistes" ce n'est pas une bonne méthode de sécurisation.
    Une bonne sécurisation c'est utiliser une mécanique robuste, pas d'utiliser une mécanique secrète : les plus puissants algorithmes de chiffrement sont parfaitement connus.

  5. #5
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Pour illustrer la remarque de Sab' : c'est comme choisir entre planquer ses bijoux dans une chaussette retournée au fond de ton tiroir à lingerie, en se disant qu'un cambrioleur ne pensera pas à regarder là, ou dans une solide coffre-fort, qui, même si il n'est pas discret, résistera quand même vachement mieux qu'un tiroir de commode...

Discussions similaires

  1. Réponses: 2
    Dernier message: 13/08/2014, 12h28
  2. Réponses: 4
    Dernier message: 02/12/2013, 10h03
  3. Réponses: 4
    Dernier message: 02/05/2009, 17h56
  4. Protéger les données sensibles
    Par peofofo dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 19/03/2009, 21h41
  5. Réponses: 12
    Dernier message: 14/02/2008, 04h31

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo