これは私が生成している応答です:
Processing by OrdersController#create as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"C/1Fmc4iEAiRGXwTcQNcDdX3j81KyhMHnfNcuYC/p1Y=", "order"=>{"video_id"=>"99", "member_id"=>"36", "price"=>"1000", "stripe_card_token"=>"tok_2mYQqbzBgt1EYy"}}
Completed 404 Not Found in 22ms
ActionController::RoutingError - No route matches {:action=>"show", :controller=>"orders", :id=>#<Order id: nil, video_id: 99, member_id: 36, stripe_card_token: nil, price: 1000, created_at: nil, updated_at: nil>}:
基本的に、新しい注文が作成されると、すべての正しい属性が生成されますが、何らかの理由で、stripe_card_token がパラメーターに渡されません。
これは私の注文モデルです:
attr_accessible :price, :stripe_card_token, :member_id, :video_id
belongs_to :video
belongs_to :member
accepts_nested_attributes_for :video
accepts_nested_attributes_for :member
validates :member_id, presence: true
validates :video_id, presence: true
validates :price, presence: true
attr_accessor :stripe_card_token
def save_with_stripe
if valid?
@charge = Stripe::Charge.create(
amount: price,
currency: "gbp",
card: stripe_card_token,
description: "something"
)
save!
end
rescue
errors.add :base, "There was a problem with Stripe"
end
これは私の注文コントローラーです:
def new
@order = Order.new(:member_id => @member.id, :video_id => @video.id, :price => @video.price)
end
def create
@order = Order.new(params[:order])
if @order.save_with_stripe
flash[:success] = "Enjoy the video!"
redirect_to order_path(@order)
else
render partial: 'orders/buynow'
end
end
def show
@order = Order.find(params[:id])
end
そして私のフォーム:
<%= form_for @order do |f| %>
<% if @order.errors.any? %>
<div class="error_messages">
<h2><%= pluralize(@order.errors.count, "error") %> stopped your card from being charged:</h2>
<ul>
<% @order.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<%= f.hidden_field :video_id %>
<%= f.hidden_field :member_id %>
<%= f.hidden_field :price %>
<%= f.hidden_field :stripe_card_token %>
<% if current_user.stripe_customer_token.present? %>
Credit card has been provided.
<% else %>
<div class="field">
<%= label_tag :name, "Name on card" %>
<%= text_field_tag :name, nil, name: nil %>
</div>
<div class="field">
<%= label_tag :card_number, "Credit Card Number" %>
<%= text_field_tag :card_number, nil, name: nil %>
</div>
<div class="field">
<%= label_tag :card_code, "Security Code on Card (CVV)" %>
<%= text_field_tag :card_code, nil, name: nil %>
</div>
<div class="field">
<%= label_tag :card_month, "Card Expiration" %>
<%= select_month nil, {add_month_numbers: true}, {name: nil, id: "card_month"} %>
<%= select_year nil, {start_year: Date.today.year, end_year: Date.today.year+15}, {name: nil, id: "card_year"} %>
</div>
<% end %>
<div id="stripe_error">
<noscript>JavaScript is not enabled and is required for this form. First enable it in your web browser settings.</noscript>
</div>
<div class="actions">
<%= f.submit "Buy Now" %>
</div>
<% end %>
そして私のコーヒースクリプト:
jQuery ->
Stripe.setPublishableKey($('meta[name="stripe-key"]').attr('content'))
order.setupForm()
order =
setupForm: ->
$('#new_order').submit ->
$('input[type=submit]').attr('disabled', true)
if $('#card_number').length
order.processCard()
false
else
true
processCard: ->
card =
number: $('#card_number').val()
cvc: $('#card_code').val()
expMonth: $('#card_month').val()
expYear: $('#card_year').val()
Stripe.createToken(card, order.handleStripeResponse)
handleStripeResponse: (status, response) ->
if status == 200
$('#order_stripe_card_token').val(response.id)
$('#new_order')[0].submit()
else
$('#stripe_error').text(response.error.message)
$('input[type=submit]').attr('disabled', false)
私が間違っていることを理解するのを手伝ってもらえますか?
編集1:
これは私の開発ログで生成された新しい応答です。未定義の「email」ローカル変数を「description」キーに渡そうとする問題を修正しました。
Started POST "/orders" for 127.0.0.1 at 2013-10-19 14:45:22 +0100
Processing by OrdersController#create as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"C/1Fmc4iEAiRGXwTcQNcDdX3j81KyhMHnfNcuYC/p1Y=", "order"=>{"video_id"=>"99", "member_id"=>"36", "price"=>"1000", "stripe_card_token"=>"tok_2mZBErSMVjAa3F"}}
(1.9ms) BEGIN
SQL (2.4ms) INSERT INTO "orders" ("created_at", "member_id", "price", "stripe_card_token", "updated_at", "video_id") VALUES ($1, $2, $3, $4, $5, $6) RETURNING "id" [["created_at", Sat, 19 Oct 2013 13:45:24 UTC +00:00], ["member_id", 36], ["price", 1000], ["stripe_card_token", nil], ["updated_at", Sat, 19 Oct 2013 13:45:24 UTC +00:00], ["video_id", 99]]
(2.3ms) COMMIT
Redirected to http://eqrfqer.xavy.dev/orders/13
何らかの理由で、params で生成された strip_card_token が Order モデルに挿入されていません。それが問題ですが、なぜ理解できませんか?
編集2:
おそらく問題は、実際には未定義のメールを「説明」に渡そうとしたことだと思います。それを変更してから、料金が私の Stripe アカウントに渡されていることがわかります。ログで、stripe_card_token が「nil」のように見える理由がわかりませんが、これはセキュリティ機能に違いないと思いますか?
とにかく、それは今働いているようです。