0

在完成 Michael Hart 的 Rails 教程后,我正在尝试制作自己的简单应用程序。

我设法创建了用户资源,现在正在尝试创建会话资源,以跟踪某人何时登录。我得到了一些非常古怪的结果。

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=>"show", :controller=>"users", :id=>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

结尾

会话助手

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

应用控制器

class ApplicationController < ActionController::Base
  protect_from_forgery
  include SessionsHelper
end

想法?

4

1 回答 1

0

谢谢你们的帮助!似乎我有两个错误——1)当用户在用户控制器中注册时我没有登录用户,2)我没有重新启动服务器,并执行 db:reset。尝试之后,与注销不起作用有关的其他问题已修复。

于 2012-10-04T14:29:08.030 回答