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

PHP & Base de données Discussion :

MSSQL - Champ VARCHAR avec données RTF


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 54
    Par défaut MSSQL - Champ VARCHAR avec données RTF
    Bonjour,

    J'ai un champ VARCHAR dans une base de données MS SQL. Il contient des données formatées RTF.
    Lorsque je fais une requête via le Studio MS SQL, je vois bien les données de type texte.
    Par contre, lorsque j'essaie de l'afficher dans une page web par script PHP et avec une connexion ODBC, j'ai des caractères bizarre.

    Avez-vous déjà rencontré ce problème ? Et comment l'avez-vous résolu ?

    Merci.

  2. #2
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    Le rtf n'est pas compatible avec des pages web sans parsage préalable. Le studio MSSQL te l'affiche car c'est une techno microsoft et qu'il l'ont intégré.

    Dans ton cas il va falloir trouver un parser RTF pour modifier les données en html (ou autre chose) avant affichage.

    J'utilise pour ma part https://github.com/silvermine/php-rtflex qui permet de transformer du RTF en plaintext.
    C'est pas toujours parfait ,en particulier sur les caractères spéciaux, mais ça fait l'affaire , moyennant parfois quelques ajustements.

    Ceci étant dit , si tu es maitre des données je te conseil vivement de choisir autre chose à la place du RTF , je trouve que c'est un calvaire de travailler avec ce format
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 54
    Par défaut
    Merci pour la réponse.

    Mais je sèche encore un peu...
    Je souhaite afficher ce champ dans un tableau et j'ai donc plusieurs fois ce champ dans ma requête. Pourrais-tu m'indiquer comment intégrer cela dans ma boucle ?
    J'ai l'impression qu'il faut créer un fichier texte temporaire et aller le lire. Du coup, cela ne va-t-il pas être dur de le faire plusieurs fois pour un même tableau ?

  4. #4
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    Je suis passé par la création d'un fichier virtuel en mémoire. C'est sans doute pas idéal mais ça fonctionne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $temp = iconv(mb_detect_encoding($i['RTF_DATA'], mb_detect_order(), true), "UTF-8//TRANSLIT", $i['RTF_DATA']);
    $virtualfile ='data:text/plain;base64,'.base64_encode($temp);
    try {
        $lexer = \RTFLexer::file($virtualfile);
        $text = trim($lexer->extractText());
    } catch(\Exception $e) {
        //Gérer l'erreur
    }
    La première ligne sert à convertir l'encodage du rtf en UTF8 , si ton rtf est déjà en utf8 (peu probable) ou que tu ne travail pas en utf8 tu n'en aura pas besoin.

    Ceci étant dit il existe sans doute plein d'autre librairie de conversion de rtf , tu peux aussi en trouver une qui gère directement les chaines de caractères en plus des fichiers
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

Discussions similaires

  1. Réponses: 10
    Dernier message: 15/11/2013, 09h16
  2. Champ calculé avec données manquantes = #Erreur
    Par bikeur62 dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 24/05/2013, 17h06
  3. Réponses: 3
    Dernier message: 01/08/2007, 09h26
  4. [MySQL] Transformer un champ VARCHAR en TINYINT contenant des données
    Par yoyot dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 29/06/2007, 15h47
  5. Réponses: 1
    Dernier message: 03/11/2004, 14h55

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