アプリでdevise gemとカスタムユーザーコントローラーを使用しています。ショー ページとインデックス ページの両方でユーザーを編集するためのリンクがあります。サインイン後、users/index.html.erb または users/edit.html.erb の編集リンクをクリックすると、GET 要求が送信されたにもかかわらず、ユーザーの新しいフォームにリダイレクトされます。
ルートでは、ユーザーコントローラーを使用してそれを処理しており、正常に動作しているため、登録可能をスキップしています。
これがルートです
devise_for :users, :path_prefix => 'd', skip: [:registrations], controllers: {sessons: "sessions"}
resources :users
レーキルート | grep edit_userが与える
edit_user_password GET /d/users/password/edit(.:format) devise/passwords#edit
edit_user GET /users/:id/edit(.:format) users#edit
ユーザー/show.html.erb
<div class="btn btn-primary"> <%= link_to "Edit", edit_user_path(@user) %></div>
これは、index または show ページの編集リンクをクリックすると表示される登録フォームのスクリーンショットです。get リクエストを行っていますが、編集用のフォームではなく、新規用のフォームを表示しています。
これは、表示ページの編集リンクをクリックしたときのログです。
Started GET "/users/17/edit" for at 2013-08-19 08:40:49 +0000
Processing by UsersController#edit as HTML
Parameters: {"id"=>"17"}
User Load (0.2ms) SELECT "users".* FROM "users" WHERE "users"."id" = ? LIMIT 1 [["id", "17"]]
User Load (0.3ms) SELECT "users".* FROM "users" WHERE "users"."id" = 17 ORDER BY "users"."id" ASC LIMIT 1
Rendered users/_form.html.erb (17.5ms)
Rendered users/edit.html.erb within layouts/application (26.8ms)
Completed 200 OK in 50ms (Views: 47.1ms | ActiveRecord: 0.5ms
users_controller.rb
class UsersController < ApplicationController
before_action :set_user, only: [:show, :edit, :update, :destroy]
before_filter :authenticate_user!, except: [:new, :create]
respond_to :html, :json
def show
end
def edit
end
private
def set_user
@user = User.find(params[:id])
end
end
users/_edit.html.erbフォームに URL パスを指定しても、新しいフォームがレンダリングされます
form_for(@user, :url => edit_user_path(@user))
users/edit.html.erb
<%= render "edit" %>
ユーザー/index.html.erb
<% @users.each do |user| %>
<div class="btn btn-primary"><%= link_to "Edit", edit_user_path(user) %> </div>
<div class="btn btn-danger"><%= link_to 'Remove', user, method: :delete, data: {confirmation: 'Are you sure'} %></div>
<% end %>