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

C# Discussion :

Replace et le caractère @


Sujet :

C#

  1. #1
    Membre confirmé
    Inscrit en
    Janvier 2011
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 83
    Par défaut Replace et le caractère @
    Salut,

    j'ai un soucis avec la methode Replace.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    result = result.Replace(@"\", @"\\");
    avec result = "\a" je n'obtiens pas le resultat escomtpté qui a mon serai "\\a".

    Que dois je amélioré dans ma routine où se trouve mon erreur.

    Merci

  2. #2
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2003
    Messages
    274
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Luxembourg

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 274
    Par défaut
    Salut,

    Si je fais ceci ca marche chez moi:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    string test = @"\a";
                test = test.Replace(@"\", @"\\");
                Console.WriteLine(test);
    J'obtiensSi je fais Ca marche aussi et j'obtiens \\\\a

    La difference c'est que moi je fais quand j'initialise ma chaine

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2011
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 83
    Par défaut
    Je veux en fait utilisé les caractères générique ("\","%"....) sql comme caractères normaux dans une expression like. Mon escape est "\".

    Donc si l'utilisateur entre par exemple "\a" j'aimerai transformé cela en "\\a" en mon expression sql. et la je coince

  4. #4
    Membre très actif
    Avatar de charouel
    Homme Profil pro
    Freelance
    Inscrit en
    Mars 2009
    Messages
    618
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Freelance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2009
    Messages : 618
    Billets dans le blog
    9
    Par défaut
    Tu peux voir ici

  5. #5
    Membre Expert Avatar de DonQuiche
    Inscrit en
    Septembre 2010
    Messages
    2 741
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 2 741
    Par défaut
    Bonjour, cette façon de faire est dangereuse du fait du risque d'attaque par injection SQL. Mieux vaut utiliser une requête paramétrée. Cela évitera de se demander si le code est exhaustif et robuste, ou de devoir le réexaminer si le DB utilisée devait changer.


    Cela étant dit il aurait fallu faire quelque chose du genre: str.Replace("\a", @"\a").Replace("\n", @"\n").Replace(...
    Mais encore une fois cette approche est plus que déconseillée.

  6. #6
    Membre confirmé
    Inscrit en
    Janvier 2011
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 83
    Par défaut
    je ne trouve tjr pas de solution me permetant de transformer "\a" en "\\a". @"\a" c est autre chose et mon utiliseur entre "\a".

  7. #7
    Membre Expert Avatar de DonQuiche
    Inscrit en
    Septembre 2010
    Messages
    2 741
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 2 741
    Par défaut
    La solution que j'ai proposée fonctionne.

  8. #8
    Membre confirmé
    Inscrit en
    Janvier 2011
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 83
    Par défaut
    desolé j'ai posté sans avoir lu ta solution.

    Apres mon backslash je peut voir une lettre comprise entre [a-z] est il possible de géneraliser ta solution?

  9. #9
    Membre Expert Avatar de DonQuiche
    Inscrit en
    Septembre 2010
    Messages
    2 741
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 2 741
    Par défaut
    Oh oui, tu pourrais créer une boucle pour effectuer 26 remplacements. Et là tu te rendrais compte que tu dois encore gérer le cas des guillemets, et tu te demanderais après ça si ton code est vraiment robuste.

    Encore une fois une requête paramétrée serait très préférable.

  10. #10
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2003
    Messages
    274
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Luxembourg

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 274
    Par défaut
    En effet, tu devrais utiliser les requetes parametrisees!
    Si tu as une attaque par injection, ton code sera plus qu'inutile et tes donnees seront accessible directement.

    Tu dis que tu n'as pas les bons resultats mais peux tu nous poster le code que tu as mis en place ?

Discussions similaires

  1. [MySQL-5.5] Requête REPLACE avec le caractère /
    Par aragorn23 dans le forum Requêtes
    Réponses: 2
    Dernier message: 22/10/2014, 19h24
  2. find and replace d'un caractère español
    Par ldiaz dans le forum Shell et commandes GNU
    Réponses: 3
    Dernier message: 09/09/2010, 13h30
  3. replace.all avec caractère paranthese
    Par totoche dans le forum Langage
    Réponses: 7
    Dernier message: 09/10/2009, 18h06
  4. Réponses: 4
    Dernier message: 31/03/2008, 17h33
  5. Fonction REPLACE() pour le caractère "
    Par snoopy69 dans le forum VBA Access
    Réponses: 4
    Dernier message: 10/12/2007, 10h05

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