我设法创建了用户资源,现在我正在尝试创建一个会话资源,以跟踪某人何时登录。我得到了一些非常古怪的结果。
1)我试图在有人登录时以及有人退出时显示不同的菜单选项。它有效,除了它与我预期的方式相反!即我写的时候
<ul class="nav pull-right">
<% if signed_in? %>
#menu for registered users
<% else %>
#menu for unregistered users
<% end %>
</ul>
当我登录时,未注册用户的#menu会显示,当我退出时,注册用户的#menu会显示出来。
2)我也在尝试创建一个指向用户管理页面的链接,该页面基本上是用户的id页面。
我把它作为链接代码
作为以下内容<%= link_to "Admin", user_path(current_user) %>
得到了错误
没有路线匹配{:action =&gt;“show”,:controller =&gt;“users”,:id =&gt; nil}
这让我觉得我在会话助手中定义的current_user没有被保存,但是我认为,但我不确定为什么。
这是我的代码 用户模型
class User < ActiveRecord::Base
attr_accessible :name, :email, :password, :password_confirmation
has_secure_password
before_save { |user| user.email = email.downcase }
before_save :create_remember_token
validates :name, presence: true, length: { maximum: 50 }
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
validates :email, presence: true,
format: { with: VALID_EMAIL_REGEX },
uniqueness: { case_sensitive: false }
validates :password, presence: true, length: { minimum: 6 }
validates :password_confirmation, presence: true
private
def create_remember_token
self.remember_token = SecureRandom.urlsafe_base64
end
end
会话控制器
class SessionsController < ApplicationController
def new
end
def create
user = User.find_by_email(params[:session][:email].downcase)
if user && user.authenticate(params[:session][:password])
sign_in user
redirect_to user
else
flash.now[:error] = 'Invalid Email/Password Combination' #Not quite right;
render 'new'
end
end
端
SessionsHelper
module SessionsHelper
def sign_in(user)
cookies.permanent[:remember_token] = user.remember_token
self.current_user = user
end
def signed_in?
!current_user.nil?
end
def current_user=(user)
@current_user = user
end
def current_user
@current_user ||= User.find_by_remember_token(cookies[:remember_token])
end
end
的ApplicationController
class ApplicationController < ActionController::Base
protect_from_forgery
include SessionsHelper
end
思想?
答案 0 :(得分:0)
感谢帮帮!看起来我有两个错误 - 1)当用户在用户控制器中注册时我没有登录用户2)我没有重启服务器,并且做了db:reset。在尝试之后,其他问题,与登出不起作用,修复了。