可以使用没有支付信息的 Stripe JS 创建令牌
Possible to create Token with Stripe JS with no payment information
我有一个客户想要免费订阅 Stripe。目前,他们的应用程序设置为获取 CC 信息,因为他们的旧计划确实需要月费。
我想知道是否可以通过 Stripe JS 创建 Stripe 客户令牌而无需从用户那里获取任何类型的 CC info/bank 帐户等?
我尝试使用 jQuery 删除 CC 字段,但我不断收到 Stripe Invalid Request 错误,因为它找不到付款信息。
总而言之,当用户从下拉列表中选择 'free' 计划时,他们不应该看到 CC 字段,并且他们应该能够在没有任何 Stripe 验证的情况下继续浏览注册页面,同时还创建他们的客户令牌。
这可能吗?
相关文件
主机控制器#create
def create
@host = User.new(host_params)
if @host.valid?
customer = Stripe::Customer.create(
stripe_params.merge(email: host_params[:email], coupon: coupon)
)
@host.update(
stripe_customer_id: customer[:id],
subscription_plan: stripe_params[:plan]
)
sign_in(:user, @host)
redirect_to dashboard_path, notice: t('notices.hosts.created')
else
render :new
end
rescue Stripe::CardError, Stripe::InvalidRequestError => error
render :new, alert: error.message
end
条纹JS代码
$(document).on 'ready page:load', ->
$cardFields = $('#credit-card-fields')
$parentForm = $cardFields.parents('form')
$parentBtn = $('.js-payment-btn', $parentForm)
return unless $parentForm.length
$parentBtn.on 'click', (event) ->
event.preventDefault()
pub_key = $('meta[name=stripe-publishable-key]').attr('content')
$parentBtn.prop('disabled', true)
Stripe.setPublishableKey(pub_key)
Stripe.card.createToken $parentForm, (status, response) ->
if response.error
$parentForm.find('.payment-errors').text(response.error.message)
$parentBtn.prop('disabled', false)
else
token = response.id
S> $parentForm.append($('<input type="hidden" name="stripe[source]" />').val(token))
$parentForm.get(0).submit()
Stripe JS 表单
<script type="text/javascript" src="https://js.stripe.com/v2/" data-turbolinks-track="true"></script>
<div class="clearfix" id="credit-card-fields">
<span class="payment-errors"></span>
<div class="form-group">
<div class="input-group">
<span class="input-group-addon icon icon-credit-card"></span>
<input id="card-number" class="form-control input-cc" required placeholder="Card Number" type="text" size="16" maxlength=16 data-stripe="number" />
</div>
</div>
<div class="form-group side-by-side">
<div class="input-group">
<span class="input-group-addon icon icon-calendar"></span>
<input id="card-month" class="form-control input-exp" required placeholder="MM" type="text" size="2" maxlength="2" data-stripe="exp-month" />
<input id="card-year" class="form-control input-exp" required placeholder="YY" type="text" size="2" maxlength="2" data-stripe="exp-year" />
</div>
</div>
<div class="form-group side-by-side">
<div class="input-group">
<span class="input-group-addon icon icon-lock"></span>
<input id="card-cvc" class="form-control input-cvv" required placeholder="CVC" type="text" size="4" maxlength="4" data-stripe="cvc" />
</div>
</div>
</div>
创建没有任何卡详细信息的卡令牌是没有意义的,因此这是不可能的。正如您所提到的,如果您尝试创建一个没有所需参数(例如卡号或到期日期)的令牌,您会得到 invalid_request_error
返回。
如果您不想要求提供银行卡详细信息,那么您不应该创建令牌。当有人尝试订阅免费计划时,您无需创建令牌,只需收集您想要的其余信息,例如客户的电子邮件地址或姓名。然后在服务器端,您将调用 Create Customer API 并在 plan
参数中传递计划 ID 以订阅它们。
如果计划是免费的,则无需传递令牌,您可以完全忽略 source
参数。
我有一个客户想要免费订阅 Stripe。目前,他们的应用程序设置为获取 CC 信息,因为他们的旧计划确实需要月费。
我想知道是否可以通过 Stripe JS 创建 Stripe 客户令牌而无需从用户那里获取任何类型的 CC info/bank 帐户等?
我尝试使用 jQuery 删除 CC 字段,但我不断收到 Stripe Invalid Request 错误,因为它找不到付款信息。
总而言之,当用户从下拉列表中选择 'free' 计划时,他们不应该看到 CC 字段,并且他们应该能够在没有任何 Stripe 验证的情况下继续浏览注册页面,同时还创建他们的客户令牌。
这可能吗?
相关文件
主机控制器#create
def create
@host = User.new(host_params)
if @host.valid?
customer = Stripe::Customer.create(
stripe_params.merge(email: host_params[:email], coupon: coupon)
)
@host.update(
stripe_customer_id: customer[:id],
subscription_plan: stripe_params[:plan]
)
sign_in(:user, @host)
redirect_to dashboard_path, notice: t('notices.hosts.created')
else
render :new
end
rescue Stripe::CardError, Stripe::InvalidRequestError => error
render :new, alert: error.message
end
条纹JS代码
$(document).on 'ready page:load', ->
$cardFields = $('#credit-card-fields')
$parentForm = $cardFields.parents('form')
$parentBtn = $('.js-payment-btn', $parentForm)
return unless $parentForm.length
$parentBtn.on 'click', (event) ->
event.preventDefault()
pub_key = $('meta[name=stripe-publishable-key]').attr('content')
$parentBtn.prop('disabled', true)
Stripe.setPublishableKey(pub_key)
Stripe.card.createToken $parentForm, (status, response) ->
if response.error
$parentForm.find('.payment-errors').text(response.error.message)
$parentBtn.prop('disabled', false)
else
token = response.id
S> $parentForm.append($('<input type="hidden" name="stripe[source]" />').val(token))
$parentForm.get(0).submit()
Stripe JS 表单
<script type="text/javascript" src="https://js.stripe.com/v2/" data-turbolinks-track="true"></script>
<div class="clearfix" id="credit-card-fields">
<span class="payment-errors"></span>
<div class="form-group">
<div class="input-group">
<span class="input-group-addon icon icon-credit-card"></span>
<input id="card-number" class="form-control input-cc" required placeholder="Card Number" type="text" size="16" maxlength=16 data-stripe="number" />
</div>
</div>
<div class="form-group side-by-side">
<div class="input-group">
<span class="input-group-addon icon icon-calendar"></span>
<input id="card-month" class="form-control input-exp" required placeholder="MM" type="text" size="2" maxlength="2" data-stripe="exp-month" />
<input id="card-year" class="form-control input-exp" required placeholder="YY" type="text" size="2" maxlength="2" data-stripe="exp-year" />
</div>
</div>
<div class="form-group side-by-side">
<div class="input-group">
<span class="input-group-addon icon icon-lock"></span>
<input id="card-cvc" class="form-control input-cvv" required placeholder="CVC" type="text" size="4" maxlength="4" data-stripe="cvc" />
</div>
</div>
</div>
创建没有任何卡详细信息的卡令牌是没有意义的,因此这是不可能的。正如您所提到的,如果您尝试创建一个没有所需参数(例如卡号或到期日期)的令牌,您会得到 invalid_request_error
返回。
如果您不想要求提供银行卡详细信息,那么您不应该创建令牌。当有人尝试订阅免费计划时,您无需创建令牌,只需收集您想要的其余信息,例如客户的电子邮件地址或姓名。然后在服务器端,您将调用 Create Customer API 并在 plan
参数中传递计划 ID 以订阅它们。
如果计划是免费的,则无需传递令牌,您可以完全忽略 source
参数。