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

VB.NET Discussion :

VB.NET INSERT RTF code into (SQL)


Sujet :

VB.NET

  1. #1
    Membre à l'essai
    Inscrit en
    Janvier 2008
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 15
    Points : 17
    Points
    17
    Par défaut VB.NET INSERT RTF code into (SQL)
    Bonjour
    Je suppose que ceci est une demande courante, mais je ne trouve pas mon bonheur dans mes recherches.
    En fait j'ai un champ RTF appelé ici champ_rtf (System.Windows.Forms.RichTextBox()) que j'aimerai insérer dans un champ d'une table sur une base SQL
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    DIM mon_rtf as string
    mon_rtf = champ_rtf.rtf
    Le code en lui même fonctionne jusqu'au moment où dans le code RTF j'ai une quote, exemple j'ai un ä dans le texte qui est transformé en \u228\'e4 donc un simple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO TABLE_RTF(RTFVAL) VALUES('" & mon_rtf &"');
    m'envoie dans les roses car le code SQL est faux

    J'ai lu des tas de choses comme sauver le contenu rtf en fichier le recharger puis insérer ... plein de manipulations que je pense inutiles, il doit bien y avoir un autre moyen.

    Merci pour toute aide / info

  2. #2
    Membre confirmé Avatar de joKED
    Profil pro
    Imposteur en chef
    Inscrit en
    Février 2006
    Messages
    337
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Imposteur en chef

    Informations forums :
    Inscription : Février 2006
    Messages : 337
    Points : 458
    Points
    458
    Par défaut
    Bonjour,

    Règle numéro 1 : On ne fait pas de concaténation de chaine pour un INSERT en SQL.
    Règle numéro 2 : On ne fait pas de concaténation de chaine pour un INSERT en SQL.

    Pourquoi ? Car il y a un risque d'injection SQL. Et c'est moche.

    L'idée, pour éviter ton problème, c'est de passer le contenu en paramètre. Potentiellement avec une procédure stockée (recommandé), ou avec une requête paramétrée.
    Tout ceci est bien documenté et facile à mettre en oeuvre.
    Tant va la cruche à l'eau qu'à la fin y'a plus d'eau.

Discussions similaires

  1. [VB.NET]insert sql server & computed field
    Par Kropernic dans le forum Windows Forms
    Réponses: 24
    Dernier message: 25/08/2009, 09h49
  2. [SQL] insert into sql session
    Par bernard26000 dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 23/12/2007, 11h56
  3. [SQL SERVER 2005][ADO.NET] insertion de la valeur NULL
    Par nem&sys dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 23/11/2007, 11h39
  4. Format de date avec INSERT INTO (SQL)
    Par St-Jean dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 21/10/2007, 16h51
  5. [SQL + VB.NET] Alléger mon code pour un accès plus rapide
    Par Miles Raymond dans le forum VB.NET
    Réponses: 8
    Dernier message: 15/10/2007, 23h09

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