Ruby on rails 条带API错误“;必须提供卡、客户或银行账户来创建代币。”;
我一直致力于将Stripe与我的应用程序集成。目前正在建立一个双边市场 即使我正在使用他们在文档/测试部分中提供的卡详细信息,也要继续获取上面列出的错误 尝试了一些修复,但似乎无法纠正问题 所有相关代码都附在下面,非常感谢您的帮助 我的订单.js.咖啡Ruby on rails 条带API错误“;必须提供卡、客户或银行账户来创建代币。”;,ruby-on-rails,stripe-payments,Ruby On Rails,Stripe Payments,我一直致力于将Stripe与我的应用程序集成。目前正在建立一个双边市场 即使我正在使用他们在文档/测试部分中提供的卡详细信息,也要继续获取上面列出的错误 尝试了一些修复,但似乎无法纠正问题 所有相关代码都附在下面,非常感谢您的帮助 我的订单.js.咖啡 jQuery -> Stripe.setPublishableKey($('meta[name="stripe-key"]').attr('content')) payment.setupForm() payment = setup
jQuery ->
Stripe.setPublishableKey($('meta[name="stripe-key"]').attr('content'))
payment.setupForm()
payment =
setupForm: ->
$('#new_order').submit ->
$('input[type=submit]').attr('disabled', true)
Stripe.card.createToken($('#new_order'), payment.handleStripeResponse)
false
handleStripeResponse: (status, response) ->
if status == 200
$('#new_order').append($('<input type="hidden" name="stripeToken" />').val(response.id))
$('#new_order')[0].submit()
else
$('#stripe_error').text(response.error.message).show()
$('input[type=submit]').attr('disabled', false)
jQuery->
Stripe.setPublishableKey($('meta[name=“Stripe key”]”)attr('content'))
付款方式
付款=
设置形式:->
$(“#新订单”)。提交->
$('input[type=submit]').attr('disabled',true)
Stripe.card.createToken($(“#新订单”),payment.handleStripeResponse)
假的
HandleStripereResponse:(状态、响应)->
如果状态==200
$('#新订单')。追加($('.val(response.id))
$('new_order')[0]。提交()
其他的
$('#stripe_error').text(response.error.message).show()
$('input[type=submit]').attr('disabled',false)
my\u form.html.erb
<div class="row">
<div class="col-md-6">
<div class="thumbnail">
<%= image_tag @listing.image.url %>
</div>
<h3><%= @listing.name %></h3>
<h4><%= number_to_currency(@listing.price) %></h4>
</div>
<div class="row">
<div class="col-md-5">
<%= form_for([@listing, @order]) do |f| %>
<% if @order.errors.any? %>
<div id="error_explanation" class="alert alert-danger alert-dismissable">
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">× </button>
<h4><%= pluralize(@order.errors.count, "error") %> prohibited this order from being saved:</h4>
<ul>
<% @order.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<div id="stripe_error" class="alert alert-danger" style="display:none">
<noscript>JavaScript is not enabled and is required for this form. First enable it in your web browser settings.</noscript>
</div>
<div class="form-group">
<%= f.label :email %><br>
<%= f.text_field :email, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :name %><br>
<%= f.text_field :name, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :address %><br>
<%= f.text_field :address, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :city %><br>
<%= f.text_field :city, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :county %><br>
<%= f.text_field :county, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :post_code %><br>
<%= f.text_field :post_code, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :phone %><br>
<%= f.text_field :phone, class: "form-control" %>
</div>
</div>
class OrdersController < ApplicationController
before_action :set_order, only: [:show, :edit, :update, :destroy]
before_action :authenticate_user!
# GET /orders
# GET /orders.json
def sales
@orders = Order.all.where(seller: current_user).order("created_at DESC")
end
def purchases
@orders = Order.all.where(buyer: current_user).order("created_at DESC")
end
# GET /orders/new
def new
@order = Order.new
@listing = Listing.find(params[:listing_id])
end
# POST /orders
# POST /orders.json
def create
@order = Order.new(order_params)
@listing = Listing.find(params[:listing_id])
@seller = @listing.user
@order.listing_id = @listing.id
@order.buyer_id = current_user.id
@order.seller_id = @seller.id
Stripe.api_key = ENV["STRIPE_API_KEY"]
token = params[:stripeToken]
begin
charge = Stripe::Charge.create(
:amount => (@listing.price * 100).floor,
:currency => "gbp",
:card => token
)
flash[:notice] = "Thanks for ordering!"
rescue Stripe::CardError => e
flash[:danger] = e.message
end
respond_to do |format|
if @order.save
format.html { redirect_to root_url }
format.json { render action: 'show', status: :created, location: @order }
else
format.html { render action: 'new' }
format.json { render json: @order.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /orders/1
# PATCH/PUT /orders/1.json
private
# Use callbacks to share common setup or constraints between actions.
def set_order
@order = Order.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def order_params
params.require(:order).permit(:email, :name, :address, :city, :county, :post_code, :phone)
end
end
&时代;
禁止保存此订单:
未启用JavaScript,此表单需要JavaScript。首先在web浏览器设置中启用它。
nil,:'data-stripe'=>“number”,类:“表单控件”}%>
nil,:'data-stripe'=>“cvc”,类:“表单控制”}%>
nil,:'data-stripe'=>“exp-month”,类:“表单控件”}%>
nil,:'data-stripe'=>“exp year”,类:“表单控制”}%>
最后,我的命令\u controller.rb
<div class="row">
<div class="col-md-6">
<div class="thumbnail">
<%= image_tag @listing.image.url %>
</div>
<h3><%= @listing.name %></h3>
<h4><%= number_to_currency(@listing.price) %></h4>
</div>
<div class="row">
<div class="col-md-5">
<%= form_for([@listing, @order]) do |f| %>
<% if @order.errors.any? %>
<div id="error_explanation" class="alert alert-danger alert-dismissable">
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">× </button>
<h4><%= pluralize(@order.errors.count, "error") %> prohibited this order from being saved:</h4>
<ul>
<% @order.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<div id="stripe_error" class="alert alert-danger" style="display:none">
<noscript>JavaScript is not enabled and is required for this form. First enable it in your web browser settings.</noscript>
</div>
<div class="form-group">
<%= f.label :email %><br>
<%= f.text_field :email, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :name %><br>
<%= f.text_field :name, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :address %><br>
<%= f.text_field :address, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :city %><br>
<%= f.text_field :city, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :county %><br>
<%= f.text_field :county, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :post_code %><br>
<%= f.text_field :post_code, class: "form-control" %>
</div>
<div class="form-group">
<%= f.label :phone %><br>
<%= f.text_field :phone, class: "form-control" %>
</div>
</div>
class OrdersController < ApplicationController
before_action :set_order, only: [:show, :edit, :update, :destroy]
before_action :authenticate_user!
# GET /orders
# GET /orders.json
def sales
@orders = Order.all.where(seller: current_user).order("created_at DESC")
end
def purchases
@orders = Order.all.where(buyer: current_user).order("created_at DESC")
end
# GET /orders/new
def new
@order = Order.new
@listing = Listing.find(params[:listing_id])
end
# POST /orders
# POST /orders.json
def create
@order = Order.new(order_params)
@listing = Listing.find(params[:listing_id])
@seller = @listing.user
@order.listing_id = @listing.id
@order.buyer_id = current_user.id
@order.seller_id = @seller.id
Stripe.api_key = ENV["STRIPE_API_KEY"]
token = params[:stripeToken]
begin
charge = Stripe::Charge.create(
:amount => (@listing.price * 100).floor,
:currency => "gbp",
:card => token
)
flash[:notice] = "Thanks for ordering!"
rescue Stripe::CardError => e
flash[:danger] = e.message
end
respond_to do |format|
if @order.save
format.html { redirect_to root_url }
format.json { render action: 'show', status: :created, location: @order }
else
format.html { render action: 'new' }
format.json { render json: @order.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /orders/1
# PATCH/PUT /orders/1.json
private
# Use callbacks to share common setup or constraints between actions.
def set_order
@order = Order.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def order_params
params.require(:order).permit(:email, :name, :address, :city, :county, :post_code, :phone)
end
end
class OrdersController(@listing.price*100)。地板,
:货币=>“英镑”,
:卡=>令牌
)
flash[:notice]=“感谢订购!”
救援条带::CardError=>e
闪光[:危险]=e.信息
结束
回应待办事项|格式|
如果@order.save
format.html{redirect_to root_url}
format.json{呈现操作:“显示”,状态::已创建,位置:@order}
其他的
format.html{呈现操作:'new'}
format.json{render json:@order.errors,status::unprocessable_entity}
结束
结束
结束
#补丁/PUT/orders/1
#PATCH/PUT/orders/1.json
私有的
#使用回调在操作之间共享公共设置或约束。
def设置顺序
@order=order.find(参数[:id])
结束
#永远不要相信来自恐怖网络的参数,只允许白名单通过。
def order_参数
参数要求(:订单)。许可(:电子邮件,:姓名,:地址,:城市,:县,:邮政编码,:电话)
结束
结束
此处发布的内容是否与代码中的内容匹配?如果是这样,请记住CoffeeScript使用了大量空白。正如您发布的那样,Stripe.js没有付款。handleStripeResponse
函数用于回调Stripe.js(因此在您的表单中没有stripeToken
参数)。您的#新订单
表单声明在哪里?@Dhaulagiri在部分表单中form_for
根据控制器操作生成id。OrdersController#new将构建id为new_order
的表单。感谢您的评论。我误诊了错误,实际上是因为没有收到令牌。一旦我知道了这一点,我就能够追踪错误。如果你能分享你是如何修复错误的,这将是很有帮助的,因为我现在面临着同样的问题。