J'ai un contrôleur avec espace de noms pour certaines fonctionnalités d'administration. Mon formulaire de création ne fonctionne pas - il finit par acheminer la requête à l'action index au lieu de l'action create.Demande POST dans le contrôleur de ressources avec espace de noms allant à l'action d'index au lieu de créer
Pourquoi le POST n'est-il pas routé vers l'action de création comme il se doit (étant RESTful)?
routes.rb:
map.namespace :admin do |admin|
admin.resources :events
end
routes rake:
admin_events GET /admin/events {:action=>"index", :controller=>"admin/events"}
formatted_admin_events GET /admin/events.:format {:action=>"index", :controller=>"admin/events"}
POST /admin/events {:action=>"create", :controller=>"admin/events"}
POST /admin/events.:format {:action=>"create", :controller=>"admin/events"}
new_admin_event GET /admin/events/new {:action=>"new", :controller=>"admin/events"}
formatted_new_admin_event GET /admin/events/new.:format {:action=>"new", :controller=>"admin/events"}
edit_admin_event GET /admin/events/:id/edit {:action=>"edit", :controller=>"admin/events"}
formatted_edit_admin_event GET /admin/events/:id/edit.:format {:action=>"edit", :controller=>"admin/events"}
admin_event GET /admin/events/:id {:action=>"show", :controller=>"admin/events"}
formatted_admin_event GET /admin/events/:id.:format {:action=>"show", :controller=>"admin/events"}
PUT /admin/events/:id {:action=>"update", :controller=>"admin/events"}
PUT /admin/events/:id.:format {:action=>"update", :controller=>"admin/events"}
DELETE /admin/events/:id {:action=>"destroy", :controller=>"admin/events"}
DELETE /admin/events/:id.:format {:action=>"destroy", :controller=>"admin/events"}
app/views/admin/événements/new.html.erb:
<h1>New event</h1>
<% form_for([:admin, @event]) do |f| %>
<%= f.error_messages %>
...
app/controllers/admin/event_controller.rb:
class Admin::EventsController < ApplicationController
def index
@events = Event.find(:all)
...
end
def create
@event = Event.new(params[:event])
...
end
...
end
Et enfin, un peu d'un fichier journal dans lequel vous pouvez le voir est en effet afficherons:
Processing Admin::EventsController#index (for 127.0.0.1 at 2008-10-16 18:12:47) [POST]
Session ID: ...
Parameters: {"commit"=>"Create", "authenticity_token"=>"...", "action"=>"index", "controller"=>"admin/events", "event"=>{"location"=>""}}
Event Load (0.000273) SELECT * FROM `events`
Rendering template within layouts/application
Rendering admin/events/index
Completed in 0.00757 (132 reqs/sec) | Rendering: 0.00118 (15%) | DB: 0.00027 (3%) | 200 OK [http://localhost/admin/events]
Merci beaucoup. Ce bug inexplicable est sur le point de faire exploser mon cerveau! Merci beaucoup pour cette question. – Antiarchitect
Je veux juste demander quelle est la différence entre 'map.connect ''' et 'map.root'? – PeterWong