Rails设计行动电缆

mar*_*ger 9 ruby-on-rails devise actioncable

我正试图让Action Cable与Devise合作.

module ApplicationCable
  class Connection < ActionCable::Connection::Base

    identified_by :current_user

    def connect
      self.current_user = find_verified_user
      logger.add_tags 'ActionCable', current_user.name
    end

    protected

    def find_verified_user
      verified_user = User.find_by(id: cookies.signed['user.id'])
      if verified_user && cookies.signed['user.expires_at'] > Time.now
        verified_user
      else
        reject_unauthorized_connection
      end
    end
  end
end
Run Code Online (Sandbox Code Playgroud)

如果用户已登录,我仍然可以nil从中获取cookies.signed['user.id']

小智 19

connection.rb使用以下内容更新您:

module ApplicationCable
  class Connection < ActionCable::Connection::Base
    identified_by :current_user

    def connect
      self.current_user = find_verified_user
      logger.add_tags 'ActionCable', current_user.studentid
    end

    protected

    def find_verified_user # this checks whether a user is authenticated with devise
      if verified_user = env['warden'].user
        verified_user
      else
        reject_unauthorized_connection
      end
    end
  end
end
Run Code Online (Sandbox Code Playgroud)

链接:http: //tutorials.pluralsight.com/ruby-ruby-on-rails/implementing-a-custom-devise-sign-in-and-actioncable-rails-5?saved=1&status=in-review

  • 哪个版本的 rails/devise/warden 应该可以工作?`env['warden'].user` 始终为零 (3认同)
  • 我遇到了类似的问题,我已经注销并登录并尝试过,但 `env['warden'].user` 始终为零。 (2认同)

小智 6

尝试在warden回调中设置cookie.

将文件添加到`config/initializers/your_file.rb``

将其添加到文件中:

Warden::Manager.after_set_user do |user, auth, opts|
  scope = opts[:scope]
  auth.cookies.signed["#{scope}.id"] = user.id
  auth.cookies.signed["#{scope}.expires_at"] = 60.minutes.from_now
end

Warden::Manager.before_logout do |user, auth, opts|
  scope = opts[:scope]
  auth.cookies.signed["#{scope}.id"] = nil
  auth.cookies.signed["#{scope}.expires_at"] = nil
end
Run Code Online (Sandbox Code Playgroud)

或者你可以这样做:

verified_user = env['warden'].user
Run Code Online (Sandbox Code Playgroud)

正如在这个非常好的课程中所解释的那样:https://www.sitepoint.com/create-a-chat-app-with-rails-5-actioncable-and-devise/

  • 正确的注销代码:`Warden :: Manager.before_logout do | user,auth,opts | scope = opts [:scope] auth.cookies.delete("#{scope} .id")auth.cookies.delete("#{scope} .expires_at")end` (3认同)
  • 除了我的用户不是你用devise设置的默认用户之外,这对我来说效果很好.对于你有不同用户登录的实例,只需将该用户类型添加为下一个参数,如`verfied_user = env ['warden'].user('admin_user')` (2认同)
  • 如果您使用的是Devise,请使用`auth.cookies.signed [“#{scope} .expires_at”] = Devise :: timeout_in.from_now` (2认同)