Magento

Como exportar produtos no formato JSON – Magento

Como exportar produtos no formato JSON é um post que irá ensinar a como criar uma lista de produtos e disponibiliza-la no formato JSON no Magento, versão 1.9.x.

Sobre exportando os produtos em JSON

Este tutorial é útil para integrações, aonde você deseja exibir em widgets alguns produtos de sua loja virtual Magento em outros sites.

Você também pode utilizar este código como base para uma integração.

Criando o arquivo

Crie o arquivo PHP “produtos.php” na raiz da instalação Magento.

Inicie com seguinte código:

 header("Access-Control-Allow-Origin: *");

Este Header irá permitir que sites externos acessem este arquivo (ex: via ajax..)

Carregando Magento no arquivo externo

Iremos utilizar um arquivo “fora” do Magento, para que possamos acessar as funções, classes, etc, devemos incluir em nosso arquivo:

 require_once '../app/Mage.php';

 umask(0);

 Mage::app('default');

Não vamos complicar a coisa, nem tudo precisa de um módulo, ainda mais para a versão 1.9.x que logo será descontinuada.

Montando a collection

Neste parte montamos nossa collection.

 $collection_aux = Mage::getModel('catalog/product')->getCollection();

 $collection_aux->joinField(

 'qty',

 'cataloginventory/stock_item',

 'qty',

 'product_id=entity_id',

 '{{table}}.stock_id=1',

 'left'

 );

 

Utilizo o “joinField” para agregar na nossa collection o estoque do produto.

Neste parte estou adicionando alguns atributos para filtrar a collection “addAttributeToFilter”, como Status, Tipo…

 $collection_aux->addAttributeToFilter('qty', array('neq' => 0));

 $collection_aux->addAttributeToFilter('type_id','simple');

 $collection_aux->addAttributeToFilter('status', 1);

 $collection_aux->addAttributeToFilter('visibility', 4);

 $collection_aux->addAttributeToSelect('price');

 $collection_aux->addAttributeToSelect('special_price');

 $collection_aux->addAttributeToSelect('name');

 $collection_aux->addAttributeToSelect('url');

 $collection_aux->addAttributeToSelect('image');

 $collection_aux->joinField('category_id',

 'catalog/category_product',

 'category_id',

 'product_id=entity_id',

 null,

 'left'

 );

E com addAttributeToSelect os campos que desejo.

Utilizo o joinField mais uma vez para incluir também a categoria.

Nesta parte estou definindo o modo de ordenação aleatório, você pode comentar ou alterar de acordo com suas necessidades.

$collection_aux->getSelect()->order(new Zend_Db_Expr('RAND()'));

Defino a quantidade de registros que desejo. Você pode montar uma paginação utilizando setPageSizesetCurPage.

$collection_aux->setPageSize(20)->setCurPage(1);

Parte Final, loop e output JSON

Percorremos os produtos e trabalhamos os valores em um array que será convertido para formato JSON.

 $products = array();

 $_coreHelper =  Mage::helper('core');

 foreach ($collection_aux as $product){


  $price = $product->getPrice();

  $specialprice = $product->getFinalPrice();


  if( ((int) $price) == ((int) $specialprice)){

  $price = $price;

  }else{  

  $price = $specialprice;  

  }
  

 $products[] = array("name" => $product->getName(), "sku" => $product->getSku(), "url" => $product->getProductUrl(), "picture" => (string)Mage::helper('catalog/image')->init($product, 'image')->resize(197, 167), "price" => $price );

}

 

 echo json_encode($products);

Conclusão do como exportar produtos no formato JSON

Você pode montar uma simples integração utilizando este tutorial, análise o código e faça as melhorias.

Qualquer dúvida ou erro, por favor faça um comentário.

Código completo

<?php

 header("Access-Control-Allow-Origin: *");

 require_once '../app/Mage.php';

 umask(0);

 Mage::app('default');

 

 $collection_aux = Mage::getModel('catalog/product')->getCollection();

 $collection_aux->joinField(

 'qty',

 'cataloginventory/stock_item',

 'qty',

 'product_id=entity_id',

 '{{table}}.stock_id=1',

 'left'

 );

 

 

 

 $collection_aux->addAttributeToFilter('qty', array('neq' => 0));

 $collection_aux->addAttributeToFilter('type_id','simple');

 $collection_aux->addAttributeToFilter('status', 1);

 $collection_aux->addAttributeToFilter('visibility', 4);

 $collection_aux->addAttributeToSelect('price');

 $collection_aux->addAttributeToSelect('special_price');

 $collection_aux->addAttributeToSelect('name');

 $collection_aux->addAttributeToSelect('url');

 $collection_aux->addAttributeToSelect('image');

 $collection_aux->joinField('category_id',

 'catalog/category_product',

 'category_id',

 'product_id=entity_id',

 null,

 'left'

 );

 

$collection_aux->getSelect()->order(new Zend_Db_Expr('RAND()'));



$collection_aux->setPageSize(20)->setCurPage(1);

 

 

 $products = array();

 $_coreHelper =  Mage::helper('core');

 foreach ($collection_aux as $product){


  $price = $product->getPrice();

  $specialprice = $product->getFinalPrice();


  if( ((int) $price) == ((int) $specialprice)){

  $price = $price;

  }else{  

  $price = $specialprice;  

  }
  

 $products[] = array("name" => $product->getName(), "sku" => $product->getSku(), "url" => $product->getProductUrl(), "picture" => (string)Mage::helper('catalog/image')->init($product, 'image')->resize(197, 167), "price" => $price );

}

 

 echo json_encode($products);

 

?>

 

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

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…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

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…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás