尝试创建用户会话 - >没有路由匹配{:action =>“show”,:controller =>“users”,:id => nil}

时间:2012-09-30 12:42:07

标签: ruby-on-rails ruby ruby-on-rails-3

在完成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 =&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

思想?

1 个答案:

答案 0 :(得分:0)

感谢帮帮!看起来我有两个错误 - 1)当用户在用户控制器中注册时我没有登录用户2)我没有重启服务器,并且做了db:reset。在尝试之后,其他问题,与登出不起作用,修复了。