首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >条带连接支付令牌生成令牌未完成测试模式的交易

条带连接支付令牌生成令牌未完成测试模式的交易
EN

Stack Overflow用户
提问于 2018-05-23 17:28:26
回答 1查看 170关注 0票数 1

我正在使用条带连接支付网关,我想发送自定义值到结帐表单,我已经使用了js元素条带与支付button.In条带连接仪表板,它显示v1/令牌和测试没有显示付款mode.How我可以调用与此js元素生活以及生活模式收费方法。

代码语言:javascript
复制
<script src="https://js.stripe.com/v3/"></script>
<form>
<div class="form-group">
    <h2 class="heading">Schedule Course</h2>

    <label for="name">Tutor Name: </label>
    <input type="text" name="selectedTutor" value="<?php echo $tutorName;?>" required>
   <label for="phone">Subject</label>
    <input type="text" name="slectedSubject" value="<?php echo get_user_meta($userId, 'userinfo' , true );?>" id="selectedSubject" required>
   <label for="email">Booking Dates</label>
    <input type="text" name="slectedDates" value="" id="selectedAppointment" required>
<label for="email">Price</label>
    <input type="text" name="slectedDates" value="<?php echo get_user_meta( $userId, 'price_individualcourse' , true);?>" id="selectedAppointment" required>
<label>
    <input name="cardholder-name" class="field is-empty" placeholder="Jane Doe" />
    <span><span>Name</span></span>
  </label>

  <label>
    <div id="card-element" class="field is-empty"></div>
    <span><span>Credit or debit card</span></span>
  </label>
  <button type="submit">Pay <?php echo get_user_meta( $userId, 'price_individualcourse' , true);?></button>
  <div class="outcome">
    <div class="error" role="alert"></div>
    <div class="success">
      Success! Your Stripe token is <span class="token"></span>
    </div>
  </div>
</form>
<script>
var stripe = Stripe('pk_test_uFOdE1YPIXhbssFt1FwH9RGQ');
var elements = stripe.elements();
var card = elements.create('card', {
  iconStyle: 'solid',
  style: {
    base: {
      iconColor: '#8898AA',
      color: 'black',
      lineHeight: '36px',
      fontWeight: 300,
      fontFamily: '"Helvetica Neue", Helvetica, sans-serif',
      fontSize: '19px',

      '::placeholder': {
        color: '#8898AA',
      },
    },
    invalid: {
      iconColor: '#e85746',
      color: '#e85746',
    }
  },
  classes: {
    focus: 'is-focused',
    empty: 'is-empty',
  },
});
card.mount('#card-element');

var inputs = document.querySelectorAll('input.field');
Array.prototype.forEach.call(inputs, function(input) {
  input.addEventListener('focus', function() {
    input.classList.add('is-focused');
  });
  input.addEventListener('blur', function() {
    input.classList.remove('is-focused');
  });
  input.addEventListener('keyup', function() {
    if (input.value.length === 0) {
      input.classList.add('is-empty');
    } else {
      input.classList.remove('is-empty');
    }
  });
});

function setOutcome(result) {
  var successElement = document.querySelector('.success');
  var errorElement = document.querySelector('.error');
  successElement.classList.remove('visible');
  errorElement.classList.remove('visible');

  if (result.token) {

    successElement.querySelector('.token').textContent = result.token.id;
    successElement.classList.add('visible');
  } else if (result.error) {
    errorElement.textContent = result.error.message;
    errorElement.classList.add('visible');
  }
}

card.on('change', function(event) {
  setOutcome(event);
});

document.querySelector('form').addEventListener('submit', function(e) {
  e.preventDefault();
  var form = document.querySelector('form');
  var extraDetails = {
    name: form.querySelector('input[name=cardholder-name]').value,
  };
  stripe.createToken(card, extraDetails).then(setOutcome);
});
 </script>
EN

回答 1

Stack Overflow用户

发布于 2018-05-23 19:48:22

条带元素只收集支付信息并向您返回令牌,它不向卡收费。您需要将令牌从您的setOutcome函数内部传递到后端PHP脚本,并调用那里的条带API来创建费用。

你可以看一下与Checkout:https://stripe.com/docs/checkout/php进行端到端PHP集成的条纹文档,它将为你指明正确的方向,告诉你如何将你的支付表单数据传回服务器。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50484688

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档