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

JavaScript Discussion :

javascript & security


Sujet :

JavaScript

  1. #1
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Billets dans le blog
    1
    Par défaut javascript & security
    Bonjour à tous je cherche une piste pour un site d'affilié concernant le controle de l'utilisation d'un de nos modules js.
    Empêcher l'utilisation n fois de notre script dans la même page.
    Merci d'avance.
    Utilisation
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <script type="text/javascript"></script>

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 205
    Par défaut
    Bonjour,
    Empêcher l'utilisation n fois de notre script dans la même page.
    je ne comprend pas trop le sens de la question...mais
    initialise une variable dans ton script qui te permettra de tester si c'est un autre appel

    Ceci dit seul le dernier chargement est pris en compte lors de plusieurs insertions du même fichier, "écrasement" des nommages des fonctions.

  3. #3
    Membre extrêmement actif
    Avatar de kdmbella
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2010
    Messages
    799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Août 2010
    Messages : 799
    Par défaut
    si tu peut nous donner des exemples on a du mal a comprendre ton problème
    "L'humanité se divise en trois catégories : ceux qui ne peuvent pas bouger, ceux qui peuvent bouger, et ceux qui bougent."
    - Benjamin Franklin

    De l'aide en Javascript , consultez la FAQ JS.

    De l'aide sur le FrameWork JS DHTMLX : posez vos questions sur le forum des Bibliothèques & Frameworks JS.

  4. #4
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Billets dans le blog
    1
    Par défaut
    bonjour et merci pour vos réponses, pour l'instant je n'ai pas d'exemple concrète je suis toujours dans la manière de m'y prendre.
    Il s'agit d'un script qui charge des animations de nos serveurs.
    L'utilisateur lambda utilise notre script directement accessible sur le backoffice.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <script type="text/javascript" src="url_vers_nos_domaines"></script>
    afin de contrôler l'utilisation j'avais pensé à a truc du genre

    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
     
    <html>
    <head>
    <script type="text/javascript">
    function bill(){
    	return "funkyclaqued";
    }
    </script>
    <script type="text/javascript">
    if(typeof(bill) == "undefined"){
    	function bill(){
    		return "funkyclaque";
    	}
    }
    alert(bill());
    </script>
    mais la j'avoue que c'est pas top comme début et un peu flippant au vue du nombre de méthode de l'application en question...
    Un array de tout les fonctions une boucle avec typeof, mais au niveau fiabilité je sèche...
    Merci de vos lumières.

  5. #5
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Billets dans le blog
    1
    Par défaut un petit autre pas
    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
     
    <html>
    <head>
    <!-- UTILISATEUR LAMBDA -->
    <script type="text/javascript">
    function bill(){
    	 alert("billclaqued");
    }
    function boule(){
    	alert("bouleclaqued");
    }
    function le_mechand(){
    	alert("mechandclaqued");
    }
    </script>
    <script type="text/javascript">
    //Var personnages array des functions à parametrer
    var personnages = new Array('bill','boule','le_mechand');
     
    //functions de controles & initialisations
    function FuncExist(funcName){
    	alert("CHECK function "+funcName);
    	if(typeof(funcName) == "undefined"){
    		init_function(funcName);
    	}
    }
    function init_function(functionName){
    	alert("INIT function "+functionName);
      functionName(); //initialisation
    }
     
    for(var i=0;personnages.length>i;i++){
    	FuncExist(personnages[i]);
    }
     
    //scripts de nos serveurs
    function bill(){
            alert("billclick");
    }
    function boule(){
    	alert("bouleclick");
    }
    function le_mechand(){
    	alert("mechandclick");
    }
    </script>

  6. #6
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Billets dans le blog
    1
    Par défaut petit oubli
    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
     
    <head>
    <!-- UTILISATEUR LAMBDA -->
    <script type="text/javascript">
    function bill(){
    	 alert("billclaqued");
    }
    function boule(){
    	alert("bouleclaqued");
    }
    function le_mechand(){
    	alert("mechandclaqued");
    }
    </script>
    <script type="text/javascript">
    //Var personnages array des functions à parametrer
    var personnages = new Array('bill','boule','le_mechand');
     
    //functions de controles & initialisations
    function FuncExist(funcName){
    	alert("CHECK function "+funcName);
    	if(typeof(funcName) == "undefined"){
    		init_function(funcName);
    	}else{
    		delete(FuncName);
    	}
    }
    function init_function(functionName){
    	alert("INIT function "+functionName);
      functionName(); //initialisation
    }
     
    for(var i=0;personnages.length>i;i++){
    	FuncExist(personnages[i]);
    }
    //scripts de nos serveurs
    function bill(){
    	 alert("billclick");
    }
    function boule(){
    	alert("bouleclick");
    }
    function le_mechand(){
    	alert("mechandclick");
    }
    </script>
    Ici j'obtiens ce que je souhaite mes fonctions s’exécutent et pas celle de la première balise. Mais toujours pas convaincu... sur la fiabilité.

  7. #7
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 205
    Par défaut
    Ceci dit seul le dernier chargement est pris en compte lors de plusieurs insertions du même fichier, "écrasement" des nommages des fonctions.
    c'est bien la dernière affectation qui est pris en compte, la lecture du code se faisant de façon séquentielle.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    function fctTest(){
      alert('1st declaration');
    }
    // ecrasement de la premiere definition
    function fctTest(){
      alert('2nd declaration');
    }
    fctTest(); // Affiche -> 2nd declaration
    les tests que tu effectues ne sont pas nécessaire sauf si tu veux préserver celle de l'utilisateur "lamda", mais c'est une autre histoire...

    La meilleur solution reste dans ce cas les Espaces de noms (ou namespace) en JavaScript, bonne lecture...

  8. #8
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Billets dans le blog
    1
    Par défaut
    Merci pour cette info je jette un coup d'oeil sur ton lien.
    Encore merci

+ Répondre à la discussion
Cette discussion est résolue.

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