- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
通过 M. Hartl 的 Rails 教程第 8 章登录、注销
当我尝试注销我的应用程序时,我收到了问题标题中给出的错误消息。
我对此很陌生,但我认为这意味着在 models/user.rb
中定义并在 SessionsHelper< 中调用的
正在 forget
实例方法user
上调用,由于某种原因为 nil。这是我在 SessionsHelper
中谈论的片段:
#Found in SessionHelper. Forgets persistent session
def forget(user)
user.forget
cookies.delete(:user_id)
cookies.delete(:remember_tolken)
end
下面是 forget
实例方法的定义:
#Found in class models/user.rb
def forget
update_attribute(:remember_digest, nil)
end
我不知道为什么在 SessionsHelper
中调用时 user 会是 nil。以下是完整的文件,包括 SessionsController
、SessionsHelper
和 User
。
我希望我表达清楚并使用了正确的术语。让我知道是否需要澄清。
class SessionsController < ApplicationController
def new
end
def create
user = User.find_by(email: params[:session][:email].downcase)
if user && user.authenticate(params[:session][:password])
log_in user # Log the user in and redirect to the user's showpage
params[:session][:remember_me] == '1' ? remember(user) : forget(user)
redirect_to user # same as user_url(user)
else
# Show error message
flash.now[:danger] = 'Wrong email or password'
render 'new'
end
end
def destroy
log_out # if logged_in? # not logging out
redirect_to root_url
end
end
XXXXXXXXXX
module SessionsHelper
# Logs in given user
def log_in(user)
session[:user_id] = user.id
end
# Remembers a user in a persistant session
def remember(user)
user.remember
cookies.permanent.signed[:user_id] = user.id
cookies.permanent[:remember_token] = user.remember_token
end
#Forgets persistent session
def forget(user)
user.forget
cookies.delete(:user_id)
cookies.delete(:remember_tolken)
end
# Returns the current logged-in user (if any)
def current_user
if (user_id = session[:user_id]) # CAREFUL! (not ==). Read if session of user_id exists
@current_user ||= User.find_by(id: user_id)
else (user_id = cookies.signed[:user_id])
user = User.find_by(id: user_id)
if user && user.authenticated?(cookies[:remember_token])
log_in(user)
@current_user = user
end
end
end
# Returns true if the user is logged-in, else false
def logged_in?
!current_user.nil?
end
# logs out current user
def log_out
session.delete(:user_id)
forget(current_user)
@current_user = nil
end
end
XXXXXXXXXX
class User < ActiveRecord::Base
attr_accessor :remember_token
before_save {email.downcase!}
validates :name, presence: true, length: {maximum: 50}
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-]+(\.[a-z\d\-]+)*\.[a-z]+\z/i
validates :email, presence: true, length: {maximum: 255},
format: { with: VALID_EMAIL_REGEX },
uniqueness: {case_sensitive: false}
has_secure_password
validates :password, length: {minimum: 6}
# Returns the hash digest of the given string. Used to make hashed password of user in fixture model for login integration testing
def User.digest(string)
cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST :
BCrypt::Engine.cost
BCrypt::Password.create(string, cost: cost)
end
# Returns random token for remembering users via cookies
def User.new_token
SecureRandom.urlsafe_base64
end
# Remembers a user in the database for use in persisten sessions
def remember
self.remember_token = User.new_token
update_attribute(:remember_digest, User.digest(remember_token))
end
# Returns true if the given token matches the digest
def authenticated?(remember_token)
return false if remember_digest.nil?
BCrypt::Password.new(remember_digest).is_password?(remember_token)
end
# Forgets a user
def forget
update_attribute(:remember_digest, nil)
end
end
谢谢
最佳答案
您的log_out
方法在忘记用户之前删除 session 。这会导致错误,因为 forget
将 current_user
作为参数并且 current_user
使用 session 来确定当前用户是谁:
if (user_id = session[:user_id]) # This will attempt to assign user_id based on the value of session[:user_id], but will fail since the session was deleted
您需要在忘记用户之后删除 session 。更改您的 log out
方法:
def log_out
session.delete(:user_id)
forget(current_user)
@current_user = nil
end
对此:
def log_out
forget(current_user)
session.delete(:user_id)
@current_user = nil
end
关于ruby-on-rails - SessionsController 中的 NoMethodError#destroy undefined method `forget' for nil :NilClass,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29068050/
我正在编写一个 API 并尝试使用该 API 登录并收到 uninitialized constant SessionsController 错误,然后是“尝试运行 rake 路由以获取有关可用路由的
我正在尝试覆盖 Devise 中的 destroy 方法 SessionsController ,但我还没有成功。我已经为 create 做了这件事方法,但我不知道为什么它不适用于 destroy方法
我正在尝试在我的主页上设置登录表单。我按照 Wiki 设法做到了 除了,如果登录信息不正确,/devise/session/new.html.erb被渲染。 我不想要那个。我希望我的用户被重定向到 r
使用 Devise 管理用户 session /注册我需要在每次用户登录时以及在他被设计重定向到主页以进行连接之前执行特定任务(例如更新该特定用户的用户表中的某些字段)用户。 我是否必须覆盖设计 Se
我正在尝试向 Devise 的 SessionsController 添加一个 before_destroy 过滤器。 这是我尝试过的: 我创建了一个包含 before_destroy 过滤器的模块和
我有用于使用 devise gem 进行授权的用户模型。我想添加 after_sign_in_path 方法: # application_controller.rb protected # redi
我正在尝试使用 :lockable ,所以当我将它添加到 class User Rails.root: /Users/user/Ruby Application Trace | Framework
我正在使用经过修改以启用 Active Admin 的 Ruby on Rails 5 Api 应用程序。到现在为止一切都很好。我不记得在应用程序中做过任何更改,但现在,如果我在浏览器上删除 cook
当我尝试登录 Rails 应用程序时出现以下错误。我使用设计进行身份验证。我的错误是 设计中的 NoMethodError::SessionsController#create 未定义的方法 `cur
我从这个 repo 中克隆了一个测验应用程序项目:https://github.com/Pk13055/quiz-app 我正在尝试使用以下命令从我的系统运行它: rails server 但我收到此
这可能是我没有正确处理依赖注入(inject)的问题,但我正在尝试为我的 SessionsController 提供“ session ”服务。这是我的 SessionsController: ang
我安装了 ActiveAdmin 并使用默认管理员名称和密码登录,但出现错误,希望有人能帮助我。谢谢 ! 这是错误: ArgumentError in ActiveAdmin::Devise::Ses
我正在尝试为 iPhone 应用构建一个 Rails API。 Devise 可以很好地通过 Web 界面登录,但我需要能够使用 REST API 创建和销毁 session ,我想使用 JSON 而
我尝试了很长时间,并用谷歌搜索了我无法摆脱的问题。任何人都可以解释为什么会发生这种情况以及如何解决它。 def new self.resource = resource_class.new
我在使用 Rails 3 和 Devise 时遇到了一个特殊问题。我的 Rails 应用程序有 3 种用户类型: 客户、所有者和管理员 routes.rb: devise_for :admins
蛋糕版本 3.1.2 我做了什么: 在 MySQL 数据库中运行以下查询: CREATE TABLE `sessions` ( `id` varchar(255) NOT NULL DEFAULT
我必须修复旧 Rails 2.3.8 项目中的错误,但我在加载开发环境时遇到了麻烦。 我已经将项目转换为使用 bundler ,这是我的 Gemfile: source :gemcutter gem
我是 RoR 的新手,我正在按照本教程从头开始制作用户身份验证系统:http://railscasts.com/episodes/250-authentication-from-scratch .我整
我是 Ruby 生态系统的新手,快被淹死了。我想我被带有 C# 的 Visual Studio 的简单智能感知宠坏了。不管怎样,我在 Ubuntu 上使用 Ruby 1.9.3、Rails 3.2.1
通过 M. Hartl 的 Rails 教程第 8 章登录、注销 当我尝试注销我的应用程序时,我收到了问题标题中给出的错误消息。 我对此很陌生,但我认为这意味着在 models/user.rb 中定义
我是一名优秀的程序员,十分优秀!