ruby-on-rails - Rails,Devise - 管理员试图编辑另一个用户配置文件,而不是加载自己的配置文件

标签 ruby-on-rails ruby ruby-on-rails-4 devise

作为使用 Rails 进行开发的新手,我正在努力解决以下问题: 我正在使用 Devise + Cancan + olify 应用程序来尝试创建身份验证和用户管理。 我已经对一般用户行为进行了分类,并且正在努力让管理员用户能够编辑另一个用户个人资料。

目前,管理员用户可以列出用户并尝试编辑其他用户的个人资料。但是,在进入编辑页面时,尽管 URL/路由对我来说是正确的,但我仍然会看到表单中的“currentuser”/admin 信息。

简而言之,场景: UserId1 是管理员 UserId1 正在尝试编辑 UserId2 的配置文件

登录为 UserId1,以下路由为 UserId1 而不是 UserId2 带来详细信息: http://localhost:3000/d/users/edit.2

这是 routes.rb:

devise_for :users, :path_prefix => 'd', :controllers => { :registrations => 'registrations' }

namespace :admin do
  get '', to: 'dashboard#index', as: '/'
  resources :users
end

这是 users#index View :

<table>
  <tbody>
    <% @users.each do |user| %>
      <tr>
        <td><%= user.id %></td>
        <td><%= user.first_name %></td>
        <td><%= user.last_name %></td>
        <td><%= user.email %></td>
        <td>
          <%= link_to edit_user_registration_path(user) %>
        </td>
        <td>
          <%= link_to registration_path(user),class: "red", :data => { :confirm => "Are you sure?" }, :method => :delete %>
        </td>
      </tr>
    <% end %>
  </tbody>
</table>

这是 users_controller.rb:

class Admin::UsersController < ApplicationController
  def index
    @users = User.all
  end
end

感谢任何帮助!


编辑 1

rake routes 给我以下内容:

    Prefix Verb               URI Pattern                         Controller#Action
new_user_session          GET    /d/users/sign_in(.:format)          devise/sessions#new
user_session              POST   /d/users/sign_in(.:format)          devise/sessions#create
destroy_user_session      DELETE /d/users/sign_out(.:format)         devise/sessions#destroy
user_password             POST   /d/users/password(.:format)         devise/passwords#create
new_user_password         GET    /d/users/password/new(.:format)     devise/passwords#new
edit_user_password        GET    /d/users/password/edit(.:format)    devise/passwords#edit
                          PATCH  /d/users/password(.:format)         devise/passwords#update
                          PUT    /d/users/password(.:format)         devise/passwords#update
cancel_user_registration  GET    /d/users/cancel(.:format)           registrations#cancel
user_registration         POST   /d/users(.:format)                  registrations#create
new_user_registration     GET    /d/users/sign_up(.:format)          registrations#new
edit_user_registration    GET    /d/users/edit(.:format)             registrations#edit
                          PATCH  /d/users(.:format)                  registrations#update
                          PUT    /d/users(.:format)                  registrations#update
                          DELETE /d/users(.:format)                  registrations#destroy
user_confirmation         POST   /d/users/confirmation(.:format)     devise/confirmations#create
new_user_confirmation     GET    /d/users/confirmation/new(.:format) devise/confirmations#new
                          GET    /d/users/confirmation(.:format)     devise/confirmations#show
user_unlock               POST   /d/users/unlock(.:format)           devise/unlocks#create
new_user_unlock           GET    /d/users/unlock/new(.:format)       devise/unlocks#new
                          GET    /d/users/unlock(.:format)           devise/unlocks#show
root                      GET    /                                   pages#home
about                     GET    /about(.:format)                    pages#about
admin                     GET    /admin(.:format)                    admin/dashboard#index
admin_users               GET    /admin/users(.:format)              admin/users#index
                          POST   /admin/users(.:format)              admin/users#create
new_admin_user            GET    /admin/users/new(.:format)          admin/users#new
edit_admin_user           GET    /admin/users/:id/edit(.:format)     admin/users#edit
admin_user                GET    /admin/users/:id(.:format)          admin/users#show
                          PATCH  /admin/users/:id(.:format)          admin/users#update
                          PUT    /admin/users/:id(.:format)          admin/users#update
                          DELETE /admin/users/:id(.:format)          admin/users#destroy

最佳答案

<%= link_to edit_user_registration_path(user) %>

还是指向你的设计路线,应该是:

<%= link_to edit_admin_user_path(user) %>

在rake routes中有描述。

关于ruby-on-rails - Rails,Devise - 管理员试图编辑另一个用户配置文件,而不是加载自己的配置文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22394822/

相关文章:

ruby-on-rails - Shopify API 如何使用 like 进行搜索查询

ruby-on-rails - Rails 3 run_callbacks 方法

json - Rails 嵌套属性不会从隐藏表单输入中的 JSON 字符串创建对象

ruby-on-rails - Rails 生成错误 : No such file or directory - getcwd

sql - Rails 迭代查询到 SQL 语句

mysql - 更新非规范化数据库表

ruby - 在好的 Ruby 代码中没有注释是否被认为是可以接受的?

ruby-on-rails - 已初始化常量 Patientinfo::PATIENT_HASH。警告:PATIENT_HASH 的先前定义位于此处

javascript - 使用浏览器历史记录时,Rails link_to Remote True 问题

ruby-on-rails - 在haml中使用link_to传递参数