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 :

Undefined index lors de la création d'une variable te type UploadedFile [4.x]


Sujet :

Symfony PHP

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut Undefined index lors de la création d'une variable te type UploadedFile
    Bonjour,

    J'utilise Cropper.js. Pour stocker l'image recadrée, je fais appel à une fonction ajax. Dans le fichier de traitement en Php, je récupère le fichier et tente de créer une variable de type UploadedFile. En faisant cela, j'obtiens l'erreur suivante :

    Notice: Undefined index: avatar
    Cependant, si je ne tente pas de créer cette variable, je n'ai aucune erreur d'index.

    Voici mon code engendrant une erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
     
        /**
         * Save the avatar
         * 
         * @Route("/media/avatar/save", options={"expose"=true}, name="media.avatar.save")
         *
         * @param Request $request
         * 
         * @return Response
         */
        public function ajaxAction(Request $request, EntityManagerInterface $manager, ProfileRepository $profileRepository): Response
        {
     
            $tmp_name = $_FILES['avatar']['tmp_name'];
            $name = $_FILES['avatar']['name'];
            $mimeType = $_FILES['avatar']['type'];
     
            $file = new UploadedFile($tmp_name, $name, $mimeType);
     
            $response = new JsonResponse($_FILES['avatar']); 
     
            return $response;
     
        }
    Si je supprime la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $file = new UploadedFile($tmp_name, $name, $mimeType);
    , je n'ai plus d'erreur et le Json retourné est correct :

    {name: "blob", type: "image/png", tmp_name: "C:\xampp\tmp\php73BA.tmp", error: 0, size: 53383}
    Je ne comprends vraiment pas pourquoi cette erreur ne survient qu'à la création de l'UploadedFile. Quelqu'un aurait une idée?

    Merci d'avance pour votre aide.

  2. #2
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    C'est donc UploadedFile qui envoie la notification. De plus $file étant locale et pas utilisée dans le reste du code de la méthode $file ne sert à rien.

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    Merci pour ta réaction.

    Effectivement, pour le moment, $file ne sert à rien, mais le code dans lequel je désire l'utiliser n'est pas encore écrit. Cependant, j'en aurai besoin pour stocker mon image, mais comme ça me renvoie une erreur, je suis bloqué.

  4. #4
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    Es-tu sûr que tu as bien des données dans $_FILES ?

    Que donne un var_dump($_FILES); ?

  5. #5
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    Oui, étant donné que si je fais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
            $response = new JsonResponse($_FILES['avatar']); 
     
            return $response;
    sans le new UpdatedFile, j'obtiens

    {name: "blob", type: "image/png", tmp_name: "C:\xampp\tmp\php73BA.tmp", error: 0, size: 53383}

  6. #6
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    Ok, encore merci pour ton intérêt.

    Voici comment j'y suis finalement arrivé :

    Mon js :

    Code js : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
     
    import { deletePhoto } from '../app';
    import { autocompleteAddress } from '../app';
    import Cropper from 'cropperjs/dist/cropper'; 
    import { getAjax } from '../app';
     
    $(document).ready(function() { 
     
        var avatar = document.getElementById('avatar_img');
        var image = document.getElementById('image');
        var input = document.getElementById('avatar_input');
        var $modal = $('#modal_avatar');
        var $alert = $('.alert');
        var $progress = $('.progress');
        var cropper;
     
        $('[data-toggle="tooltip"]').tooltip();
     
        input.addEventListener('change', function (e) {
     
            var files = e.target.files;        
            var done = function (url) {
                                        input.value = '';
                                        image.src = url;
                                        $alert.hide();
                                        $('#modal_avatar').modal('show');
                                      }
            ;
     
            var reader;
            var file;
            var url;
     
            if (files && files.length > 0) 
            {
     
                file = files[0];
     
                if (URL) 
                {
     
                    done(URL.createObjectURL(file));
     
                } 
                else if (FileReader) 
                {
     
                    reader = new FileReader();
                    reader.onload = function (e) {
     
                        done(reader.result);
     
                    };
                    reader.readAsDataURL(file);
     
                }
     
            } 
     
        });
     
        $modal.on('shown.bs.modal', function () {
     
          cropper = new Cropper(image, {
     
            aspectRatio: 1,
            viewMode: 3
     
          });
        }).on('hidden.bs.modal', function () {
     
          cropper.destroy();
          cropper = null;
     
        });
     
        document.getElementById('crop').addEventListener('click', function () {
     
          var initialAvatarURL;
          var canvas;
     
          $modal.modal('hide');
     
          if (cropper) 
          {
     
            canvas = cropper.getCroppedCanvas({
     
              width: 160,
              height: 160
     
            });
     
            initialAvatarURL = avatar.src;
            avatar.src = canvas.toDataURL();
            $progress.show();
            $alert.removeClass('alert-success alert-warning');
     
            canvas.toBlob(function (blob) {
     
              canvas.toBlob(function (blob) {
     
                saveAvatar(blob, $alert, $progress);
     
              });
     
            });
     
          }
     
        });
     
        $('body').on('click','#photoRemovingLink',function(e) {
     
            e.preventDefault();
            deletePhoto($(this));
     
        });
     
        autocompleteAddress('address_street', ' address_city', 'address_zipcode', 'address_country', 'address_number', 'address_box', 
                            'address_state', 'address_latitude', 'address_longitude', true, 'address_default_location');
     
    });
     
    function saveAvatar(blob, $alert, $progress)
    {
     
      var $progressBar = $('.progress-bar');
      var data = new FormData();
     
      data.append('file', blob);
     
      $.ajax(Routing.generate('media.avatar.save'), {
     
        type: 'POST',
        data: data,
        processData: false,
        contentType: false,  
        async:      true,
     
         xhr: function () {
     
          var xhr = new XMLHttpRequest();
     
          xhr.upload.onprogress = function (e) {
     
            var percent = '0';
            var percentage = '0%';
     
            if (e.lengthComputable) 
            {
     
              percent = Math.round((e.loaded / e.total) * 100);
              percentage = percent + '%';
              $progressBar.width(percentage).attr('aria-valuenow', percent).text(percentage);
     
            }
     
          };
     
          return xhr;
     
        },
     
        success: function (response) {
     
          $alert.show().addClass('alert-success').text('Upload success');
          console.log(response);
     
        },
     
        error: function (response) {
     
          avatar.src = initialAvatarURL;
          $alert.show().addClass('alert-warning').text('Upload error');
          console.log(response);
     
        },
     
         complete: function () {
     
          $progress.hide();
     
        },
     
      });
     
    }

    Et ma fonction de traitement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
     
        /**
         * Save the avatar
         * 
         * @Route("/media/avatar/save", name="media.avatar.save", methods={"POST"}, options={"expose"=true})
         *
         * @param Request $request
         * 
         * @return Response
         */
        public function ajaxAction(Request $request, EntityManagerInterface $manager, ProfileRepository $profileRepository): Response
        {
     
            if ($request->isXmlHttpRequest()) 
            {
     
                $profile = $profileRepository->find(6);
                $photo = new Photo();
                $profile->setPhoto($photo);
     
                $tmp_name = $_FILES['file']['tmp_name'];
                $name = $_FILES['file']['name'];
                $mimeType = $_FILES['file']['type'];
     
                $file = new UploadedFile($tmp_name, $name, $mimeType);
     
                $photo->setName($name);
                $photo->setFile($file);
                $photo->setProfile($profile);
     
                 $manager->persist($profile);
                $manager->flush();
     
                $response = new JsonResponse(array('success' => 'Avatar saved'));
     
            }
            else 
            {
     
                $response = new JsonResponse(array('error' => 'Not a XmlHttpRequest'));
     
            }
     
     
            return $response;
     
        }
     
        public function generateUniqueName()
        {
     
            return md5(uniqid());
     
        }

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

Discussions similaires

  1. [XL-2010] Contrôle d'erreur lors de la saisie d'une variable de type Byte
    Par xloganx dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 21/03/2017, 23h01
  2. Réponses: 2
    Dernier message: 29/08/2012, 11h05
  3. Réponses: 1
    Dernier message: 22/02/2008, 11h30
  4. Erreur lors de la création d'une variable
    Par neuro6 dans le forum C++
    Réponses: 5
    Dernier message: 22/01/2007, 08h40
  5. Réponses: 6
    Dernier message: 29/04/2006, 20h37

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