Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Wagner Martins Bodyboard

Enviar vários produtos para o pagseguro

Recommended Posts

enho esse código onde pego as informações necessárias para fazer uma transação pelo pagseguro.

<?php 

    $creditCardToken = htmlspecialchars($_POST["token"]);
    $senderHash = htmlspecialchars($_POST["senderHash"]);

    $params = array(
        'email'                     => $PAGSEGURO_EMAIL,  
        'token'                     => $PAGSEGURO_TOKEN,
        'creditCardToken'           => $creditCardToken,
        'senderHash'                => $senderHash,
        'receiverEmail'             => $PAGSEGURO_EMAIL,
        'paymentMode'               => 'default', 
        'paymentMethod'             => 'creditCard', 
        'currency'                  => 'BRL',
        // 'extraAmount'               => '1.00',
        'itemId1'                   => '0001',
        'itemDescription1'          => 'PHP Test',  
        'itemAmount1'               => '100.00',  
        'itemQuantity1'             => 1,
        'reference'                 => 'REF1234',
        'senderName'                => 'Chuck Norris',
        'senderCPF'                 => '54793120652',
        'senderAreaCode'            => 83,
        'senderPhone'               => '999999999',
        'senderEmail'               => 'ChuckNorris@sandbox.pagseguro.com.br',
        'shippingAddressStreet'     => 'Address',
        'shippingAddressNumber'     => '1234',
        'shippingAddressDistrict'   => 'Bairro',
        'shippingAddressPostalCode' => '58075000',
        'shippingAddressCity'       => 'João Pessoa',
        'shippingAddressState'      => 'PB',
        'shippingAddressCountry'    => 'BRA',
        'shippingType'              => 1,
        'shippingCost'              => '1.00',
        'installmentQuantity'       => 1,
        'installmentValue'          => '101.00',
        'creditCardHolderName'      => 'Chuck Norris',
        'creditCardHolderCPF'       => '54793120652',
        'creditCardHolderBirthDate' => '01/01/1990',
        'creditCardHolderAreaCode'  => 83,
        'creditCardHolderPhone'     => '999999999',
        'billingAddressStreet'     => 'Address',
        'billingAddressNumber'     => '1234',
        'billingAddressDistrict'   => 'Bairro',
        'billingAddressPostalCode' => '58075000',
        'billingAddressCity'       => 'João Pessoa',
        'billingAddressState'      => 'PB',
        'billingAddressCountry'    => 'BRA'
    );

    $header = array('Content-Type' => 'application/json; charset=UTF-8;');
    $response = curlExec($PAGSEGURO_API_URL."/transactions", $params, $header);
    $json = json_decode(json_encode(simplexml_load_string($response)));
?>

aqui mostra a quantidade de itens no carrinho, que no caso é 1

'itemId1'                   => '0001',
'itemDescription1'          => 'PHP Test',  
'itemAmount1'               => '100.00',  
'itemQuantity1'             => 1,
'reference'                 => 'REF1234',

Como eu faria para colocar mais de um item no carrinho e gerar pelo pagseguro?

 

tentei assim mais não tive suecsso

'itemId'                   => '0002',
        'itemDescription'          => 'PHP Test2',  
        'itemAmount'               => $numero,  
        'itemQuantity'             => 1,
        'reference'                 => 'REF12342',
        
        'itemId'                   => '00013',
        'itemDescription1'          => 'PHP Test3',  
        'itemAmount1'               => $numero,  
        'itemQuantity1'             => 1,
        'reference'                 => 'REF12343',
        
        'itemId'                   => '00014',
        'itemDescription1'          => 'PHP Test4',  
        'itemAmount1'               => $numero,  
        'itemQuantity1'             => 1,
        'reference'                 => 'REF12344',

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Você está utilizando uma versão mais antiga da API. 

 

As mais novas, enviaria um XML:

Spoiler

<?xml version="1.0"?>
<payment>
  <mode>default</mode>
  <currency>BRL</currency>
  <notificationURL>https://sualoja.com.br/notifica.html</notificationURL>
  <receiverEmail>suporte@lojamodelo.com.br</receiverEmail>
  <sender>
    <hash>04007c1448e7b1e26dd02b81ad332a3125ab977a1748f35b275c2dfefd45a041</hash>
    <ip>1.1.1.1</ip>
    <name>Jose Comprador</name>
    <bornDate>01/01/1900</bornDate>
    <email>comprador@uol.com.br</email>
    <phone>
      <areaCode>99</areaCode>
      <number>99999999</number>
    </phone>
    <documents>
      <document>
        <type>CPF</type>
        <value>11475714734</value>
      </document>
    </documents>
  </sender>
  <items>
    <item>
      <id>0001</id>
      <description>Produto PagSeguroI</description>
      <amount>99999.99</amount>
      <quantity>1</quantity>
    </item>
  </items>
  <reference>REF1234</reference>
  <shipping>
    <address>
      <street>Av. PagSeguro</street>
      <number>9999</number>
      <complement>99o andar</complement>
      <district>Jardim Internet</district>
      <city>Cidade Exemplo</city>
      <state>SP</state>
      <country>BRA</country>
      <postalCode>99999999</postalCode>
    </address>
    <type>1</type>
    <cost>1.00</cost>
    <addressRequired>true</addressRequired>
  </shipping>
  <extraAmount>1.00</extraAmount>
  <method>boleto</method>
  <creditCard>
    <token>1e358d39e26448dc8a28d0f1815f08c5</token>
    <installment>
      <quantity>1</quantity>
      <noInterestInstallmentQuantity>2</noInterestInstallmentQuantity>
      <value>99999.99</value>
    </installment>
    <holder>
      <name>Jose Comprador</name>
      <documents>
        <document>
          <type>CPF</type>
          <value>11475714734</value>
        </document>
      </documents>
      <birthDate>01/01/1900</birthDate>
      <phone>
        <areaCode>99</areaCode>
        <number>99999999</number>
      </phone>
    </holder>
    <address>
      <street>Av. PagSeguro</street>
      <number>9999</number>
      <complement>99o andar</complement>
      <district>Jardim Internet</district>
      <city>Cidade Exemplo</city>
      <state>SP</state>
      <country>BRA</country>
      <postalCode>99999999</postalCode>
    </address>
  </creditCard>
  <bank>
    <name>bancodobrasil</name>
  </bank>
  <dynamicPaymentMethodMessage>
    <creditCard>Minha loja</creditCard>
    <boleto>Minha loja</boleto>
  </dynamicPaymentMethodMessage>
  <promoCode>PROMOCODE_PAGSEGURO</promoCode>
</payment>

 

Dentro do XML, poderiam ser adicionados quantos produtos quisessem.

 

Já, no seu caso, provavelmente é necessário apenas alterar o número de sufixo:

'itemId1'                   => '0001',
'itemDescription1'          => 'PHP Test',  
'itemAmount1'               => '100.00',  
'itemQuantity1'             => 1,

'itemId2'                   => '0002',
'itemDescription2'          => 'PHP Test 2',  
'itemAmount2'               => '100.00',  
'itemQuantity2'             => 1,

'itemId3'                   => '0003',
'itemDescription3'          => 'PHP Test 3',  
'itemAmount3'               => '100.00',  
'itemQuantity3'             => 1,

Lembrando que, 'reference' não é uma propriedade do produto e sim a referência da venda (número de ordem de venda, número da nota, etc..)

Compartilhar este post


Link para o post
Compartilhar em outros sites

blza, funcionou!

 

Como eu faço para o PHP pegar dinamicamente os itens do carrinho e colocar dentro do array $params[]? Para que possa ser enviados todos os produtos do carrinho?

Essa parte pega os produtos para ser gerado dentro do array pelo PHP:

            'itemId1'                   => '0001',
            'itemDescription1'          => 'PHP Test',  
            'itemAmount1'               => $numero,  
            'itemQuantity1'             => 1,

            'itemId2'                   => '0002',
            'itemDescription2'          => 'PHP Test2',  
            'itemAmount2'               => $numero,  
            'itemQuantity2'             => 1,
 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.