【发布时间】:2014-09-11 03:51:01
【问题描述】:
对于个人项目,我想在 Rails 4 中创建一个 Restful Web 服务。
所以,我使用rails-api 创建了我的第一个项目并添加了以下代码:
routes.rb 在 MyProject > config 目录中
MyProject::Application.routes.draw do
namespace :api, defaults: {format: 'json'} do
namespace :v1 do
resources :users
end
end
end
users_controller.rb 在 MyProject > app > controllers > api > v1 > users 目录中
module Api
module V1
class UsersController < ApplicationController
def index
end
def create
end
def show
end
def update
end
def delete
end
end
end
end
当我使用命令行rails s 启动 Rails 服务器并转到此 URL:http://localhost:3000/api/v1/users/show 时,我遇到了此错误:
未初始化的常量 Api::V1::UsersController
Rails.root:/Users/Jean/Development/MyProject
应用程序跟踪 |框架跟踪 |全跟踪活动支持 (4.0.4) lib/active_support/inflector/methods.rb:228:in
const_get' activesupport (4.0.4) lib/active_support/inflector/methods.rb:228:inblock in constantize' activesupport (4.0.4) lib/active_support/inflector/methods.rb:224:ineach' activesupport (4.0.4) lib/active_support/inflector/methods.rb:224:ininject' activesupport (4.0.4) lib/active_support/inflector/methods.rb:224:inconstantize' actionpack (4.0.4) lib/action_dispatch/routing/route_set.rb:76:incontroller_reference' actionpack (4.0.4) lib/action_dispatch/routing/route_set.rb:66:incontroller' actionpack (4.0.4) lib/action_dispatch/routing/route_set.rb:44:incall' 动作包 (4.0.4) lib/action_dispatch/journey/router.rb:71:inblock in call' actionpack (4.0.4) lib/action_dispatch/journey/router.rb:59:ineach' actionpack (4.0.4) lib/action_dispatch/journey/router.rb:59:incall' actionpack (4.0.4) lib/action_dispatch/routing/route_set.rb:674:incall' rack (1.5.2) lib/rack/etag.rb:23:incall' rack (1.5.2) lib/rack/conditionalget.rb:25:incall' rack (1.5. 2) lib/rack/head.rb:11:incall' actionpack (4.0.4) lib/action_dispatch/middleware/params_parser.rb:27:incall' activerecord (4.0.4) lib/active_record/query_cache.rb:36:incall' activerecord (4.0.4) lib/active_record/connection_adapters/abstract/connection_pool.rb:626:incall' activerecord (4.0.4) lib/active_record/migration.rb:373:incall' actionpack (4.0.4) lib/action_dispatch/middleware/callbacks.rb:29:inblock in call' activesupport (4.0.4) lib/active_support/callbacks.rb:373:in_run__4323212420903942114__call__callbacks' activesupport (4.0.4) lib/active_support/callbacks.rb:80:inrun_callbacks' 动作包 (4.0.4) lib/action_dispatch/middleware/callbacks.rb:27:incall' actionpack (4.0.4) lib/action_dispatch/middleware/reloader.rb:64:incall' actionpack (4.0.4) lib/action_dispatch/middleware/remote_ip.rb:76:incall' actionpack (4.0.4) lib/action_dispatch/middleware/debug_exceptions.rb:17:incall' actionpack (4.0.4) lib/action_dispatch/middleware/show_exceptions.rb:30:incall' railties (4.0.4) lib/rails/rack/logger.rb:38:incall_app' railties (4.0.4) lib/rails/rack/logger.rb:20:inblock in call' activesupport (4.0.4) lib/active_support/tagged_logging.rb:68:inblock in 标记' activesupport (4.0.4) lib/active_support/tagged_logging.rb:26:intagged' activesupport (4.0.4) lib/active_support/tagged_logging.rb:68:intagged' railties (4.0.4) lib/rails/rack/logger.rb:20:incall' actionpack (4.0.4) lib/action_dispatch/middleware/request_id.rb:21:incall' 机架 (1.5.2) lib/rack/runtime.rb:17:incall' activesupport (4.0.4) lib/active_support/cache/strategy/local_cache.rb:83:incall' 机架 (1.5.2) lib/rack/lock.rb:17:incall' actionpack (4.0.4) lib/action_dispatch/middleware/static.rb:64:incall' railties (4.0.4) lib/rails/engine.rb:511:incall' railties (4.0.4) lib/rails/application.rb:97:incall' 机架 (1.5.2) lib/rack/lock.rb:17:incall' rack (1.5.2) lib/rack/content_length.rb:14:incall' 机架 (1.5.2) lib/rack/handler/webrick.rb:60:inservice' /Users/Jean/.rvm/rubies/ruby-2.1.2/lib/ruby/2.1.0/webrick/httpserver.rb:138:inservice' /Users/Jean/.rvm/rubies/ruby-2.1.2/lib/ruby/2.1.0/webrick/httpserver.rb:94:inrun' /Users/Jean/.rvm/rubies/ruby-2.1.2/lib/ruby/2.1.0/webrick/server.rb:295:inblock in start_thread'
我在 Stackoverflow 上发现很多帖子都有相同的错误,但答案并没有帮助我解决我的问题。
谢谢!
【问题讨论】:
标签: ruby-on-rails web-services api ruby-on-rails-4 routes