操作系统: openSUSE 11.4 Rails 3.2.0
我刚刚创建了一个非常简单的应用程序"koko“。下面是我运行的命令的顺序
rails new koko
rails generate model Story name:string description:string
rake db:migrate
rails generate controller Stories index以上所有命令均已成功执行。然后我运行=>rails服务器来启动服务器。localhost:3000/工作正常。
当我尝试执行localhost:3000/store时,我得到以下错误:(浏览器显示第一行关于没有路由匹配)
Started GET "/stories" for 127.0.0.1 at Sat Aug 04 12:52:02 -0400 2012
ActionController::RoutingError (No route matches [GET] "/stories"):
actionpack (3.2.0) lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
actionpack (3.2.0) lib/action_dispatch/middleware/show_exceptions.rb:56:in `call'
railties (3.2.0) lib/rails/rack/logger.rb:26:in `call_app'
railties (3.2.0) lib/rails/rack/logger.rb:16:in `call'
actionpack (3.2.0) lib/action_dispatch/middleware/request_id.rb:22:in `call'
rack (1.4.1) lib/rack/methodoverride.rb:21:in `call'
rack (1.4.1) lib/rack/runtime.rb:17:in `call'
activesupport (3.2.0) lib/active_support/cache/strategy/local_cache.rb:72:in `call'
rack (1.4.1) lib/rack/lock.rb:15:in `call'
actionpack (3.2.0) lib/action_dispatch/middleware/static.rb:53:in `call'
railties (3.2.0) lib/rails/engine.rb:479:in `call'
railties (3.2.0) lib/rails/application.rb:220:in `call'
rack (1.4.1) lib/rack/content_length.rb:14:in `call'
railties (3.2.0) lib/rails/rack/log_tailer.rb:14:in `call'
rack (1.4.1) lib/rack/handler/webrick.rb:59:in `service'
/usr/lib/ruby/1.8/webrick/httpserver.rb:104:in `service'
/usr/lib/ruby/1.8/webrick/httpserver.rb:65:in `run'
/usr/lib/ruby/1.8/webrick/server.rb:173:in `start_thread'
/usr/lib/ruby/1.8/webrick/server.rb:162:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:162:in `start_thread'
/usr/lib/ruby/1.8/webrick/server.rb:95:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:92:in `each'
/usr/lib/ruby/1.8/webrick/server.rb:92:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:23:in `start'
/usr/lib/ruby/1.8/webrick/server.rb:82:in `start'
rack (1.4.1) lib/rack/handler/webrick.rb:13:in `run'
rack (1.4.1) lib/rack/server.rb:265:in `start'
railties (3.2.0) lib/rails/commands/server.rb:70:in `start'
railties (3.2.0) lib/rails/commands.rb:55
railties (3.2.0) lib/rails/commands.rb:50:in `tap'
railties (3.2.0) lib/rails/commands.rb:50
script/rails:6:in `require'
script/rails:6
Rendered /usr/lib/ruby/gems/1.8/gems/actionpack-3.2.0/lib/action_dispatch/middleware/templates/rescues/routing_error.erb within rescues/layout (0.9ms)发布于 2012-08-08 11:31:54
您的问题是,您正在尝试使用非RESTful资源的RESTful接口。您创建了一个模型,并创建了一个带有索引操作的控制器(/controller_name/action)。
如果您对使用/stories/index感到满意,那么我们就完成了!如果您更喜欢更传统的RESTful界面/stories,那么我建议您使用:
rails generate resource ModelName fields:types。
这将创建一个Model和一个Controller,并且应该可以开箱即用。这将设置评论中提到的路由。
希望这能有所帮助!
发布于 2012-08-08 13:54:36
您可能只是遇到了一些命名问题。通常,在创建控制器时,它应该是
rails g controller stories index或
rails g controller Story index然后将自动生成的路由更改为
match "/stories" => "stories#index", :as => "stories"https://stackoverflow.com/questions/11856680
复制相似问题