Rails应用程序管理部分

Gee*_*ock 7 ruby ruby-on-rails

我正在开发我的第一个Rails应用程序,并希望创建一个管理部分.

我是否希望将我的视图和控制器与管理部分和站点的其余部分完全分开(即在不同的目录中)?

如何在自定义目录中组织我的视图/控制器(如何配置路由)?

nit*_*der 8

要创建管理控制器:

script/generate controller admin/articles
Run Code Online (Sandbox Code Playgroud)

然后在routes.rb文件中

map.resource :admin do |admin|
  admin.resources :articles, :path_prefix => "admin", :name_prefix => "admin_", :controller => "admin/articles"
end
Run Code Online (Sandbox Code Playgroud)

然后,您可以访问索引网址:

<%= link_to "Articles Admin", admin_articles_path %>
Run Code Online (Sandbox Code Playgroud)


Gis*_*shu 5

您还可以将应用程序和控制器保留在通常的位置,并使用Rails过滤器来控制访问,这是我认为您在这里寻找的.

如果你有方便的AWDWR书,请转到Chap11 Task F Administrivia

  • 基本上在app\controllers\application.rb中定义一个授权方法,它检查授权,如果没有登录,则重定向到登录页面.
  • 标记要限制使用before_filters 访问的控制器

.

class AdminController < ApplicationController
   before_filter :authorize
   #  ... the rest of the code
end
Run Code Online (Sandbox Code Playgroud)

这将拦截对AdminController中定义的所有动作的调用,并强制它们通过授权进行

  • 这种方法是可行的,但并不总是合适的,特别是如果你想拥有一个像CMS一样的CMS部分而不是通过你的应用程序散布的一些管理资源. (2认同)

Gho*_*oti 5

map.namespace :admin do |admin|
  admin.register :controller => 'main', :action => 'register'
  admin.login, :controller => 'main', action => 'login'
  # ...
end
Run Code Online (Sandbox Code Playgroud)

这就是你如何命名的东西,把这个添加到这里关于授权事情的其他评论,你就离开了.看看restful_authentication插件来进行用户管理,比滚动自己更快更容易.

上面的路由假定控制器及其视图位于一个名为admin的子目录中,我认为这就是你想要的.