繁体   English   中英

使用Node JS进行条带化支付

[英]Stripe payment with node js

我的堆栈:前端:react, react-stripe模块后端:带有Express 4.x的nodejs

我一直在关注https://stripe.com/docs/charges上的示例

这是我的前端代码,它在用户单击“付款”后触发:

  onToken(token){
    console.log("Token " , token);
    $.post('/apicall', token, function(result){
      console.log(result);
    })
  }

这是我的服务器代码,它接收数据并应处理测试付款:

router.post('/payment/barf-complete', function(req, response, next){
  console.log(req.body);
  var stripeToken = req.body;

  var charge = stripe.charges.create({
    amount: 1990, // amount in cents, again
    currency: "eur",
    source: stripeToken,
    description: "Example charge"
    }, function(err, charge) {
    if (err && err.type === 'StripeCardError') {
      // The card has been declined
      console.log(err);
    }
  });
});

我不得不更改var stripeToken = request.body.stripeToken; 进入var stripeToken = request.body; 因为第一个变量声明一直未定义。

现在的问题是,在前端完成付款后,我一直在服务器上收到以下错误消息:

rawType: 'card_error',
code: 'invalid_number',
param: 'number',
message: 'The card object must have a value for \'number\'.',

我以前从未使用过付款系统,并且文档没有为我提供任何有用的信息-:/

有什么想法可能会错过吗?

编辑这是request.body的console.log:

{ id: 'tok_123456789',
  object: 'token',
  'card[id]': 'card_123456789',
  'card[object]': 'card',
  'card[address_city]': '',
  'card[address_country]': '',
  'card[address_line1]': '',
  'card[address_line1_check]': '',
  'card[address_line2]': '',
  'card[address_state]': '',
  'card[address_zip]': '',
  'card[address_zip_check]': '',
  'card[brand]': 'Visa',
  'card[country]': 'US',
  'card[cvc_check]': 'pass',
  'card[dynamic_last4]': '',
  'card[exp_month]': '1',
  'card[exp_year]': '2017',
  'card[funding]': 'credit',
  'card[last4]': '4242',
  'card[name]': 'noa@mail.com',
  'card[tokenization_method]': '',
  client_ip: '12334567',
  created: '1457075159',
  email: 'noa@mail.com',
  livemode: 'false',
  type: 'card',
  used: 'false' }

req.body是整个令牌对象,但是Stripe只需要令牌对象的id ,因此将source设置为req.body.id应该可以解决它。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM