Necesito guardar una imagen de la URL directamente en mi servidor, he intentado con muchos métodos, pero parece que no funciona correctamente. file_put_contents($file_location, file_get_contents($image_url));
me mantiene sin obtener el error del directorio de archivos encontrado. Simple fopen
y fwrite
sigue devolviendo la imagen dañada. Éste funcionó, pero sigue devolviendo archivos html en lugar de archivos jpg.Guardar imagen de la URL con cURL
function getimg($url) {
$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 = 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)';
$process = curl_init($url);
curl_setopt($process, CURLOPT_HTTPHEADER, $headers);
curl_setopt($process, CURLOPT_HEADER, 0);
curl_setopt($process, CURLOPT_USERAGENT, $user_agent);
curl_setopt($process, CURLOPT_TIMEOUT, 30);
curl_setopt($process, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($process, CURLOPT_FOLLOWLOCATION, 1);
$return = curl_exec($process);
curl_close($process);
return $return;
}
$imgurl = 'http://some/url/to/image.jpg';
$imagename= basename($imgurl);
if(file_exists('./image/'.$imagename)){continue;}
$image = getimg($imgurl);
file_put_contents('image/'.$imagename,$image);
¿Algo falta?
Gracias.
¿Estás seguro de que es un archivo de imagen que estás intentando descargar y no una página web? ¿Qué contiene el archivo HTML que obtienes? – JJJ