0

アプリで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 %>
4

1 に答える 1