2017-09-26 1 views
-1

Pas vraiment s'attendre à obtenir une réponse, mais se débattent avec ce 2 jours maintenant et n'ont aucune idée de ce qui se passe.Le navigateur se bloque après AJAX complet (réponse d'attente?)

Voici donc ce que je l'ai fait:

fichier via AJAX et Uploading commencer immédiatement le traitement en arrière-plan.

$.ajax({ 
    type : "post", 
    cache: false, 
    contentType: false, 
    processData: false, 
    url : formAction, 
    data : formData 
}); 

En backend j'écrit la session où stocker les progrès actuels comme 500 de 10000 ...

J'appeler un autre AJAX pour vérifier l'état de la session, j'appeler ce funcion toutes les 1 seconde jusqu'à ce que les rendements responsve « done '. Cela me semble légitime, mais le problème est qu'après le traitement backend effectué, et le premier changement de statut de XHR de 'pending' à 200 freezer, on dirait que quelque chose le bloque, comme une autre requête ou quelque chose. Chekc écrans ci-dessous.

starting to process imported file

Il est fait, chèque est arrêté, l'état est changé à 200, rien ne se passe mais les navigateurs geler, essayé Chrome, Firefox ... Navigateur me suggère de tuer processus, mais si j'attendre un certain temps va se rafraîchir.

Done

MISE À JOUR

donc je mens un peu, j'ai essayé à nouveau faire même mais sans ajax et vu problème similaire, après une réponse en attente de traitement back-end complet, navigateur (rotation arrière) .. Alors c'est ce cousin qui pend.

Voici mon backend il est Laravel

foreach ($chunks as $rows) 
     { 
      $current_chunk++; 

      if ($current_chunk < $all_chunks) { 
       Session::put(['import_progress'=>'Importing ' . $current_chunk * 150 . ' of ' . $all_results]); 
       Session::save(); 
      } elseif ($current_chunk >= $all_chunks) { 
       Session::put(['import_progress'=>'done']); 
      } 

      foreach ($rows as $row) 
      { 
       // transakcija start 
       DB::transaction(function() use ($row) { 

        $code = $row[0]; 
        $gender = $row[1]; 
        $brand_name = filter_var($row[2],FILTER_SANITIZE_STRING); 
        $category = $row[3]; 
        $subcategory = $row[4]; 
        $condition = $row[5]; 
        $details = $row[6]; 
        $composition = $row[7]; 
        $materials = $row[8]; 
        $colors = $row[9]; 
        $patterns = $row[10]; 
        $country = $row[11]; 
        $size = $row[12]; 
        $m_a = $row[13]; 
        $m_b = $row[14]; 
        $m_c = $row[15]; 
        $m_d = $row[16]; 
        $m_e = $row[17]; 
        $m_f = $row[18]; 
        $m_g = $row[19]; 

        $product = new Product(); 
        $product->code = $code; 
        $product->gender = $gender; 
        $product->size = $country . ' | ' . $size; 
        $product->condition = $condition; 
        $product->measurement_a = $m_a; 
        $product->measurement_b = $m_b; 
        $product->measurement_c = $m_c; 
        $product->measurement_d = $m_d; 
        $product->measurement_e = $m_e; 
        $product->measurement_f = $m_f; 
        $product->measurement_g = $m_g; 
        $product->save(); 

        if (empty($code)) { 
         $bad_prods[] = $product->id; 
        } 

        if (!empty($brand_name)) { 
         $brand = Brand::firstOrCreate(['brand_name'=>$brand_name]); 
         $product_b = new ProductBrand(); 
         $product_b->brand_id = $brand->id; 
         $product_b->product_id = $product->id; 
         $product_b->save(); 
        } 

        if (!empty($materials)) { 
         $materials_exp = explode(',',$materials); 

         foreach ($materials_exp as $material) { 
          $material = Material::firstOrCreate(['material_name'=>trim($material)]); 
          $product_m = new ProductMaterial(); 
          $product_m->material_id = $material->id; 
          $product_m->product_id = $product->id; 
          $product_m->save(); 
         } 
        } 

        if (!empty($patterns)) { 
         $patterns_exp = explode('/',$patterns); 
         foreach ($patterns_exp as $pattern) { 
          $pattern = Pattern::firstOrCreate(['pattern_name'=>trim($pattern)]); 
          $product_p = new ProductPattern(); 
          $product_p->pattern_id = $pattern->id; 
          $product_p->product_id = $product->id; 
          $product_p->save(); 
         } 
        } 

        if (!empty($colors)) { 
         $colors_exp = explode('/',$colors); 
         foreach ($colors_exp as $color) { 
          $color = Color::firstOrCreate(['color_name'=>trim($color)]); 
          $product_c = new ProductColor(); 
          $product_c->color_id = $color->id; 
          $product_c->product_id = $product->id; 
          $product_c->save(); 
         } 
        } 

        $product_t = new ProductTranslation(); 
        $product_t->product_id = $product->id; 
        $product_t->product_title = $brand_name; 
        $product_t->product_description = '<p>'.$details.'</p><p>'.$composition.'</p>'; 
        $product_t->save(); 

       }); // end transakcija 
      } 
     } 

     Session::put(['import_progress'=>'done']); 
     Session::put(['bad_prods'=>$bad_prods]); 

     return redirect()->route('admin.import'); 

Et là, je suis vérification de l'état

public function status() 
    { 
     return response()->json([ 
      'status' => Session::get('import_progress'), 
      'bad_prods' => Session::get('bad_prods') 
     ]); 
    } 
+0

Avoir ** SetTimeout() ** ou ** SetInterval() ** N'importe où dans le reste du code? Affichez la partie où vous appelez la fonction après un intervalle régulier. –

+0

J'ai, mais même passe sans vérifier l'état, donc ce n'est pas un problème ... – RomkaLTU

+0

Post l'extrait où vous êtes en train de rafraîchir/vérifier l'état –

Répondre

0

Lorsque le traitement est fait, je mets la sortie simple(); à la fin du traitement Contrôleur ... Pas sûr pourquoi cela fonctionne et toute autre déclaration de retour ne fonctionne pas.