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

SGBD Perl Discussion :

Insertion d'image dans champ blob et escape des caractères spéciaux


Sujet :

SGBD Perl

  1. #1
    Membre du Club
    Inscrit en
    Décembre 2008
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 57
    Points : 41
    Points
    41
    Par défaut Insertion d'image dans champ blob et escape des caractères spéciaux
    Bonjour,

    j'espère être dans la bonne section

    Je suis actuellement sur un projet dans lequel je génère des graphiques avec gd, qui doivent ensuite être insérés dans Mysql (champ de type blob).
    Pour diverses raisons je ne fais pas l'update Mysql via le module DBI et ne peut donc utiliser "->quote()"
    J'ai pour le moment quelque chose du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    open(IMG, ">>$update_graph") or die $!;
    #binmode IMG;
    my $graph_bin = $my_graph->plot(\@data)->png;
    my $graph_id = join('_',@vals);
    $graph_bin =~ s/'/\'/g;
    $graph_bin =~ s/"/\"/g;
    print IMG "INSERT INTO GRAPH_TEST (graph_id,graph_data) values ( '".$graph_id."','".$graph_bin."' );\n";
    close IMG;
    Pour le moment j'ai tenté d'escape les ' et " mais même eux ne sont pas escape dans mon fichier de sortie, une idée ?
    Quels caractères escape exactement ->quote ? Juste les ' et " ou il y en a aussi d'autres?

    Merci

  2. #2
    Membre du Club
    Inscrit en
    Décembre 2008
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 57
    Points : 41
    Points
    41
    Par défaut
    Bon bah avec un peu de recherche....

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $graph_bin =~ s/\\/\\\\/sg;
    $graph_bin =~ s/\0/\\0/sg;
    $graph_bin =~ s/\'/\\\'/sg;
    $graph_bin =~ s/\n/\\n/sg;
    $graph_bin =~ s/\r/\\r/sg;
    Merci

  3. #3
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    Pour une meilleure lisibilité :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $graph_bin =~ s{\\}{\\\\}sg;
    $graph_bin =~ s{\0}{\\0}sg;
    $graph_bin =~ s{'}{\\'}sg;
    $graph_bin =~ s{\n}{\\n}sg;
    $graph_bin =~ s{\r}{\\r}sg;

  4. #4
    Membre du Club
    Inscrit en
    Décembre 2008
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 57
    Points : 41
    Points
    41
    Par défaut
    Je n'avais pas encore rencontré ce type d'écriture pour les regexp sous perl

    Merci pour le tips djibril bien utile à la lisibilité en effet

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

Discussions similaires

  1. Oracle 8i : insertion d'une image dans un BLOB
    Par garfield_fr dans le forum SQL
    Réponses: 0
    Dernier message: 02/12/2010, 14h04
  2. Insertion d'image dans un champ BLOB
    Par aminus19 dans le forum MySQL
    Réponses: 2
    Dernier message: 06/05/2010, 14h26
  3. [MySQL] Récuperer une image dans champs BLOB de la base de données
    Par gilou31 dans le forum PHP & Base de données
    Réponses: 16
    Dernier message: 28/02/2008, 16h32
  4. Insertion documents word dans champ objet OLE sous VBA
    Par frankouche dans le forum Access
    Réponses: 4
    Dernier message: 20/12/2006, 21h35
  5. [ADO]Transfert image dans champ blob
    Par dleu dans le forum Bases de données
    Réponses: 4
    Dernier message: 27/05/2005, 08h44

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