Trying to copy images from remote server to use as thumbnails in my wordpress site. Some of this images become corrupted after copying.
Here's my code:
$url = 'http://media.cultserv.ru/i/1000x1000/'.$event->subevents[0]->image;
$timeout_seconds = 100;
$temp_file = download_url( $url, $timeout_seconds );
if(!is_wp_error( $temp_file )) {
  $file = array(
    'name' => basename($url),
    'type' => wp_check_filetype(basename($url), null),
    'tmp_name' => $temp_file,
    'error' => 0,
    'size' => filesize($temp_file),
  );
  $overrides = array(
    'test_form' => false,
    'test_size' => true,
    'test_upload' => true,
  );
  $results = wp_handle_sideload( $file, $overrides );
  if(empty($results['error'])) {
    $filename = $results['file'];
    $local_url = $results['url'];
    $type = $results['type'];
    $attachment = array(
      'post_mime_type' => $results['type'],
      'post_title' => preg_replace('/.[^.]+$/', '', basename( $results['file'] ) ),
      'post_content' => '',
      'post_status' => 'inherit',
      'post_type' => 'attachment',
      'post_parent' => $pID,
    );
    $attachment_id = wp_insert_attachment( $attachment, $filename );
    if($attachment_id) {
      set_post_thumbnail( $pID, $attachment_id );
    }
  }
}
Here's a screenshot that shows what I mean (Left - original image; Right - copy on my server):

I think that your download_url( $url, $timeout_seconds ) function is not working properly (you don't get to catch network/other errors, that's why you have corrupted images), also I don't think that the timeout parameter is really needed to download an url...
To fix this it's better to rewrite this function into something like this :
function download_url($url)
{
    $saveto = 'temp.jpg'; // generate temp file
    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_BINARYTRANSFER, 1);
    $raw = curl_exec($ch);
    if (curl_errno($ch)) {
        curl_close($ch);
        return false;
        // you probably have a network problem here.
        // you need to handle it, for example retry or skip and reqeue the image url
    }
    curl_close($ch);
    if (file_exists($saveto)) {
        unlink($saveto);
    }
    $fp = fopen($saveto, 'x');
    fwrite($fp, $raw);
    fclose($fp);
    return $saveto;
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With