nibblelab / boletobancario-php
BoletoBancario的Boleto Fácil REST API客户端
1.2-stable
2019-02-22 13:39 UTC
Requires
- php: ^7.1.0
- lib-curl: *
This package is auto-updated.
Last update: 2024-09-23 01:55:52 UTC
README
API规范可以在https://www.boletobancario.com/boletofacil/integration/integration.html找到
先决条件
- PHP >= 7.1.0
- libcurl
- composer
安装
使用composer安装
$ composer require nibblelab/boletobancario-php
支付请求
要请求支付,首先创建支付数据的详细信息,包括付款人信息
include './vendor/autoload.php';
use BoletoFacil\Payment\PaymentItem;
use BoletoFacil\Payment\Payer;
use BoletoFacil\BoletoFacil;
$item = new PaymentItem();
$item->setDescricao("Descrição"); # texto de descrição do pagamento
$item->setDataVencimento("99/99/9999"); # data de vencimento, no formato DD/MM/YYYY
$item->setValor(10.50); # valor do pagamento
$item->setReferencia("Id interno"); # referência do pagamento que me permita linkar o registro interno do meu sistema com o do boleto fácil
$pagador = new Payer();
$pagador->setNome("Teste de Teste"); # nome do pagador
$pagador->setCpfCnpj("099.999.999-99"); # CPF do pagador
通过票据支付
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"sua url de notificação",true); # modo sandbox
$b = new BoletoFacil($token,"sua url de notificação"); # modo produção
$url = $b->gerarBoleto($item, $pagador); # gera o boleto e obtem a URL de checkout
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
通过收据支付
$item->setParcelas(2); # carnê possui duas ou mais parcelas
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"sua url de notificação",true); # modo sandbox
$b = new BoletoFacil($token,"sua url de notificação"); # modo produção
$urls = $b->gerarCarne($item, $pagador); # gera o boleto e obtem as URLs de checkout
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
通过信用卡支付
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"sua url de notificação",true); # modo sandbox
$b = new BoletoFacil($token,"sua url de notificação"); # modo produção
$url = $b->gerarPagtoCartao($item, $pagador); # gera o pagamento e obtem a URL de checkout
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
通过信用卡提前支付分期款
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"sua url de notificação",true); # modo sandbox
$b = new BoletoFacil($token,"sua url de notificação"); # modo produção
$url = $b->gerarPagtoCartao($item, $pagador, true); # gera o pagamento e obtem a URL de checkout
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
通过信用卡或票据支付
$token = "seu_token"; # token de produção ou sandbox
$antecipar = false; # flag para permitir ou não a antecipação de parcelas
try
{
//$b = new BoletoFacil($token,"sua url de notificação",true); # modo sandbox
$b = new BoletoFacil($token,"sua url de notificação"); # modo produção
$url = $b->gerarBoletoOuCartao($item, $pagador, $antecipar); # gera o pagamento e obtem a URL de checkout
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
通过信用卡透明支付
在这种支付方式中,信用卡哈希是必需的。如何生成此字段的说明在:https://www.boletobancario.com/boletofacil/integration/integration.html#credit_card_hash
$token = "seu_token"; # token de produção ou sandbox
$hash_cartao = "hash_cartao"; # hash do cartão de crédito
try
{
//$b = new BoletoFacil($token,"sua url de notificação",true); # modo sandbox
$b = new BoletoFacil($token,"sua url de notificação"); # modo produção
$b->gerarPagtoCartaoTransparente($item, $pagador, $hash_cartao); # gera o pagamento
$status = $b->getPaymentResponse()->getData()->getPayments()[0]->getStatus(); # obtendo o status da transação
if($status == 'AUTHORIZED' || $status == 'CONFIRMED') # pagamento permitido
{
$id_cartao = $b->getPaymentResponse()->getData()->getPayments()[0]->getCreditCardId(); # obtendo o id do cartão
}
else if($status == 'DECLINED' || $status == 'FAILED' || $status == 'NOT_AUTHORIZED') # pagamento não permitido
{
}
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
通过信用卡透明支付并存储卡片
在这种支付方式中,信用卡哈希是必需的。如何生成此字段的说明在:https://www.boletobancario.com/boletofacil/integration/integration.html#credit_card_hash
可以存储信用卡信息以供将来支付使用。如果是这种情况,Boleto Fácil将生成一个id,该id可以在未来的透明支付交易中发送。
$token = "seu_token"; # token de produção ou sandbox
$hash_cartao = "hash_cartao"; # hash do cartão de crédito
$id_cartao = ''; # id de cartão previamente armazenado
$armazenar_cartao = true; # flag para indicar se o cartão será armazenado ou não
try
{
//$b = new BoletoFacil($token,"sua url de notificação",true); # modo sandbox
$b = new BoletoFacil($token,"sua url de notificação"); # modo produção
$b->gerarPagtoCartaoTransparente($item, $pagador, $hash_cartao, $id_cartao, $armazenar_cartao); # gera o pagamento
$status = $b->getPaymentResponse()->getData()->getPayments()[0]->getStatus(); # obtendo o status da transação
if($status == 'AUTHORIZED' || $status == 'CONFIRMED') # pagamento permitido
{
}
else if($status == 'DECLINED' || $status == 'FAILED' || $status == 'NOT_AUTHORIZED') # pagamento não permitido
{
}
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
支付通知
Boleto Fácil API通知支付状态的变化到支付请求中提供的URL。
要处理此通知并获取数据,请使用
include './vendor/autoload.php';
use BoletoFacil\BoletoFacil;
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"",true); # modo sandbox
$b = new BoletoFacil($token); # modo produção
$b->processarNotificacao(); # processa a requisição
$valor_pago = $b->getNotificationResponse()->getValorPago(); # obtendo o valor pago
$valor_taxas = $b->getNotificationResponse()->getValorTaxas(); # obtendo o valor das taxas
$valor_cobrado = $b->getNotificationResponse()->getValorCobrado(); # obtendo o valor cobrado
$referencia = $b->getNotificationResponse()->getPagtoReferencia(); # obtendo a referência do pagamento fornecida durante o pagamento
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
收费搜索
按到期日搜索
include './vendor/autoload.php';
use BoletoFacil\BoletoFacil;
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"",true); # modo sandbox
$b = new BoletoFacil($token); # modo produção
$pagamentos = $b->buscarCobrancasPorDataVencimento('99/99/9999'); # busca as cobranças que venceram após a data fornecida
# itere
foreach($cobrancas as $c)
{
$data_vencimento = $c->getDueDate(); # data de vencimento
# liste os pagamentos do registro
foreach($c->todosOsPagamentos() as $p) {
$data_pagto = $p->getDate(); # data do pagamento
$valor_pago = $p->getAmount(); # valor pago
$valor_taxas = $p->getFee(); # valor das taxas
$tipo_pagto = $p->getType(); # tipo do pagamento
$status_pagto = $p->getStatus(); # status do pagamento
}
}
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
按支付日期搜索
include './vendor/autoload.php';
use BoletoFacil\BoletoFacil;
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"",true); # modo sandbox
$b = new BoletoFacil($token); # modo produção
$cobrancas = $b->buscarCobrancasPorDataPagto('99/99/9999'); # busca as cobranças que foram pagas após a data fornecida
# itere
foreach($cobrancas as $c)
{
$data_vencimento = $c->getDueDate(); # data de vencimento
# liste os pagamentos do registro
foreach($c->todosOsPagamentos() as $p) {
$data_pagto = $p->getDate(); # data do pagamento
$valor_pago = $p->getAmount(); # valor pago
$valor_taxas = $p->getFee(); # valor das taxas
$tipo_pagto = $p->getType(); # tipo do pagamento
$status_pagto = $p->getStatus(); # status do pagamento
}
}
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
按支付确认日期搜索
include './vendor/autoload.php';
use BoletoFacil\BoletoFacil;
$token = "seu_token"; # token de produção ou sandbox
try
{
//$b = new BoletoFacil($token,"",true); # modo sandbox
$b = new BoletoFacil($token); # modo produção
$cobrancas = $b->buscarCobrancasPorDataConfirmacaoPagto('99/99/9999'); # busca as cobranças que tiveram pagamento confirmado após a data fornecida
# itere
foreach($cobrancas as $c)
{
$data_vencimento = $c->getDueDate(); # data de vencimento
# liste os pagamentos do registro
foreach($c->todosOsPagamentos() as $p) {
$data_pagto = $p->getDate(); # data do pagamento
$valor_pago = $p->getAmount(); # valor pago
$valor_taxas = $p->getFee(); # valor das taxas
$tipo_pagto = $p->getType(); # tipo do pagamento
$status_pagto = $p->getStatus(); # status do pagamento
}
}
}
catch(Exception $ex)
{
echo $ex->getMessage();
}
许可证
此项目采用Apache许可证 - 请参阅LICENSE.md以获取更多详细信息