2checkout Payment API不会给我成功回拨

时间:2014-05-21 11:54:29

标签: javascript php 2checkout

您好我正在尝试创建将使用2checkout API的付款 我按照2co提供的说明进行了操作,一切似乎都有效,但我从未收到确认信息,说明我的订单已经完成,我在沙盒上开了帐户,我使用了那里的信息,但仍然没有运气。

现在看到这是第一个包含表单和2co.js文件的代码

<!DOCTYPE html>
<html lang="en">
<head>
  <title>Example Form</title>
  <script type="text/javascript" src="https://www.2checkout.com/checkout/api/2co.min.js"></script>
  <script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
</head>
<body>
<form id="myCCForm" action="test3.php" method="post">
  <input name="token" type="hidden" value="" />
  <div>
    <label>
      <span>Card Number</span>
      <input id="ccNo" type="text" value="" autocomplete="off" required />
    </label>
  </div>
  <div>
    <label>
      <span>Expiration Date (MM/YYYY)</span>
      <input id="expMonth" type="text" size="2" required />
    </label>
    <span> / </span>
    <input id="expYear" type="text" size="4" required />
  </div>
  <div>
    <label>
      <span>CVC</span>
      <input id="cvv" type="text" value="" autocomplete="off" required />
    </label>
  </div>
  <input type="submit" value="Submit Payment" />
</form>

<script>
    // Called when token created successfully.
    var successCallback = function(data) {
        var myForm = document.getElementById('myCCForm');

        // Set the token as the value for the token input
        myForm.token.value = data.response.token.token;

        // IMPORTANT: Here we call `submit()` on the form element directly instead of using jQuery to prevent and infinite token request loop.
        myForm.submit();
    };

    // Called when token creation fails.
    var errorCallback = function(data) {
        // Retry the token request if ajax call fails
        if (data.errorCode === 200) {
            // This error code indicates that the ajax call failed. We recommend that you retry the token request.
        } else {
            alert(data.errorMsg);
        }
    };

    var tokenRequest = function() {
        // Setup token request arguments
        var args = {
            sellerId: "901249656",
            publishableKey: "0A0C4A4D-FE71-41D0-A960-7C637F347785",
            ccNo: $("#ccNo").val(),
            cvv: $("#cvv").val(),
            expMonth: $("#expMonth").val(),
            expYear: $("#expYear").val()
        };

        // Make the token request
        TCO.requestToken(successCallback, errorCallback, args);
    };

    $(function() {
        // Pull in the public encryption key for our environment
        TCO.loadPubKey('sandbox', function() {
            // Execute when Public Key is available
        });​

        $("#myCCForm").submit(function(e) {
            // Call our token request function
            tokenRequest();

            // Prevent form from submitting
            return false;
        });
    });

</script>
</body>
</html> 

我从沙箱模拟账户中获得了sellerId: "901249656",publishableKey: "0A0C4A4D-FE71-41D0-A960-7C637F347785",

现在这是其他页面&#34; test3.php &#34;

<?php
require_once("2checkout-php-master/lib/Twocheckout.php");
Twocheckout::privateKey('4D67BA12-CE09-4F1D-AB20-0133F24E3472');
Twocheckout::sellerId('901249656');
Twocheckout::sandbox(true);  #Uncomment to use Sandbox

try {
    $charge = Twocheckout_Charge::auth(array(
        "merchantOrderId" => "123",
        "token" => 'Y2U2OTdlZjMtOGQzMi00MDdkLWJjNGQtMGJhN2IyOTdlN2Ni',
        "currency" => 'USD',
        "total" => '10.00',
        "billingAddr" => array(
            "name" => 'Testing Tester',
            "addrLine1" => '123 Test St',
            "city" => 'Columbus',
            "state" => 'OH',
            "zipCode" => '43123',
            "country" => 'USA',
            "email" => 'testingtester@2co.com',
            "phoneNumber" => '555-555-5555'
        ),
        "shippingAddr" => array(
            "name" => 'Testing Tester',
            "addrLine1" => '123 Test St',
            "city" => 'Columbus',
            "state" => 'OH',
            "zipCode" => '43123',
            "country" => 'USA',
            "email" => 'testingtester@2co.com',
            "phoneNumber" => '555-555-5555'
        )
    ), 'array');
    if ($charge['response']['responseCode'] == 'APPROVED') {
        echo "Thanks for your Order!";
    }
} catch (Twocheckout_Error $e) {
    $e->getMessage();
}

我从他们提供的链接下载了 Twocheckout.php

现在问题是 它假设如果页面上有任何错误,它会给我“未经授权的”#。 因此,如果没有错误,一切正常,它应该给我授权#39; 发生的事情是我去了test3.php&#39;并停在那里没有任何错误或注意只是白页,当尝试刷新它给出重新发送&#39;

任何帮助请问如何做到这一点? 我的错误是什么? 我假设当我提交此信息时,我应该看到有人在我的演示页面中发布了新订单&#34;沙盒帐户&#34;

4 个答案:

答案 0 :(得分:2)

请检查https://www.2checkout.com/checkout/api/2co.min.js是否已完全加载,然后才需要致电

TCO.loadPubKey('sandbox', function() {
            // Execute when Public Key is available
});​

使用此代码

$.getScript('https://www.2checkout.com/checkout/api/2co.min.js', function() {
                    try {
                            // Pull in the public encryption key for our environment
                            TCO.loadPubKey('sandbox');
                        } catch(e) {
                            alert(e.toSource());
                        }
                });

答案 1 :(得分:1)

在test3.php服务器端,您需要更改&#39;令牌&#39;的值。在try块中。

'token' => 'Y2U2OTdlZjMtOGQzMi00MDdkLWJjNGQtMGJhN2IyOTdlN2Ni', //wrong value.

将其更改为

'token' => $_POST['token'], //correct value.

希望有所帮助。

答案 2 :(得分:1)

我已经(很难)了解到您需要&#34;沙盒&#34; 帐户才能成功运行此示例代码。

答案 3 :(得分:0)

documentation

我遇到了同样的问题,最后我得到了解决方案... 每当我在代码中放入“沙盒”时,我都会在存入我的真实帐户的凭据... 因此,如果您使用的是沙箱,请确保您的2checkout帐户是沙箱... 请检查所附的屏幕截图。