0

OpenCart 框架版本 3.0.2.0 中有一个错误,

如果存在文件名之间包含空格的文件,则处理和执行时间过长

例如:考虑

img = https://DomainNameServer/image/catalog/pimages/SKU 081985 P80.jpg

<?php

set_time_limit(0);
ignore_user_abort(true);

public  function addSubImages($images){    
      $Image =array();

      foreach($images['img'] as $key => $img){

          $headers[] = 'Accept: image/gif, image/x-bitmap, image/jpeg, image/pjpeg';              
          $headers[] = 'Connection: Keep-Alive';         
          $headers[] = 'Content-type: application/x-www-form-urlencoded;charset=UTF-8';         
          $user_agent = 'php';         
          $process = curl_init($img); // http://localhost/bluemb/image/catalog/pimages/SKU 081985 P80.jpg    
          curl_setopt($process, CURLOPT_HTTPHEADER, $headers);         
          curl_setopt($process, CURLOPT_HEADER, 0);         
          curl_setopt($process, CURLOPT_USERAGENT, $user_agent);
          curl_setopt($process, CURLOPT_TIMEOUT, 1800);   
          curl_setopt($process, CURLOPT_CONNECTTIMEOUT, 0); 
          //curl_setopt($process, CURLOPT_CONNECTTIMEOUT, 1700); 
          curl_setopt($process, CURLOPT_RETURNTRANSFER, 1);         
          curl_setopt($process, CURLOPT_FOLLOWLOCATION, 1);         
          $return = curl_exec($process);         
          curl_close($process);         
          //return $return;  

          $filepath  = pathinfo($img);
          $dirname  = DIR_IMAGE.'catalog/prod/';

          if (!file_exists($dirname)) {
            mkdir($dirname, 0755, true);
          } 

          if (!empty($dirname)) {
            $srcfile = $img;
            $dstfile = DIR_IMAGE.'catalog/prod/'.$filepath['basename']; // /var/www/html/opencart/image/catalog/prod/SKU 081985 P80.jpg
            $Image[] = 'catalog/prod/'.$filepath['basename'];  //catalog/prod/SKU 081985 P80.jpg
            copy(str_replace(" ","%20",$srcfile), $dstfile);
            //file_put_contents($dstfile,$return);
          } 
          else {
            $Image = "";
          }

      }      
  return $Image;
}

使用以下这些功能:

  1. 图像以 Corrupted/RAW 格式保存,延迟时间更长,没有吞吐量 file_put_contents($dstfile, $return);

  2. 图像以适当的吞吐量完美保存,延迟更长 copy(str_replace(" ", "%20", $srcfile), $dstfile);

  3. 图像以文本格式保存,延迟时间更长,吞吐量不正确 @copy($srcfile, $dstfile); $content = file_get_contents($srcfile); $fp = fopen($dstfile , "w+"); fwrite($fp, $content); $Image = 'catalog/prod/'.$filepath['basename']; fclose($fp); curl_close($process);

  4. copy(urlencode($srcfile), $dstfile);

    结果:

    警告:复制(https%3A%2F%2Fwww.DomainNameServer.in%2Fimage%2Fcatalog%2Fpimages%2FSKU093126+%281%29.jpg):无法打开流: /var/www/html/opencart3中没有此类文件或目录/admin/model/account/apisync.php在第 264行

  5. copy(urldecode($srcfile), $dstfile);

    结果:

    警告:复制(https://www.DomainNameServer.in/image/catalog/pimages/SKU093126 (1).jpg):无法打开流:HTTP 请求失败!在第264行的/var/www/html/opencart3/admin/model/account/apisync.php

  6. copy(str_replace('_','%20',$srcfile), $dstfile);

    结果:

    警告:复制(https://www.DomainNameServer.in/image/catalog/pimages/SKU093126 (1).jpg):打开流失败:HTTP 请求失败!在 第265行 的/var/www/html/opencart3/admin/model/account/apisync.php

  7. copy(str_replace('%20',' ',$srcfile), $dstfile); copy(str_replace('%20','_',$srcfile), $dstfile); copy(str_replace('%20','',$srcfile), $dstfile);

    结果:

    警告:复制(https://www.DomainNameServer.in/image/catalog/pimages/SKU093126 (1).jpg):无法打开流:HTTP 请求失败!在 第265行 的/var/www/html/opencart3/admin/model/account/apisync.php


在构建 API 功能时,在 10,000 种产品中,只有 1091 种产品保存到数据库中,其余 8909 种产品需要 7 到 10 个小时才能执行。由于我已将执行时间限制设置为无限。当我在 10 小时后检查时,所有产品都已成功保存。

Total Time Taken 与 no 成正比。包含空格的图像文件名

导出编号。产品的名称根据包含空格的图像文件名而有所不同。当我调试三个具有带空格的图像文件名的产品时,它需要 20 分钟才能完成,而没有addSubImages()功能它甚至不需要一秒钟来执行

如果解决方案有任何其他方法可以解决这种情况?

4

2 回答 2

0

Modifying Prasannas answer this worked for me:

$string_without_space = str_replace(" ", "_", $string_with_space);
于 2020-01-27T18:56:38.647 回答
0

使用此代码不要使用空间

copy(str_replace("%20", "", $srcfile), $dstfile);
OR 
copy(str_replace("%20", "_", $srcfile), $dstfile);

https://www.w3schools.com/php/func_string_str_replace.asp

于 2018-06-12T10:42:40.720 回答