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

Symfony PHP Discussion :

api platform + react : envoyer des fichiers


Sujet :

Symfony PHP

  1. #1
    Membre éclairé
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2020
    Messages
    280
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2020
    Messages : 280
    Par défaut api platform + react : envoyer des fichiers
    Bonjour,

    j'ai suivi la documentation apiplatform pour uploader des ficheirs.
    Tout fonctionne correctement ... avec insomnia !

    Mais au moment de faire la requête dans mon front React, je n'arrive pas à envoyer le fichier choisi !
    le React:
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    const handleSubmit = (ev) => {
            const file = document.getElementById('file').files[0]
            console.log('le fichier: ', file)
            ev.preventDefault()
            fetch('api/animals/' + props.id + "/image", {
                method: "POST",
                headers: {
                    'Content-Type': 'multipart/form-data'
                },
                body: 
                   // quoi mettre ici ?
            })

    Le controller (pour le post personnalisée):
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    class AnimalImageController
    {
        public function __invoke(Animal $animal, Request $request)
        {
            $image = new ImageAnimal($animal);
            $uploadFile = $request->files->get('file');
            dd($request);
            $image->setFeatured(false);
            $image->setImageFile($uploadFile);
            return $image;
        }
    }

    J'ai beau bidouiller dans le body:
    {file: file}
    {imageFile: file} ( imageFile est le nom du champ dans ma table qui contient les chemins vers les images)
    file...

    Il n'y a aucune trace de fichier dans $request !

    J'avoue, je ne sais pas comment faire.
    Merci,

    Laurent.

  2. #2
    Membre éclairé
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2020
    Messages
    280
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2020
    Messages : 280
    Par défaut
    Alors après tâtonnements:

    une function handleChange dans le input, qui permet de récupérer le nom du fichier ( React contrôle le composant ):
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    const handleChange = (ev) => {
            setFile(ev.target.files[0])
    }

    Puis le formData dans la fonction HandlSubimt:
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    const handleSubmit = (ev) => {
            ev.preventDefault()
            let formData = new FormData()
            formData.append("file", file)
            fetch('api/animals/' + props.id + "/image", {
                method: "POST",
                body: formData
            })
            .then(response =>  response.json())
    }

    Donc ceci fonctionne !

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

Discussions similaires

  1. [DEV] Envoyer des fichiers vers (menu contextuel)
    Par AnTaReS7364 dans le forum Apple
    Réponses: 7
    Dernier message: 16/09/2007, 17h53
  2. Réponses: 1
    Dernier message: 02/05/2007, 09h22
  3. Réponses: 14
    Dernier message: 14/03/2007, 19h32
  4. Réponses: 7
    Dernier message: 09/08/2006, 20h45
  5. Envoyer des fichiers de manière répétée
    Par Micheal1221 dans le forum C++Builder
    Réponses: 6
    Dernier message: 05/07/2006, 10h05

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