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

EDI, CMS, Outils, Scripts et API PHP Discussion :

Php fonctions utilisateur sécurisées ?


Sujet :

EDI, CMS, Outils, Scripts et API PHP

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 150
    Points : 412
    Points
    412
    Par défaut Php fonctions utilisateur sécurisées ?
    Bonjour,


    Pour un projet perso j'aurai besoin d'autoriser les utilisateurs d'un site à écrire eux même un bout de code PHP (des fonctions de calculs pour l'essentiel).

    Donc évidemment pour éviter que le serveur ne soit piraté, ou attaqué de diverses manières, je me demandais s'il était possible de limiter les actions d'un script php appellé via un call_user_func().

    L'idée est d'interdire tout accès disque, tout include de fichier, tout envoi d'email, tout accès socket, tout appel au shell etc... en gros la fonction utilisateur ne doit pouvoir faire que des calculs, accéder à certaines données en mémoire et renvoyer un résultat.

    Je suis ouvert à toute approche simple, même si elle implique d'utiliser une autre syntaxe/un autre langage pour les fonctions utilisateur.
    La seule contrainte est que le moteur qui appellera ces fonctions sera côté serveur (donc pas de javascript côté navigateur).



  2. #2
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    Pour bien faire : m'est d'avis que tu n'échapperas pas au parsage de l'équation reçue.

    Une autre approche, c'est de purger pas à pas le texte des valeurs autorisées : parenthèses, crochets, signes, valeurs numériques... et si à la fin ta chaîne n'est pas vide alors elle contient quelque chose de non autorisé -> poubelle. Dans ce cas, tu ne vérifies pas la validité de la chaîne (correspondance des parenthèses, emplacement des signes...) comme le permet un parsage soigné, tu ne t'assures uniquement que de sa non dangerosité.

    Un truc dans le genre avec (if (str_replace(array(autorisés), '', $text) !== '') { // poubelle }

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    150
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 150
    Points : 412
    Points
    412
    Par défaut
    En effet merci de cette suggestion, le parsage "inversé" pourrait résoudre le problème, il manque sans doute un moyen d'autoriser toutes les fonctions mathématiques (abs,cos,ceil ...) car un simple replace ne fera pas la différence entre "cos" et "coscos" par exemple alors que "coscos" n'a rien à faire là.

    En théorie on doit pouvoir extraire tous les "mots" (commençant par une lettre, au moins 3 caractères et finissant par une lettre ou un digit) du script avec preg_match_all puis voir si il y a au moins un mot non autorisé dans la liste ... faut que je creuse cette piste.

    Bon il risque d'y avoir d'autres surprises en cours de route ... mais ça pourrait être un début.

    Après si je veux autoriser des déclarations de variables dans la fonction utilisateur je ne pense pas que ça suffira.

  4. #4
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Pour ces problèmes, il suffit d'adapter la chaîne cherchée par exemple de cos en cos(...
    Après, si tu veux vraiment offrir un éditeur mathématique en bonne et due forme : ne reste plus qu'à coder le parseur qui va bien en fonction de tes contraintes (c'est pas simple crois-moi )

Discussions similaires

  1. fonction utilisateur non reconue par sql server 2000
    Par ouedmouss dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 05/09/2005, 07h46
  2. Fonction utilisateurs et programme externe
    Par syl2095 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 29/08/2005, 15h30
  3. Fonction utilisateur qui renvoie la date du jour
    Par falcon dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 13/12/2004, 11h03
  4. Retour NULL d'une fonction utilisateur
    Par tiboleo dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 18/11/2004, 15h40
  5. [Crystal report] fonctions utilisateur
    Par Roma dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 15/09/2004, 09h53

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