4


1

Rails:未定義のメソッド「to_sym」

デプロイされたRails 2.3.5アプリケーションで次のエラーが表示されます。

NoMethodError(nil:NilClassの未定義メソッド「to_sym」):

Sqliteを使用するアプリケーションのローカルテストインストールではエラーは発生しませんが、Mysqlを実行しているデプロイ済みアプリケーションではエラーが発生します。 2つの唯一の違いは、ローカルマシンでRuby 1.8.7を実行し、展開サーバーで1.8.6を実行していることだけです。

User.rbのコードと以下のエラーログを含めました。 これは、宣言認可と埋め込み認可のRailscastに従って設定します。

任意の助けは大歓迎です!

編集:application_controllerのコードは次のとおりです。before_filterを使用してcurrent_userを設定します。

class ApplicationController < ActionController::Base
  helper :all
  helper_method :current_user_session, :current_user
  before_filter :set_current_user

  protected

  def set_current_user
    Authorization.current_user = current_user
  end

  def current_user_session
    return @current_user_session if defined?(@current_user_session)
    @current_user_session = UserSession.find
  end

  def current_user
    @current_user = current_user_session && current_user_session.record
  end
end

 — --

User.rb:

class User < ActiveRecord::Base
  acts_as_authentic

  has_many :products
  has_many :transactions

  ROLES = %w[admin dmstaff staff faculty]

  def role_symbols
    [role.to_sym]
  end

end

エラーログ:

NoMethodError (undefined method `to_sym' for nil:NilClass):
  app/models/user.rb:10:in `role_symbols'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization 0.4/lib/declarative_authorization/authorization.rb:242:in `roles_for'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization-0.4/lib/declarative_authorization/authorization.rb:296:in  `user_roles_privleges_from_options'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization-0.4/lib/declarative_authorization/authorization.rb:161:in `permit!'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization-0.4/lib/declarative_authorization/in_controller.rb:580:in `permit!'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization-0.4/lib/declarative_authorization/in_controller.rb:109:in `filter_access_filter'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization-0.4/lib/declarative_authorization/in_controller.rb:109:in `each'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization-0.4/lib/declarative_authorization/in_controller.rb:109:in `all?'
  /usr/lib/ruby/gems/1.8/gems/declarative_authorization-0.4/lib/declarative_authorization/in_controller.rb:109:in `filter_access_filter'
  passenger (2.2.5) lib/phusion_passenger/rack/request_handler.rb:95:in `process_request'
  passenger (2.2.5) lib/phusion_passenger/abstract_request_handler.rb:207:in `main_loop'
  passenger (2.2.5) lib/phusion_passenger/railz/application_spawner.rb:378:in `start_request_handler'
  passenger (2.2.5) lib/phusion_passenger/railz/application_spawner.rb:336:in `handle_spawn_application'
  passenger (2.2.5) lib/phusion_passenger/utils.rb:183:in `safe_fork'
  passenger (2.2.5) lib/phusion_passenger/railz/application_spawner.rb:334:in `handle_spawn_application'
  passenger (2.2.5) lib/phusion_passenger/abstract_server.rb:352:in `__send__'
  passenger (2.2.5) lib/phusion_passenger/abstract_server.rb:352:in `main_loop'
  passenger (2.2.5) lib/phusion_passenger/abstract_server.rb:196:in `start_synchronously'
  passenger (2.2.5) lib/phusion_passenger/abstract_server.rb:163:in `start'
  passenger (2.2.5) lib/phusion_passenger/railz/application_spawner.rb:213:in `start'
  passenger (2.2.5) lib/phusion_passenger/spawn_manager.rb:262:in `spawn_rails_application'
  passenger (2.2.5) lib/phusion_passenger/abstract_server_collection.rb:126:in `lookup_or_add'
  passenger (2.2.5) lib/phusion_passenger/spawn_manager.rb:256:in `spawn_rails_application'
  passenger (2.2.5) lib/phusion_passenger/abstract_server_collection.rb:80:in `synchronize'
  passenger (2.2.5) lib/phusion_passenger/abstract_server_collection.rb:79:in `synchronize'
  passenger (2.2.5) lib/phusion_passenger/spawn_manager.rb:255:in `spawn_rails_application'
  passenger (2.2.5) lib/phusion_passenger/spawn_manager.rb:154:in `spawn_application'
  passenger (2.2.5) lib/phusion_passenger/spawn_manager.rb:287:in `handle_spawn_application'
  passenger (2.2.5) lib/phusion_passenger/abstract_server.rb:352:in `__send__'
  passenger (2.2.5) lib/phusion_passenger/abstract_server.rb:352:in `main_loop'
  passenger (2.2.5) lib/phusion_passenger/abstract_server.rb:196:in `start_synchronously'

Rendering /var/data/app/current/public/500.html (500 Internal Server Error)

3 Answer


5


  def role_symbols
    [role.to_sym]
  end

→「role」は「Nil」です。 どこかで「ロール」を定義していますか?


1


ある時点で、コードは User`型のオブジェクトを期待していますが、代わりに nil`を取得しています。 このようなことをしていますか?

@user = User.find_by_login("Mary")
@user.role_symbols

どこで、「メアリー」は存在しないユーザーログインですか? role_symbolsメソッドを呼び出している場所を投稿してください。さらにお手伝いできます。

*編集:*メソッド#roles_for http://github.com/stffn/declarative_authorization/blob/master/lib/declarative_authorization/authorization.rb [こちら]を見て、プラグインを深く掘り下げることなく、 #current_userは、コード実行のこの時点では設定されていません。


1


ロール属性がテーブルに設定されていません。 あなたはレスキューコードを使用し、これがなぜ起こるかを調べなければなりません。

role.to_symを呼び出す前に「ロール」値が設定されているかどうかをテストします。