Rechercher : dans
Par :

Traitement d'images sql server/php

Dernière réponse le 8 déc 2006 à 18:49:33 Serge Pascal, le 29 jui 2005 à 12:16:43 
 Signaler ce message aux modérateurs

Salut, je voudrais inserer et afficher une image dans sql server 2000 et php.
1-Voici le script d'insertion (qui semble marcher bien):
// save file to store image
$datastring = file_get_contents("img.jpg");
$data = unpack("H*hex", $datastring);
mssql_query("insert into TblDocument (name, data)
values ('img.jpg', 0x".$data['hex'].")
");
2- Voici le script d'affichage:
// retrieving
$result = mssql_query("select data from TblDocument WHERE IDDoc = '$id'");
$lgnImg = mssql_fetch_object($result);
header("Content-type: image/pjpeg;");
echo $lngImg->data;
Ce script ne marche pas.
Je souhaiterais que vous me proposer quelque chose merçi

1

kilian, le 29 jui 2005 à 13:05:56

Salut,

Qu'est ce ui ne marche pas?
Tu ne t'es pas gourré dans le header?
Ce ne serait pas plutôt:

 header("Content-type: image/jpeg")

Répondre à kilian

2

serge pascal, le 29 jui 2005 à 13:14:12

Si j'ai mis ce header("Content-type: image/pjpeg"); c parce que lors de l'insertion, le type de donnée ds le champs est "image/pjpeg". Toutefois même en mettant ceci header("Content-type: image/jpeg"); j'ai toujours le cadre de l'image qui s'affiche avec ses dimensions mais pas l'image
Merçi de me répondre

Répondre à serge pascal

3

kilian, le 29 jui 2005 à 13:25:58

Alors là je ne saurais pas te dire....

Répondre à kilian

4

serge pascal, le 30 jui 2005 à 10:31:33

Salut kilian, j'ai une autre idée. Peux-tu regarder le script d'insertion ? je pense que le pb se situe à ce niveau
Merçi

Répondre à serge pascal

5

kilian, le 30 jui 2005 à 16:50:21

Ca te donne quoi si tu fais:
echo $data['hex'];
?

Répondre à kilian

6

kilian, le 30 jui 2005 à 16:54:59

Ce ne serait pas mieux d'enregistrer ta valeur hexadécimale comme étant une chaine de caractère plutôt qu'un entier?
Parce que ta valeur hexadécimale doit être enorme!! A mon avis, c'est
trop pour une base de données de supporter un entier pareil.
Si c'est une chaine tu ne devrais pas avoir de soucis.

Compare la valeur de $data['hex']; et celle qui a été enregistrée dans ta base. Je parie que tu as un souci à ce niveau là.

Répondre à kilian

7

serge, le 1 aoû 2005 à 10:08:30

Salut kilian,
Justement mon souci c certainement à ce niveau. En hexa c trop gros comme un entier, je recois le message les erreurs suivantes:

mssql_query() [function.mssql-query]: message: Unclosed quotation mark before the character string 'ÿØÿà'. (severity 15) in d:\wamp\www\prjpapyrus\image2.php on line 52


Warning: mssql_query() [function.mssql-query]: message: Line 2: Incorrect syntax near 'ÿØÿà'. (severity 15) in d:\wamp\www\prjpapyrus\image2.php on line 52

Warning: mssql_query() [function.mssql-query]: Query failed in d:\wamp\www\prjpapyrus\image2.php on line 52

Merçi de me répondre

Répondre à serge

9

kilian, le 2 aoû 2005 à 12:49:25

Non, là tu as une erreur de guillemet (faut echapper tes guillemets avant de les insérérer dans ta base):

message: Unclosed quotation

Répondre à kilian

8

serge pascal, le 1 aoû 2005 à 10:26:42

Echo $data['hex'] renvoi une chaine en hexa. Toutefois, peux-tu me proposer un script ou améliorer ce que j'ai proposé ?
Merçi

Répondre à serge pascal

10

kilian, le 2 aoû 2005 à 12:50:29

Et quand tu regarde dans ta base après tu vois quoi comme valeur?
data c'est un champs de quel type?

Répondre à kilian

11

serge pascal, le 2 aoû 2005 à 13:07:48

Salut,
Bien sur ds la bd on ne voit que du code binaire. En plus j'ai utilisé str_replace ou addslashes pour contourner en vain. Je te propose s de prendre ces script et expérimenter puis tu me renvoi ta version qui marche.
Merçi de me répondre.

Répondre à serge pascal

12

kilian, le 2 aoû 2005 à 13:13:53

Ce qui m'arrange pas c'est que je n'ai pas mssql_server .
Alors pour tester....

Finalement l'antislash ne fonctionne pas car tu n'insères pas ta valeur comme une chaine mais comme une valeur numerique.
Data est de quel type? Entier? Chaine de caractère?
Si c'est un entier essaie de le transformer en type texte pour voir et d'insérer ta valeur entre guillemets dans ta requête.

Répondre à kilian

13

serge pascal, le 2 aoû 2005 à 13:16:46

Dommage. Merçi de toujours m'informer

Répondre à serge pascal

14

serge, le 2 aoû 2005 à 15:03:38

Data est de type image

Répondre à serge

15

kilian, le 3 aoû 2005 à 00:18:12

Arg, désolé, je sais pas trop comment fonctionne ce genre de type....

Répondre à kilian

16

 tiana, le 8 déc 2006 à 18:49:33
  • +1

Je comprends pas pourquoi tu ajoutes une commande unpack... J'ai un script similaire qui fonctionne plus ou moins avec les jpeg (l'affichage est brouillé!)
http://www.phpcs.com/...

Répondre à tiana
Collection CommentÇaMarche.net