|
Anonyme 19853
| Posté : 07-02-2003 10:02
J'aimerai bien insérer une image dans une base de donnée mysql, la récupérer et l'afficher. Si quelqu'un a une idée, je suis prenneur.
Merci d'avance.
bobkrown |
|
|
Anonyme 19853
| Posté : 10-02-2003 14:23
L'image doit toujours se trouver quelquepart à une adresse précise.
Ensuite tu dois posséder un champ image ds une table ou tu auras taper l'adresse en question.
Regarde ds le script user ou memberlist.
gaston33 |
|
|
Anonyme 19853
| Posté : 14-02-2003 18:22
ben oui, je sais tout ça mais ça m'arrange pas de trop. Y a moyen de le faire, je l'ai vu avec des .swf mais il utilisait du xml, j'aimerai le faire en php pure.
merci tout de meme |
|
|
snipe 2450
| Posté : 14-02-2003 18:43
gaston tu vas bientot voir un nouveau moyen :)
moi la photo elle est dans un rep que tu peut acceder et pourtant tu la vera :) |  Profil E-mail
|
|
karapars 109
| Posté : 17-02-2003 23:15
pas de prob il y a moyen.
Attend je vais te chercher les ligne dans mon script et te mettre des explications.
J'arrive.... |  Profil
|
|
karapars 109
| Posté : 17-02-2003 23:34
voila la reponse :
dabord exemple du form :
<form enctype=multipart/form-data action=../base/basephoto.php method=post>
<td>
<input type=hidden name=MAX_FILE_SIZE value=100000 />
photo 1 <input type=file name=photo1 />
</td>
<input type=submit NAME=Enregistrement>
</center>
</form>
Maintenant voici le code pour le php :
// définition de l'espace destiné à recevoir les fichiers
$repository="/home/photo/";
// si un fichier maphoto a bien été transféré
if (is_uploaded_file($_FILES["photo1"]["tmp_name"])) {
// recupération de l'extension du fichier
// autrement dit tout ce qu'il y a après le dernier point (inclus)
$photo1 = $_FILES["photo1"]["name"];
$extension = substr($photo1, strrpos($photo1, "."));
// Contrôle de l'extension du fichier
if (eregi("^ph", $extension)) {
die("Les fichiers en .ph* ne sont pas autorisés.");
}
$chemin1 = $id . "_photo1" . $extension;
rename($_FILES["photo1"]["tmp_name"], $repository.$chemin1);
}
if (is_uploaded_file($_FILES["photo2"]["tmp_name"])) {
// recupération de l'extension du fichier
// autrement dit tout ce qu'il y a après le dernier point (inclus)
$photo2 = $_FILES["photo2"]["name"];
$extension = substr($photo2, strrpos($photo2, "."));
// Contrôle de l'extension du fichier
if (eregi("^ph", $extension)) {
die("Les fichiers en .ph* ne sont pas autorisés.");
}
$chemin2 = $id . "_photo2" . $extension;
rename($_FILES["photo2"]["tmp_name"], $repository.$chemin2);
}
if (is_uploaded_file($_FILES["photo3"]["tmp_name"])) {
// recupération de l'extension du fichier
// autrement dit tout ce qu'il y a après le dernier point (inclus)
$photo3 = $_FILES["photo3"]["name"];
$extension = substr($photo3, strrpos($photo3, "."));
// Contrôle de l'extension du fichier
if (eregi("^ph", $extension)) {
die("Les fichiers en .ph* ne sont pas autorisés.");
}
$chemin3 =$id . "_photo3" . $extension;
rename($_FILES["photo3"]["tmp_name"], $repository.$chemin3);
}
// Exemple de requete de stockage en BD avec MySQL
// et une table qui aurait pu être créée par
// CREATE TABLE matable (login varchar(64), image varchar(64), icone varchar(64));
$db = mysql_connect("localhost","root","") or die("Connexion impossible");
mysql_select_db("voiture") or die("Connexion impossible2");
$id = $id;
$chemin1 = "$chemin1";
$chemin2 = "$chemin2";
$chemin3 = "$chemin3";
$sql = "UPDATE voiture SET photo1='$chemin1',photo2='$chemin2',photo3='$chemin3' WHERE ID=$id";
$RET = @mysql_query($sql,$db);
if ($RET<1){ print("Pas de mise à jour de l'enregistrement $id\n");}
else {
$resultat=mysql_query (" SELECT * FROM `TABLE'
WHERE id=$id");
$row = mysql_fetch_array($resultat);
$id = $row['id'];
echo "
<body bgcolor=336666>
<center>
<u> <font size=4 color=red>VOTRE ENREGISTREMENT A ETE CORRECTEMENT ENCODE
</u></font>
<center>
<br>
& lt;font size=4 color=red>identifiant=$id
</font>
<br>
<table width=600>
<tr border=1 >
<td>
<table border=2 width=300>
<td>
<font color=FFFF99 size=2><b>photo</font></b>
<font color=white size2> $photo
</font>
</td>
</table>
</td>
"
;}
mysql_close($db);
?>
Voila tout le code php et le code mysql avec verification de la base de donne .
J'espere t'avoir bien aider.
Et tu peux meme ajouter et modifier des partie du scrip pour securise.
L.interdiction de certain type de fichier.
Au fait ce script ne permet que l'upload de fichier de moin de 2 MB sinon le script ommet une erreur du au fait que si je me trompe pas, c'est de paramettre dans la config de apache qui blocque la taille de l'upload.
Voila bon amusement.
KarAParS ThE OnE LovE Sensi
(DEV desole, je savais pas qu'il fallait desactiver le html.. moi aussi je suis novice..) |  Profil
|
|
Anonyme 19853
| Posté : 18-02-2003 22:24
merci du fond du coeur
bobkrown |
|
|
karapars 109
| Posté : 18-02-2003 22:40
De rien. C'etais avec plaisir.
J'espere que tu as reussi.
Euu fait attention a ne pas oublier de mettre dabord une requete de verification dans la base de donne pour ne pas uploader 2 fichier different mais sous le meme non ou alors ce que tu vas avoir comme prob c'est l'update de l'image ou changer l'image va etre difficile. Si 2 fichier du meme nom, tu aurra une erreur.
Des que je trouve le moyen de faire la suppresion de fichier par formulaire ou la reecriture... je le post.
KarAParS ThE OnE BY LovE |  Profil
|
|
Anonyme 19853
| Posté : 22-04-2003 13:52
Bonjour à tous
il y a un moyen beaucoup plus simple et plus rapide : c'est de stocker l'image directement dans la base MySQL, sans qu'elle soit dans un répertoire online. Il suffit pour cela d'utiliser un champ binaire.
Si le script intéresse quelqu'un, qu'il le dise, je le mettrais. Ca ne fait que quelques lignes ;)
@+ Ysandril. |
|
|
developpeur 24581
| |
Anonyme 19853
| Posté : 23-04-2003 22:11
Citation : "22-04-2003 13:52, Anonyme a écrit
il y a un moyen beaucoup plus simple et plus rapide : c'est de stocker l'image directement dans la base MySQL, sans qu'elle soit dans un répertoire online. Il suffit pour cela d'utiliser un champ binaire.
Si le script intéresse quelqu'un, qu'il le dise, je le mettrais. Ca ne fait que quelques lignes ;)
@+ Ysandril."
Bonjour à tous,
Oui, moi je suis interressé.
Si tu peux me l'envoyer à etrolle@free.fr
Merci.
ET
|
|
|
Anonyme 19853
| Posté : 30-04-2003 11:51
salut,
pas de problème je t'envoie le code.
@+
Ysandril |
|
|
developpeur 24581
| |
Anonyme 19853
| Posté : 02-05-2003 12:55
J'ai envoyé le script à cos adresses respectives. Si vous avez des questions particulières, n'hésitez pas à m'e faire part.
@+
Ysandril |
|
|
Anonyme 19853
| Posté : 02-05-2003 22:05
Citation : "22-04-2003 13:52, Anonyme a écrit :
Bonjour à tous
il y a un moyen beaucoup plus simple et plus rapide : c'est de stocker l'image directement dans la base MySQL, sans qu'elle soit dans un répertoire online. Il suffit pour cela d'utiliser un champ binaire.
Si le script intéresse quelqu'un, qu'il le dise, je le mettrais. Ca ne fait que quelques lignes ;)
@+ Ysandril."
----------
Ca m'interressait beaucoup. Si tu ne peux pas le mettre ici, saurais -tu me l'envoyer ? ceridwen@free.fr merci d'avance :) |
|
|
Aller à la page : [ 1 | 2 | 3 | 4 ] |