javascript - 需要指导尝试使用 Node js 设置带有 strip 的可变数量

标签 javascript node.js stripe-payments

我是 node 和 javascript 的新手,所以请原谅。这就是我现在拥有的,只是从 Stripe 文档中复制的。我很困惑我应该用评论的 token 功能做什么。我使用的是简单的 Stripe 配置,并且一切正常,但我决定允许用户通过输入字段设置自定义金额。任何能引导我朝那个方向发展的帮助都会很棒。

<script src="https://checkout.stripe.com/checkout.js"></script>

<button id="customButton">Purchase</button>

<script>
var handler = StripeCheckout.configure({
  key: 'pk_test_...',
  image: 'https://stripe.com/img/documentation/checkout/marketplace.png',
  locale: 'auto',
  token: function(token) {
    // You can access the token ID with `token.id`.
    // Get the token ID to your server-side code for use.
  }
});

document.getElementById('customButton').addEventListener('click', function(e) {
  // Open Checkout with further options:
  handler.open({
    name: 'Demo Site',
    description: '2 widgets',
    amount: 2000
  });
  e.preventDefault();
});

// Close Checkout on page navigation:
window.addEventListener('popstate', function() {
  handler.close();
});
</script>

这是我的服务器端代码 (stripe.js):

var express = require('express');
var router = express.Router();
var stripe = require('stripe')('sk_test_...');

router.post('/charge', function(req, res, next) {
    var token = req.body.stripeToken;
    var chargeAmount = req.body.chargeAmount;
    var charge = stripe.charges.create({
      amount: 2000,
      currency: "usd",
      source: token
    }, function(err, charge) {
      if(err) {
        return console.log(err);
      }
      console.log(req.body);
      res.redirect('/users/dashboard');
    });
});

module.exports = router;

最佳答案

Checkout不会将金额和货币发送到后端服务器 -- 它仅使用 amountcurrency 参数进行显示。

这是设计使然。除了金额应由付费客户明确设置的情况(例如,如果您正在接受捐赠),您不能相信客户浏览器发送的金额,因为它很容易修改。

但在这种情况下,听起来您确实希望客户设置金额。所以你需要这样做:

  1. 在您的客户端(前端)代码中,确保金额与 Checkout 返回的 token 一起发送。

    这是一个简单的表单示例,其中金额由客户设置:https://jsfiddle.net/ywain/g2ufa8xr/ .在此表单中,金额将作为 amount POST 参数以及 Checkout 返回的 stripeTokenstripeEmail 参数发送。

  2. 在您的服务器端(后端)代码中,使用 charge creation request 中的金额.

    这很简单,只需检索参数并将其用作费用创建请求的amount 参数的值:

    var token = req.body.stripeToken;
    var amount = req.body.amount;
    var charge = stripe.charges.create({
      amount: amount,
      currency: "usd",
      source: token
    }, function(err, charge) {
        ...
    }
    

作为旁注,请永远不要公开分享您的 secret API key ,即使它只是一个测试 key 。您应该尽快推出新 key 。您可以前往仪表板执行此操作:https://dashboard.stripe.com/account/apikeys然后单击要替换的 key 旁边的“回收”图标。

关于javascript - 需要指导尝试使用 Node js 设置带有 strip 的可变数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43972362/

相关文章:

javascript - 将 VueJS 组件渲染到 Google Map Infowindow

javascript - 使用 string.prototype 每 8 个逗号后创建一个新行

javascript - 如何更改 stripe.js 中的响应(错误/成功)语言

node.js - Swift 错误读取 Cloud Code 错误

stripe-payments - Stripe 重定向 URI - url 中的动态数字

javascript - 无法解析主机 github.com

javascript - 回到 iframe 的历史记录,但更改主窗口的地址

当我将 Javascript 数组推送到另一个数组时,它会更改值

javascript - 当调用 'this' 的函数位于子对象的对象内部时,您将如何引用 'this'?

node.js - 使用 React 构建网站并使用 firebase 作为数据库,我还需要后端吗? (例如 : Nodejs)