Rails应用程序管理部分

时间:2009-03-28 05:16:19

标签: ruby-on-rails ruby

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

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

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

3 个答案:

答案 0 :(得分:8)

创建管理员控制器:

script/generate controller admin/articles

然后在你的routes.rb文件

map.resource :admin do |admin|
  admin.resources :articles, :path_prefix => "admin", :name_prefix => "admin_", :controller => "admin/articles"
end

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

<%= link_to "Articles Admin", admin_articles_path %>

答案 1 :(得分:5)

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

如果您有方便的AWDWR书籍,请转到第11章任务F Administrivia

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

class AdminController < ApplicationController
   before_filter :authorize
   #  ... the rest of the code
end

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

答案 2 :(得分:5)

map.namespace :admin do |admin|
  admin.register :controller => 'main', :action => 'register'
  admin.login, :controller => 'main', action => 'login'
  # ...
end

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

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