2014-10-16 5 views
6

Ich folge Agile Web Entwicklung mit Rails 4. Kapitel Warenkorb 9 Warenkorb Erstellung. Wenn ich einen Einkaufswagen aktualisieren möchte, erhalte ich die folgende Fehlermeldung: Wenn Attribute zugewiesen werden, müssen Sie einen Hash als Argumente übergeben. CartController # Aktualisierung.Beim Zuweisen von Attributen müssen Sie einen Hash als Argument übergeben

class CartsController < ApplicationController 
    include CurrentCart 
    before_action :set_cart, only: [:show, :edit, :update, :destroy] 
    rescue_from ActiveRecord::RecordNotFound, with: :invalid_cart 

    def index 
    @carts = Cart.all 
    end 

    def show 
    end 

    def new 
    @cart = Cart.new 
    end 

    def edit 
    end 

    def create 
    @cart = Cart.new(cart_params) 

    respond_to do |format| 
     if @cart.save 
     format.html { redirect_to @cart, notice: 'Cart was successfully created.' } 
     format.json { render :show, status: :created, location: @cart } 
     else 
     format.html { render :new } 
     format.json { render json: @cart.errors, status: :unprocessable_entity } 
     end 
    end 
    end 

    def update 
    @cart = Cart.find(params[:id]) 

    respond_to do |format| 
     if @cart.update_attributes(params[:cart]) 
     format.html { redirect_to @cart, notice: 'Cart was successfully updated.' } 
     format.json { render :show, status: :ok, location: @cart } 
     else 
     format.html { render :edit } 
     format.json { render json: @cart.errors, status: :unprocessable_entity } 
     end 
    end 
    end 

    def destroy 
    @cart.destroy if @cart.id == session[:card_id] 
    session[:card_id] = nil 
    respond_to do |format| 
     format.html { redirect_to store_url, notice: 'Your cart is currently empty.' } 
     format.json { head :no_content } 
    end 
    end 

    private 

    def set_cart 
    @cart = Cart.find(params[:id]) 
    end 

    def cart_params 
    params[:cart] 
    end 

    def invalid_cart 
    logger.error "Attempt to access invalid cart #{params[:id]}" 
    redirect_to store_url, notice: 'Invalid cart' 
    end 
end 
+1

Wie sieht dein 'params [: cart]' aus? Ist das nicht ein Hash? Können Sie die Parameter überprüfen und das Ergebnis teilen? –

+0

Das ist was in der Logdatei. Gestartet PATCH "/ carts/32" für 127.0.0.1 am 2014-10-17 21:10:24 +0200 Verarbeitung per CartsController # Update als HTML Parameter: {"utf8" => "✓", "authenticity_token" = > "N/VxeEOEbfYQhhEcPqMnzUPZVLxZqecS4BwJjHivqi4 =", "commit" => "Warenkorb aktualisieren", "id" => "32"} Warenkorb laden (0,1ms) SELECT "Wagen". * FROM "Wagen" WO "Wagen". " id "=? LIMIT 1 [["id", 32]] (0.0ms) beginne die Transaktion (0.1ms) rollback transaction Abgeschlossen 500 Interner Server Fehler in 2ms – Keeic

+0

ArgumentError (Beim Zuweisen von Attributen müssen Sie einen Hash als Argument übergeben.) : app/controllers/carts_controller.rb: 49: in 'block in update ' app/controllers/carts_controller.rb: 47: in' update' – Keeic

Antwort

8

Ihre params ist wahrscheinlich eine Instanz von ActionController::Parameters

Wenn ja, können Sie die Attribute, die Sie erlauben müssen, verwenden möchten, etwa so:

def cart_params 
    params.require(:cart).permit(:attribute1, :attribute2, :attribute3) 
end 
3

starten: In Ihrem Update Methode ersetzen

if @cart.update_attributes(params[:cart]) 

von

if @cart.update_attributes(cart_params) 

In Ihrem cart_params private Methode dies zu tun:

def cart_params 
    params.require(:cart).permit(:attribute1, :attribute2, :attribute3) 
end 

Mit Rails 4 hat sich das Konzept der starken Parameter eingeführt worden, die im Grunde Massenzuordnung von Attributen in der Steuerung verbietet. Dies bedeutet, dass der Massenzugriffsschutz, der einmal im Modell (attr_accessible) war, nun in den Controller verschoben wurde. Daher in Ihren Modellen Sie nicht mehr Notwendigkeit, dies nutzen:

attr_accessible :attribute1, attribute 2 #attributes that can be mass-assinged 
attr_protected :attribute3 #attribute that is protected and cannot be mass-assinged 

Stattdessen können Sie jetzt tun dies in Ihrem Controller durch:

params.require(:cart).permit(:attribute1, :attribute2, :attribute3) 

Das bedeutet, dass nur attribute1, attribute2. attribute3 of cart sind zugänglich, während andere geschützte Attribute sind

Verwandte Themen