2016-09-19 4 views
5

Попытка копирования изображений с удаленного сервера для использования в качестве эскизов на моем сайте Wordpress. Некоторые из этих изображений становятся поврежденными после копирования.Изображения повреждены после копирования

Вот мой код:

$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); 
    } 
    } 
} 

Вот скриншот, который показывает, что я имею в виду (слева - исходное изображение; справа - скопировать на моем сервере):

screenshot

+0

Попробуйте использовать '$ attachData = wp_generate_attachment_metadata ($ attachment_id, $ файла);' и 'wp_update_attachment_metadata ($ attach_id, $ attachData); 'beofre вызывать' set_post_thumbnail' и посмотреть, улучшится ли полученное изображение. Убедитесь, что 'require_once (ABSPATH. 'Wp-admin/includes/image.php');' где-то на скрипте. – fyrye

+0

Проблема в том, что изображение, доступное по URL-адресу, хранящемуся в $ local_url, уже повреждено. Это до создания вложения. –

ответ

1

Я думаю, что ваш download_url($url, $timeout_seconds) функция не работает должным образом (вы не можете поймать сетевые/другие ошибки, поэтому у вас поврежденные изображения), также я не думаю, что параметр таймаута действительно необходим для загрузки URL-адреса ...

Чтобы это исправить, лучше переписать эту функцию в нечто вроде этого:

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; 
} 
Смежные вопросы