0

これは私が生成している応答です:

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」のように見える理由がわかりませんが、これはセキュリティ機能に違いないと思いますか?

とにかく、それは今働いているようです。

4

1 に答える 1

0

この行を書くことによって:

attr_accessor :stripe_card_token

を設定するためのレール機能を強制終了していますstripe_card_token

それがデータベースの列である場合は、削除してください!

于 2013-10-19T15:34:41.337 に答える