Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/475.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 由于某些原因,此付款表格未提交_Javascript_Php_Jquery_Paymill - Fatal编程技术网

Javascript 由于某些原因,此付款表格未提交

Javascript 由于某些原因,此付款表格未提交,javascript,php,jquery,paymill,Javascript,Php,Jquery,Paymill,我正在使用Paymill接受付款,由于某种原因,当我输入我的live API密钥时,此表单停止提交。我输入了一些有效的实时卡详细信息,该按钮被禁用约5秒钟,然后该按钮再次激活,而不是将信息发布到我的支付脚本中。也没有出现错误 代码如下: <form id="payment-form" action="transaction.php" method="POST"> <input type="hidden" name="app_id" value="<? echo

我正在使用Paymill接受付款,由于某种原因,当我输入我的live API密钥时,此表单停止提交。我输入了一些有效的实时卡详细信息,该按钮被禁用约5秒钟,然后该按钮再次激活,而不是将信息发布到我的支付脚本中。也没有出现错误

代码如下:

<form id="payment-form" action="transaction.php" method="POST">

    <input type="hidden" name="app_id" value="<? echo $app_id; ?>">
    <input type="hidden" name="email" value="<? echo $row['email']; ?>">
    <input type="hidden" name="first_name" value="<? echo $row['first_name']; ?>">
    <input type="hidden" name="surname" value="<? echo $row['surname']; ?>">
    <input class="card-amount-int" type="hidden" value="100" id="card-amount-int" />
    <input class="card-currency" type="hidden" value="GBP" id="card-currency"/>
    <div class="form-row">
        <input class="card-holdername" type="hidden" size="4" id="card-holdername" value="<? echo $row['surname']; ?>" />
    </div>


    <p>
        <label>Card number:</label>
        <input class="card-number form-control" type="text" size="25" id="card-number"/>
    </p>



    <br>

    <p>
        <label>Expiration Date:</label>
        <select id="card-expiry-month"   class="card-expiry-month">
            <option value="01">January</option>
            <option value="02">February</option>
            <option value="03">March</option>
            <option value="04">April</option>
            <option value="05">May</option>
            <option value="06">June</option>
            <option value="07">July</option>
            <option value="08">August</option>
            <option value="09">September</option>
            <option value="10">October</option>
            <option value="11">November</option>
            <option value="12">December</option>
        </select>
        <select id="card-expiry-year"  class="card-expiry-year">
            <option value="2015" selected="selected">2015</option><option value="2016">2016</option>
            <option value="2017">2017</option><option value="2018">2018</option>
            <option value="2019">2019</option><option value="2020">2020</option>
            <option value="2021">2021</option><option value="2022">2022</option>
            <option value="2023">2023</option><option value="2024">2024</option>
            <option value="2025">2025</option><option value="2026">2026</option>
            <option value="2027">2027</option><option value="2028">2028</option>
            <option value="2029">2029</option><option value="2030">2030</option>
            <option value="2031">2031</option><option value="2032">2032</option>
            <option value="2033">2033</option><option value="2034">2034</option>                        
        </select>
    </p>

    <br>
    <p>
        <label>Security Code (CVC):</label>
        <input class="card-cvc" type="text" size="4" id="card-cvc"/>
    </p>
    <br>
    <button class="submit-button btn btn-lg btn-success" type="submit" >Submit Payment</button>

</form>
<br><br>
</div>
<script type="text/javascript" src="https://bridge.paymill.com/"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>


<script type="text/javascript">
    var PAYMILL_PUBLIC_KEY = '****';

    jQuery(function ($) {
        $('#payment-form').submit(function (event) {
            var $form = $(this);

            // Disable the submit button to prevent repeated clicks
            $form.find('button').prop('disabled', true);

            paymill.createToken({
                number: $('.card-number').val(), // required, ohne Leerzeichen und Bindestriche
                exp_month: $('.card-expiry-month').val(), // required
                exp_year: $('.card-expiry-year').val(), // required, vierstellig z.B. "2016"
                cvc: $('.card-cvc').val(), // required
                amount_int: $('.card-amount-int').val(), // required, integer, z.B. "15" für 0,15 Euro
                currency: $('.card-currency').val(), // required, ISO 4217 z.B. "EUR" od. "GBP"
                cardholder: $('.card-holdername').val() // optional
            }, PaymillResponseHandler);
// Prevent the form from submitting with the default action
            return false;
        });
    });


    function PaymillResponseHandler(error, result) {
        var $form = $('#payment-form');

        if (error) {
// Show the errors on the form
            $(".payment-errors").text(error.apierror);
            $(".submit-button").removeAttr("disabled");
        } else {
// response contains id and card, which contains additional card details
            var token = result.token;
// Insert the token into the form so it gets submitted to the server
            $form.append($('<input type="hidden" name="paymillToken" />').val(token));
// and submit
            $form.get(0).submit();
        }
    }
    ;
</script>

所以在“没有错误”的情况下,我假设您说控制台中没有错误。就我所见,代码本身是正常的,但我认为活动密钥的身份验证失败(就测试密钥成功运行而言)


当发布到API时,会有一个代码为200的有效响应(从HTTP视图),但身份验证仍然失败(已经用于标记化/网桥中)。请检查网络响应中的响应。如果您看到类似{“code:”80,“message:”User Authentication Error“}的消息,您知道问题所在。然后请确保您的密钥有效(例如通过cUrl进行测试)。

1)控制台错误?2)如果您有`$('#支付表单')。提交(函数(事件){`然后调用submit,您需要像这样添加peventDefault:
$(“#支付表单”).submit(函数(事件){event.preventDefault();
是。在curl中,我收到了以下错误:{“错误”:“拒绝访问”,“异常”:“无效身份验证”}。我想我的API密钥一定出了问题。