我正在开发我的第一个Rails应用程序,并希望创建一个管理部分.
我是否希望将我的视图和控制器与管理部分和站点的其余部分完全分开(即在不同的目录中)?
如何在自定义目录中组织我的视图/控制器(如何配置路由)?
要创建管理控制器:
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 %>
您还可以将应用程序和控制器保留在通常的位置,并使用Rails过滤器来控制访问,这是我认为您在这里寻找的.
如果你有方便的AWDWR书,请转到Chap11 Task F Administrivia
基本上在app\controllers\application.rb中定义一个授权方法,它检查授权,如果没有登录,则重定向到登录页面.
标记要限制使用before_filter
s 访问的控制器
.
class AdminController < ApplicationController before_filter :authorize # ... the rest of the code end
这将拦截对AdminController中定义的所有动作的调用,并强制它们通过授权进行
map.namespace :admin do |admin| admin.register :controller => 'main', :action => 'register' admin.login, :controller => 'main', action => 'login' # ... end
这就是你如何命名的东西,把这个添加到这里关于授权事情的其他评论,你就离开了.看看restful_authentication插件来进行用户管理,比滚动自己更快更容易.
上面的路由假定控制器及其视图位于一个名为admin的子目录中,我认为这就是你想要的.