Ruby on rails 在Rails 4中创建API-未初始化的常量API::V1::UsersController
对于个人项目,我想在Rails4中创建一个RESTfulWeb服务 因此,我使用Ruby on rails 在Rails 4中创建API-未初始化的常量API::V1::UsersController,ruby-on-rails,web-services,api,ruby-on-rails-4,routes,Ruby On Rails,Web Services,Api,Ruby On Rails 4,Routes,对于个人项目,我想在Rails4中创建一个RESTfulWeb服务 因此,我使用railsapi创建了我的第一个项目,并添加了以下代码: 我的项目>配置目录中的routes.rb MyProject::Application.routes.draw do namespace :api, defaults: {format: 'json'} do namespace :v1 do resources :users end en
railsapi
创建了我的第一个项目,并添加了以下代码:
我的项目>配置目录中的routes.rb
MyProject::Application.routes.draw do
namespace :api, defaults: {format: 'json'} do
namespace :v1 do
resources :users
end
end
end
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
users\u controller.rb在MyProject>app>controllers>api>v1>用户目录中
MyProject::Application.routes.draw do
namespace :api, defaults: {format: 'json'} do
namespace :v1 do
resources :users
end
end
end
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
模块Api
模块V1
类UsersController
当我使用命令行rails s
启动rails服务器并转到以下URL:http://localhost:3000/api/v1/users/show
我遇到了以下错误:
未初始化的常量Api::V1::UsersController
Rails.root:/Users/Jean/Development/MyProject
应用程序跟踪|框架跟踪|完整跟踪activesupport(4.0.4)
lib/active\u support/deconctor/methods.rb:228:inconst\u get'
activesupport(4.0.4)lib/active_-support/endoctor/methods.rb:228:in
constantize'activesupport中的块(4.0.4)
lib/active\u support/definctor/methods.rb:224:ineach'activesupport
(4.0.4)lib/active_support/definctor/methods.rb:224:in
inject'
activesupport(4.0.4)lib/active_-support/endoctor/methods.rb:224:in
constantize'actionpack(4.0.4)
lib/action\u dispatch/routing/route\u set.rb:76:in
controller\u reference'
actionpack(4.0.4)lib/action\u dispatch/routing/route\u set.rb:66:in
控制器的actionpack(4.0.4)
lib/action\u dispatch/routing/route\u set.rb:44:in
call'actionpack
(4.0.4)lib/action_dispatch/journe/router.rb:71:inblock in call'
actionpack(4.0.4)lib/action_dispatch/journe/router.rb:59:in
每个'
actionpack(4.0.4)lib/action_dispatch/journe/router.rb:59:incall'
actionpack(4.0.4)lib/action\u dispatch/routing/route\u set.rb:674:in
call'rack(1.5.2)lib/rack/etag.rb:23:incall'rack(1.5.2)
lib/rack/conditionalget.rb:25:in
call'rack(1.5.2)
lib/rack/head.rb:11:incall'actionpack(4.0.4)
lib/action\u dispatch/middleware/params\u parser.rb:27:in
call'
activerecord(4.0.4)lib/active\u record/query\u cache.rb:36:incall'
activerecord(4.0.4)
lib/active\u record/connection\u adapters/abstract/connection\u pool.rb:626:in
call'activerecord(4.0.4)lib/active\u record/migration.rb:373:in
调用actionpack(4.0.4)
lib/action\u dispatch/middleware/callbacks.rb:29:inblock in call'
activesupport(4.0.4)lib/active_support/callbacks.rb:373:in
\u运行\uuuuu4323212420903942114\uuuuuuu调用\uuuu回调的活动支持(4.0.4)
lib/active\u support/callbacks.rb:80:in
run\u callbacks'actionpack
(4.0.4)lib/action\u dispatch/middleware/callbacks.rb:27:incall'
actionpack(4.0.4)lib/action\u dispatch/middleware/reloader.rb:64:in
调用actionpack(4.0.4)
lib/action\u dispatch/middleware/remote\u ip.rb:76:incall'actionpack
(4.0.4)lib/action\u dispatch/middleware/debug\u exceptions.rb:17:in
调用actionpack(4.0.4)
lib/action\u dispatch/middleware/show\u exceptions.rb:30:incall'
railties(4.0.4)lib/rails/rack/logger.rb:38:in
调用应用程序“railties”
(4.0.4)lib/rails/rack/logger.rb:20:inblock in调用'activesupport
(4.0.4)lib/active_support/taged_logging.rb:68:in
block in taged'
activesupport(4.0.4)lib/active\u support/taged\u logging.rb:26:in
taged'activesupport(4.0.4)
lib/active\u support/tagged\u logging.rb:68:in
tagged'railties(4.0.4)
lib/rails/rack/logger.rb:20:incall'actionpack(4.0.4)
lib/action\u dispatch/middleware/request\u id.rb:21:in
call'机架(1.5.2)
lib/rack/runtime.rb:17:incall'activesupport(4.0.4)
lib/active\u support/cache/strategy/local\u cache.rb:83:in
call'rack
(1.5.2)lib/rack/lock.rb:17:incall'actionpack(4.0.4)
lib/action\u dispatch/middleware/static.rb:64:in
call'railties(4.0.4)
lib/rails/engine.rb:511:incall'railties(4.0.4)
lib/rails/application.rb:97:in
call'rack(1.5.2)
lib/rack/lock.rb:17:incall'rack(1.5.2)
lib/rack/content_length.rb:14:in
call'rack(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:in
服务'
/Users/Jean/.rvm/rubies/ruby-2.1.2/lib/ruby/2.1.0/webrick/httpserver.rb:94:in
run'
/Users/Jean/.rvm/rubies/ruby-2.1.2/lib/ruby/2.1.0/webrick/server.rb:295:in
start\u线程中的块'
我在Stackoverflow上发现很多帖子都有相同的错误,但答案并不能帮助我解决问题
谢谢 如果您有此路径:
MyProject>app>Controller>api>v1>用户
控制器应该是类Api::V1::Users::UsersController
如果:
MyProject>app>controller>api>v1>users\u controller.rb
然后class Api::V1::UsersController
对于首字母缩略词名称API::V1::userscoontroller
而不是API::V1::Users::userscoontroller
使用屈折符:
在config/initializers/definctions.rb中
ActiveSupport::Inflector.inflections(:en) do |inflect|
inflect.acronym 'API'
end
谢谢你解决了我的问题!我最终删除了user
目录,并像您所说的那样声明了我的控制器:classapi::V1::userscocontroller
。但是关于本文:blogger使用moduleapi
和modulev1
创建类userscocontroller
,而不是classapi::V1::userscocontroller
。为什么?对不起,也许我的第一句话不够清楚。我想说的是博主声明了它的类模块Api模块V1类用户控制器
而不是o