
Como adicionar uma imagem no produto programaticamente utilizando a função nativa do Magento, “addImageToMediaGallery()”.
Neste exemplo você poderá adicionar várias imagens e definir qual delas é a principal.
Antes de tudo, como vamos receber essa imagem?
Iremos utilizar a imagem convertida na Base64.
Recebemos a imagem codificada e convertemos para seu formato original utilizando o método “base64_decode()”.
$filepath = Mage::getBaseDir('media') . DS . 'tmp'. DS . $id . "-" . $picture_name;
$query = base64_decode( $picture_base64 );
file_put_contents($filepath, $query); Temos 3 variáveis importante no código acima.
Com a função “file_put_contents()”, salvamos a foto decodificada no diretório temporário do Magento para sua posterior utilização.
$filepath = Mage::getBaseDir('media') . DS . 'tmp'. DS . $id . "-" . $picture_name;
$curl_handle = curl_init();
curl_setopt($curl_handle, CURLOPT_URL,$url);
curl_setopt($curl_handle, CURLOPT_CONNECTTIMEOUT, 2);
curl_setopt($curl_handle, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl_handle, CURLOPT_USERAGENT, 'Cirkel');
$query = curl_exec($curl_handle);
curl_close($curl_handle);
file_put_contents($filepath, $query); Mais uma vez temos 3 variáveis importante .
Observação: não utilizar o protocolo https.
Utilizamos a biblioteca “cURL” para baixar a imagem na variável “query”.
Feito isso, salvamos ela no diretório temporário que está configurado na variável “filepath”.
Essa é a opção mais simples.
Caso você já esteja fazendo o upload da foto no servidor aonde o Magento está instalado, basta você passar o caminho completo do arquivo da imagem para variável “filepath”.
Primeiro passo é carregar o objeto do produto.
$id = Mage::getModel('catalog/product')->getIdBySku($sku);
$product = Mage::getModel('catalog/product')->load($id); No exemplo acima eu carrego o produto utilizando o “Sku”.
Com “Sku” eu consigo recuperar o “Id” do produto para utilizar no método “load()”.
Se você já tiver disponível em seu código o “Id” do produto, pular a parte do “Sku”.
$attr = array('image', 'small_image', 'thumbnail'); No array acima, estamos passando que essa imagem será utilizada como padrão para os três tipos de exibição acima.
Deixe esse array vazio, caso essa seja uma imagem complementar.
$attr = array();
$product->addImageToMediaGallery($filepath, $attr , false, false); $product->save();
Utilizamos o método “addImageToMediaGallery()” para adicionar a imagem a galeria de fotos do produto.
Repare no parâmetro “filepath” que é o caminho completo da foto no mesmo servidor aonde o Magento está instalado.
Não podemos esquecer de deletar a foto que ficou salvar no diretório temporário.
if (file_exists($filepath)){
unlink($filepath)
} Para listar todas as fotos de um produto você pode utilizar o exemplo abaixo.
$mediaApi = Mage::getModel("catalog/product_attribute_media_api");
$mediaApiItems = $mediaApi->items($id);
$extension = substr(strrchr($picture_name,'.'), 1);
$clean_name = str_replace( "." . $extension , "", $picture_name);
$ax1 = $id . "-" . $clean_name;
$picture_found = false;
foreach($mediaApiItems as $item) {
$ax2 = $item['file'];
$pos = strpos($ax2, $ax1);
if ($pos === false) {
}else{
$picture_found = true;
break;
}
} Passo na função “$mediaApi->items($id)” o ID do produto para retornar um array com todas as fotos do produto.
Depois faço um loop no array verificando se o nome que utilizamos está presente.
Se a foto for encontrada, “true” para variável “picture_found”, caso contrário permanecerá como “false”.
Não é necessário fazer essa verificação, pois qualquer erro no método “addImageToMediaGallery()” irá gerar uma exceção fatal.
Observação: Código acima só irá funcionar se você garantir que o nome da foto “picture_name” é único.
Como remover todas as fotos de um produto no Magento
Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…
A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…
Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…
Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…
No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…
Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…