• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Integracja Server-side PAYPAL

Object Storage Arubacloud
0 głosów
261 wizyt
pytanie zadane 10 grudnia 2019 w PHP przez Damian Sierocki Użytkownik (800 p.)
zamknięte 11 grudnia 2019 przez Damian Sierocki

Witam.

Mam problem przy integracji z paypalem metodą server-side przy użyciu CURL (nie gotowych bibliotek SDK). Nie wiem czemu może nie działać, wrzucam kod źródłowy na dole z 3 plików.

server-checkout.html

<!DOCTYPE html>
<html>
  <head>
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
  </head>

  <body>
    <div id="paypal-button"></div>
    <script src="https://www.paypalobjects.com/api/checkout.js"></script>
    <script>
      paypal.Button.render(
        {
          env: "sandbox",

          payment: function(resolve, reject) {
            var CREATE_PAYMENT_URL = "server-checkout-payment.php";
            return paypal.request
              .post(CREATE_PAYMENT_URL)
              .then(function(data) {
                resolve(data.paymentID);
              })
              .catch(function(err) {
                reject(err);
              });
          },
          // Execute the payment
          onAuthorize: function(data) {
            var EXECUTE_PAYMENT_URL = "server-checkout-execute.php";
            return paypal.request
              .post(EXECUTE_PAYMENT_URL, {
                paymentID: data.paymentID,
                payerID: data.payerID
              })
              .then(function(data) {
                document.querySelector("#paypal-button").innerText =
                  "Payment Complete!";
              })
              .catch(function(err) {
                document.querySelector("#paypal-button").innerText =
                  "Payment Failed!";
              });
          }
        },
        "#paypal-button"
      );
    </script>
  </body>
</html>

server-checkout-payment.php

<?php
$requestData = array(
    'intent' => 'sale',
    'redirect_urls' => array(
        'return_url' => 'server-checkout.html',
        'cancel_url' => 'server-checkout.html'
    ),
    'payer' => array(
        'payment_method' => 'paypal',
    ),
    'transactions' => array(
        array(
            'amount' => array(
                'total' => '10.00',
                'currency' => 'USD',
            ),
            'items_list' => array(
                'items' => array(
                    array(
                        'quantity' => '1',
                        'name' => 'item1',
                        'price' => '10.00',
                        'currency' => 'USD',
                    ),
                ),
            ),
        ),
    ),
);
$requestJson = json_encode($requestJson);

$ch = curl_init();

curl_setopt($ch, CURLOPT_URL, 'https://api.sandbox.paypal.com/v1/payments/payment');
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
    'Content-Type: application/json',
    'Authorization: Bearer A21AAGaAT5GsrcjRtvmnUjNwTGOefdc7sY_L7OLllpXPMzyMtFHxZ5O7Nv2BWm5P1tdtO4xJQU8js3izip5H0skQlmlbA4kbA'
));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_2);
curl_setopt($ch, CURLOPT_POSTFIELDS, $requestJson);

$result = curl_exec($ch);
if (!$result) {
    $error = curl_error($ch);
    curl_close($ch);
    throw new \Exception($error);
}

$result = json_decode($result);

$response = array(
    'paymentID' => $result->id
);


echo json_encode($response);

server-checkout-execute.php

<?php
$requestData = array(
    'payer_id' => $_REQUEST['payerID']
);

$requestJson = json_encode($requestData);

$ch = curl_init();

curl_setopt($ch, CURLOPT_URL, "https://api.sandbox.paypal.com/v1/payments/payment/{$_REQUEST['paymentID']}/execute");
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
    'Content-Type: application/json',
    'Authorization: Bearer A21AAGaAT5GsrcjRtvmnUjNwTGOefdc7sY_L7OLllpXPMzyMtFHxZ5O7Nv2BWm5P1tdtO4xJQU8js3izip5H0skQlmlbA4kbA'
));

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_2);
curl_setopt($ch, CURLOPT_POSTFIELDS, $requestJson);

$result = curl_exec($ch);
if (!$result) {
    $error = curl_error($ch);
    curl_close($ch);
    throw new \Exception($error);
}

$resultArray = json_decode($result);
if ($resultArray->state != 'approved') {
    throw new \Exception("Failed to approve the payment.");
}


echo json_encode(array(
    'status' => 'OK',
));

I jeszcze consoli logi z chroma

komentarz zamknięcia: Już nie potrzeba

1 odpowiedź

0 głosów
odpowiedź 10 grudnia 2019 przez damenox Obywatel (1,400 p.)
Co zwraca curl ?  Pokaż zawartość zmiennej result po curl_exec
komentarz 10 grudnia 2019 przez Damian Sierocki Użytkownik (800 p.)

Tak jakby jest pusta 

komentarz 10 grudnia 2019 przez damenox Obywatel (1,400 p.)

A jaki kod statusu zwraca ? Sprawdź za pomocą takiej instrukcji

$httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE);

 

komentarz 10 grudnia 2019 przez Damian Sierocki Użytkownik (800 p.)
Jestem trochę cienki w php i zwłaszcza curl, w którą linijkę to konkretnie wkleić? Debuguje w phpstorm
komentarz 10 grudnia 2019 przez damenox Obywatel (1,400 p.)
Wklej linijkę, którą w poprzednim komentarzu zamieściłem pod curl_exec i pokaż zawartość zmiennej $httpcode

Podobne pytania

+2 głosów
1 odpowiedź 1,136 wizyt
pytanie zadane 17 sierpnia 2017 w PHP przez R[a]=d(ek); Mądrala (6,370 p.)
0 głosów
2 odpowiedzi 265 wizyt
pytanie zadane 13 lutego 2020 w PHP przez Dexter24 Nowicjusz (190 p.)
0 głosów
0 odpowiedzi 119 wizyt
pytanie zadane 10 kwietnia 2019 w HTML i CSS przez niezalogowany

92,572 zapytań

141,423 odpowiedzi

319,645 komentarzy

61,959 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...