我已经集成了jmspaymentbundle,paypal每件事都很好!当我试图通过此链接从JMS进行更改时并使用GitHub的Ruudk/PaymentsTripeBundle,实际上是相同的。
但是有一件事。我正在收到此错误:源参数是必需的
在捆绑包的问题中,我发现我必须使用条纹表格
<form action=""
method="POST">
<script
src="https://checkout.stripe.com/checkout.js" class="stripe-button"
data-key="MYPUBLISHEDKEY"
data-amount="999"
data-name="Demo Site"
data-description="Widget"
data-image="https://stripe.com/img/documentation/checkout/marketplace.png"
data-locale="auto">
</script>
</form>
此表单生成一个令牌。我需要知道的是:
1-将JMSpaymentBundle使用的名字发布的何处?
2-我应该采取什么行动?贝宝(Paypal)是否相同?
很难说这里发生了什么,但似乎https://github.com/ruudk/paymentstripebundle/缺少一些必要的文档。
我可以告诉它是在您的表格中添加token
隐藏字段:https://github.com/ruudk/paymentstripebundle/blob/master/src/src/form/checkouttype.php#l12
但是,您使用的结帐嵌入代码不会将令牌保存到该字段。我看不到此库中嵌入任何其他JavaScript,因此您需要使用自定义条纹结帐集成来构建自己的javascript:
https://stripe.com/docs/checkout#integration-custom
类似的东西应该有效:
var handler = StripeCheckout.configure({
key: 'pk_test_6pRNASCoBOKtIshFeQd4XMUh',
image: 'https://stripe.com/img/documentation/checkout/marketplace.png',
locale: 'auto',
token: function(token) {
// NOTE: assuming that the field injected by the library has an ID of "token"--you'll have to check your DOM and possibly adjust this
var field = document.getElementById('token');
field.value = token.id;
// TODO: submit form and send to your backend
}
});
document.getElementById('customButton').addEventListener('click', function(e) {
// Open Checkout with further options:
handler.open({
name: 'Stripe.com',
description: '2 widgets',
zipCode: true,
amount: 2000
});
e.preventDefault();
});
// Close Checkout on page navigation:
window.addEventListener('popstate', function() {
handler.close();
});