2

サンプルアプリからログアウトできない理由を特定する助けがあれば、非常に感謝しています. * すべての rspec テストに合格しました。* ローカル サーバーでログアウトしようとすると、[ログアウト] をクリックしてもログアウトされず、リンクが [サインイン] に変わりません (このための rspec テストはパスしますが)。

authentication_pages_spec.rb からの関連テストは次のとおりです。

require 'spec_helper'

describe "AuthenticationPages" do

  subject { page }

  describe "signin page" do
    before { visit signin_path }

    it { should have_selector('h1',    text: 'Sign in') }
    it { should have_selector('title', text: 'Sign in') }
  end

  describe "signin" do
    before { visit signin_path }

    describe "with invalid information" do
      before { click_button "Sign in" }

      it { should have_selector('title', text: 'Sign in') }
      it { should have_selector('div.alert.alert-error', text: 'Invalid') }

      describe "after visiting another page" do
        before {click_link "Home" }
        it { should_not have_selector('div.alert-error') }
      end
    end

    describe "with valid information" do
      let(:user) { FactoryGirl.create(:user) }
      before do
        fill_in "Email", with: user.email
        fill_in "Password", with: user.password
        click_button "Sign in"
      end

      it { should have_selector('title',   text: user.name) }
      it { should have_link('Profile',     href: user_path(user)) }
      it { should have_link('Sign out',    href: signout_path) }
      it {should_not have_link('Sign in',  href: signin_path) }

      describe "followed by signout" do
        before { click_link "Sign out" }
        it { should have_link ('Sign in') }
      end
    end
  end
end

ここに sessions_controller.rb があります

class SessionsController < ApplicationController

  def  new
  end

  def create
    user = User.find_by_email(params[:session][:email])
    if user && user.authenticate(params[:session][:password])
      sign_in user
      redirect_to user
    else
      flash.now[:error] = "Invalid email/password combination"
      render 'new'
    end
  end

  def destroy
    sign_out
    redirect_to root_path
  end
end

ここに sessions_helper.rb があります

module SessionsHelper
  def sign_in(user)
    cookies.permanent[:remember_token] =  user.remember_token
    self.current_user = user
  end

  def signed_in?
    !self.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   

  def sign_out
    self.current_user = nil
    cookies.delete(:remember_token)
  end
end

ここに_header.html.erbがあります

<header class="navbar navbar-fixed-top">
    <div class="navbar-inner">
        <div class="container">
            <%= link_to "sample app", root_path, id: "logo" %>
            <nav>
                <ul class="nav pull-right">
                    <li><%= link_to "Home",    root_path %></li>
                    <li><%= link_to "Help",    help_path %></li>
                    <% if signed_in? %>
                        <li><%= link_to "Users", '#' %></li>
                        <li id="fat-menu" class="dropdown">
                            <a href='#' class="dropdown-toggle"  data-toggle="dropdown">
                                Account <b class="caret"></b>
                            </a>
                            <ul class="dropdown-menu">
                                <li><%= link_to "Profile", user_path(current_user) %></li>
                                <li><%= link_to "Settings", '#' %></li>
                                <li class="divider"></li>
                                <li>
                                    <%=  link_to "Sign out", signout_path, method: "delete" %>    
                                </li>
                            </ul>
                        </li>        
                    <% else %>
                        <li><%= link_to "Sign in", signin_path %></li>
                    <% end  %>
                </ul>
            </nav>
        </div>
    </div>
</header> 

そして最後に、ここにモデル user.rb があります

class User < ActiveRecord::Base
  attr_accessible :name, :email, :password, :password_confirmation 
  has_secure_password

  before_save { |user| user.email = user.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 

これが私のWEBrickサーバーが言っていることです:

Started DELETE "/signout" for 127.0.0.1 at 2012-06-19 10:58:53 -0400
Processing by SessionsController#destroy as HTML
  Parameters: {"authenticity_token"=>"qP1xAF4YXTaFmjeHxS5SgvUx+6+c6us5AL4jqgEBeqQ="}
Redirected to http://localhost:3000/
Completed 302 Found in 1ms (ActiveRecord: 0.0ms)


Started GET "/" for 127.0.0.1 at 2012-06-19 10:58:53 -0400
Processing by StaticPagesController#home as HTML
  Rendered static_pages/home.html.erb within layouts/application (0.6ms)
  Rendered layouts/_shim.html.erb (0.1ms)
  User Load (0.3ms)  SELECT "users".* FROM "users" WHERE "users"."remember_token" IS NULL LIMIT 1
  Rendered layouts/_header.html.erb (3.1ms)
  Rendered layouts/_footer.html.erb (0.5ms)
Completed 200 OK in 22ms (Views: 21.2ms | ActiveRecord: 0.3ms)
[2012-06-19 10:58:53] WARN  Could not determine content-length of response body. Set content-length of the response or set Response#chunked = true


Started GET "/assets/application.css?body=1" for 127.0.0.1 at 2012-06-19 10:58:53 -0400
Served asset /application.css - 304 Not Modified (11ms)
[2012-06-19 10:58:53] WARN  Could not determine content-length of response body. Set content-length of the response or set Response#chunked = true 

Cookie に何らかの問題がある場合、ブラウザで Cookie を確認すると次のようになります。

Cookie の確認: 1. すべての Cookie を消去します。 2. localhost:3000 に移動します。私はまだユーザー 2 としてサインインしています。Cookie を確認しましたが、ローカル ホストの remember_token がありません。「_sample_app_session」という名前の Cookie があります。 3. [サインアウト] をクリックします。何も起こらず、サインインしたままです。 4. /signin と入力します。ユーザー 3 としてログインします。 5. Cookie に remember_token が含まれています。6. サインアウトをクリックします。上部のナビゲーションにサインインしていることをまだ示しています。7. プロファイルをクリックして、(デバッグ経由で) ユーザー 2 としてログインしていることを確認します 8. Cookie を確認し、トークンがなくなったことを覚えています。

これを引き起こしている可能性があるものをテストする方法はありますか? 私は本当にこれを解決しようとしているので、チュートリアルを進めることができます.

4

2 に答える 2

5

ああ、私も同じ問題を抱えていました。私でさえ、同じために髪を引っ張っていました。その後、友人の 1 人がコードに気づき、私を助けてくれました。問題は、RAILS CONSOLE から記憶トークンを追加し忘れたことです。オプションのきゅうりの上の部分を確認してください。Rails コンソールからトークンを追加する部分に気付くでしょう。

レールコンソール

User.first.remember_token

=>なし

User.all.each { |ユーザー| user.save(validate: false) }

User.first.remember_token

于 2012-06-30T05:01:24.027 に答える
1

herokuにプッシュした後、必ずdbを移行してください。私は同様の問題を抱えていましたが、実行した後に消えました:

$ heroku run rake db:migrate
于 2015-02-13T13:07:53.257 に答える