我的设置是:
我尝试添加一个可以正常使用的新客户as showed in the tutorial。但是当我尝试使用JavaScript SDK中的给定代码从前端添加付款方式时。我使用Drop-In-UI生成付款方式Nonce ,这是我的问题的一部分。
我使用Sandbox凭据配置了PHP后端,并粘贴了文档中给出的示例代码。
当我尝试创建用户时,一切都很好:
$result = Braintree_Customer::create(array(
'id' => Auth::id(),
'firstName' => 'Mike',
'lastName' => 'Jones',
'company' => 'Jones Co.',
'email' => 'mike.jones@example.com',
'phone' => '281.330.8004',
'fax' => '419.555.1235',
'website' => 'http://example.com'
));
付款时,一旦无效,
$result = Braintree_Transaction::sale(array(
'amount' => '10.00',
'paymentMethodNonce' => Input::get('payment_method_nonce'),
'customer' => array(
'id' => Auth::id()
),
'options' => array(
'storeInVaultOnSuccess' => true,
)
));
服务器一直说93108: Unknown paymentMethodNonce
。这似乎有点混乱和奇怪,因为Input::get('payment_method_nonce')
代表一个有效的字符串。
答案 0 :(得分:5)
经过漫长的一天对文献进行深入研究后,我终于找到了问题。
您需要将PHP库生成的Client Token(不是Sandbox中的CSE令牌!)传递到Braintree提供的JavaScript代码段中:
braintree.setup(
"{{ Braintree_ClientToken::generate(['customerId' => Auth::id()]) }}",
'dropin', {
container: 'dropin'
}
);
Drop-In-UI代码是来自文档的复制+粘贴。
<form id="checkout" method="post" action="/checkout">
{!! csrf_field() !!}
<div id="dropin"></div>
<input type="submit" value="Pay $10">
</form>
希望有人通过提供这个答案节省了大量时间。
修改强>
在Laravel 5中,您需要手动添加csrf-field(我已经更新了代码),否则您将从Laravel获得TokenMismatchException
。