gpt4 book ai didi

javascript - Stripe 表单返回丢失的参数

转载 作者:行者123 更新时间:2023-12-03 06:01:20 24 4
gpt4 key购买 nike

我的 Stripe 代码不会生成发送到服务器端代码来向用户收费的 token ,而是返回:

Missing required param: number.

我已经阅读了无数次我的代码,阅读了 Stripe 文档等。控制台中返回的唯一错误是 Stripe 的 400 请求错误,因为“缺少参数”,即使它存在并使用 data- Stripe 。

表单片段:

<input type="text" data-stripe="number" class="form-control" placeholder="Card Number">

JavaScript 代码:

<script type="text/javascript" src="https://js.stripe.com/v2/">  </script>
<script type="text/javascript">
Stripe.setPublishableKey('pk_test_6G4sPCuttf9bYhMhs0xM3JEo');
</script>

<script type="text/javascript">
$(function() {
var $form = $('#payment-form');
$form.submit(function(event) {
// Disable the submit button to prevent repeated clicks:
$form.find('.submit').prop('disabled', true);

// Request a token from Stripe:
Stripe.card.createToken($form, stripeResponseHandler);

// Prevent the form from being submitted:
return false;
});
});

function stripeResponseHandler(status, response) {
// Grab the form:
var $form = $('#payment-form');

if (response.error) { // Problem!

// Show the errors on the form:
$form.find('.payment-errors').text(response.error.message);
$form.find('.submit').prop('disabled', false); // Re-enable submission

} else { // Token was created!

// Get the token ID:
var token = response.id;

// Insert the token ID into the form so it gets submitted to the server:
$form.append($('<input type="hidden" name="stripeToken">').val(token));

// Submit the form:
$form.get(0).submit();
}
};

最佳答案

您不能仅根据卡号生成 token 。您还需要传递以下数据。

  1. 卡号
  2. cvc

  3. exp_month

  4. exp_year

您的表单应捕获用户的所有这些详细信息。

<form action="/your-charge-code" method="POST" id="payment-form">
<span class="payment-errors"></span>

<div class="form-row">
<label>
<span>Card Number</span>
<input type="text" size="20" data-stripe="number">
</label>
</div>

<div class="form-row">
<label>
<span>Expiration (MM/YY)</span>
<input type="text" size="2" data-stripe="exp_month">
</label>
<span> / </span>
<input type="text" size="2" data-stripe="exp_year">
</div>

<div class="form-row">
<label>
<span>CVC</span>
<input type="text" size="4" data-stripe="cvc">
</label>
</div>
<input type="submit" class="submit" value="Submit Payment">
</form>

关于javascript - Stripe 表单返回丢失的参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39739046/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com