1. Go to this page and download the library: Download codephix/melhorenvio-sdk library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
codephix / melhorenvio-sdk example snippets
// Instancia o objeto
$MelhorEnvio = new MelhorEnvio\MelhorEnvio(
"CLIENT ID",
"SECRET KEY",
"NOME DO APP",
"EMAIL TECNICO"
);
// Adiciona a url de callback
$MelhorEnvio->setCallbackURL("URL PARA RETORNO");
// Solicita a autenticacao
// O usuario será redirecionado para uma página da melhor envio.
$MelhorEnvio->requestAuthorization();
// Solicita o token
$retorno = $MelhorEnvio->requestToken($_GET["code"]);
// Verifica se não ocorreu erro
if(!$retorno["error"])
{
// Recupera as informações
$retorno = $retorno["data"];
}
// Solicita a atualizacao
$resposta = $MelhorEnvio->refreshToken($refreshToken);
// Verifica se deu certo
if(!$resposta["error"])
{
// Armaze os novos tokens
$resposta["data"];
}
// Informa o token
$MelhorEnvio->setAccessToken("Access Token");
// Instancia o produto
$Product = new MelhorEnvio\Product();
// Seta as informações do produto.
// Pode duplicar esse item para adicionar mais produtos
$Product->setProducts(
"Id do produto",
"Nome do produto",
"Largura",
"Altura",
"Comprimento",
"Peso",
"Valor do Produto",
"Quantidade"
);
// Realiza o calculo do frete
$resposta = $MelhorEnvio->calculate("CEP do remetente", "CEP do destinatario", $Product);
// Verifica se deu certo
if(!$resposta["error"])
{
// As informações do frete estão no array
$resposta["data"]
}
// Informa o token
$MelhorEnvio->setAccessToken("Access Token");
// Destinatario e Remetente
$Destinatario = new MelhorEnvio\User();
$Remetente = new MelhorEnvio\User();
// Adiciona as informações
$Destinatario->setDocumentos("CPF");
$Destinatario->setInformacaoPessoal("NOME", "EMAIL", "CELULAR");
$Destinatario->setEndereco([
"endereco" => "Rua xyz",
"numero" => 123,
"bairro" => "Jardim São José",
"cidade" => "São Paulo",
"cep" => 11200363
]);
// Adiciona as informações do remetente
$Remetente->setDocumentos("CPF", "CNPJ", "INCRICAO ESTADUAL");
$Remetente->setInformacaoPessoal("NOME", "EMAIL", "CELULAR");
$Remetente->setEndereco([
"endereco" => "Rua xyz",
"numero" => 123,
"bairro" => "Jardim São José",
"cidade" => "São Paulo",
"cep" => 11200363
]);
// Instancia o produto
$Product = new MelhorEnvio\Product();
// Seta as informações do produto.
// Pode duplicar esse item para adicionar mais produtos
$Product->setProducts(
"Id do produto",
"Nome do produto",
"Largura",
"Altura",
"Comprimento",
"Peso",
"Valor do Produto",
"Quantidade"
);
// Pacote
// Quando foi calculado o valor do frete, ele retorno os pacotes disponiveis
$pacotes = [];
/**
* OBS:
* Em caso de vários pacotes para a transportadora correios
* deverá realizar uma solicitação por pacote. As demais poderá
* realizar apenas uma solicitação passando um array de pacotes,
* da maneira que iremos fazer agora.
**/
// Percorre os pacotes
foreach ($packages as $package)
{
$pacotes[] = [
"height" => $packages->dimensions->height,
"width" => $packages->dimensions->width,
"length" => $packages->dimensions->length,
"weight" => $packages->weight
];
}
// Codigo do serviço de envio
$code = "CODIGO DO SERVICO (RETORNADO NA BUSCA DO VALOR)";
// Realiza a solicitação de compra das etiqueta
$resposta = $MelhorEnvio->requestBuyTag($Destinatario, $Remetente, $Product, $pacote, $code, "Identificador do Pedido");
// Verifica se deu certo
if(!$resposta["error"])
{
// Será retorno os ids da solicitação
// Armaze os ids para poder realizar a compra da etiqueta
$ids = $resposta["data"];
}
// Verifica se o id retornado não é um array
if(!is_array($ids))
{
// Força ser um array
$ids = [$ids];
}
// Realiza a compra da etiqueta
$resposta = $MelhorEnvio->processBuyTag($ids);
// Verifica se deu certo
if(!$resposta["error"])
{
// Apos o pagamento é necessário realizar a solicitação
// para impressão da etiqueta.
}
// Solicita a impressão das etiquetas
$resposta = $MelhorEnvio->printTag($ids);
// Verifica se deu certo
if(!$resposta["error"])
{
// É retornado um array contendo a url para impressão
$resposta["data"]
// Exemplo do array retornado no item data
// (Array) ["url" => "URL DO PDF DA ETIQUETA"]
}
// Gera o codigo de rastreio
$rasteio = $MelhorEnvio->getTracking($ids);
// Verifica se deu certo
if(!$resposta["error"])
{
// É retornado um array contendo os códigos
$resposta["data"]
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.