2

http://ruby.railstutorial.orgのチュートリアルに従っています

具体的には、第 9 章 (9.2.3) http://ruby.railstutorial.org/chapters/updating-showing-and-deleting-users#top

制限されたページにアクセスしたときにユーザーがログインするように求められ、ログインに成功した後に制限されたページにリダイレクトされるときに、その部分を取得することができました.

保護されたページにリダイレクトした後、次のログイン試行でメインのユーザープロファイルページに戻るようにしようとしていますが、session.delete(:return_to)機能していないようで、ユーザーは元のページに繰り返し戻されます保護されたページを保存しました。これが私のコードです:

私のセッションコントローラー:

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_back_or user
      # Sign the user in and redirect to the user's show page.
    else
      # Create an error message and re-render the signin form.
      flash.now[:error] = 'Invalid email/password combination'
      render 'new'
    end
  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

  def current_user?(user)
    user == current_user
  end

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

  def redirect_back_or(default)
    redirect_to(session[:return_to] || default)
    session.delete(:return_to)
  end

  def store_location
    session[:return_to] = request.url
  end
end

あなたが与えることができるどんな助けも素晴らしいでしょう!session.delete()単に機能していないようです。

4

2 に答える 2

1

チュートリアルを行ったとき、私のコードにはSessionsController#createメソッドの最初の行が次のようにありました。

user = User.find_by_email(params[:email])
if user && user.authenticate(params[:password])

しかし、本の対応するコードが次のように変更されていることがわかります。

user = User.find_by_email(params[:session][:email].downcase)
if user && user.authenticate(params[:session][:password])

その新しいコードを で使用しようとしましたsample_appが、ほとんどのテストが失敗しました。downcaseそのため、最初に呼び出しにメソッドを追加してテストすると思います。params[:session][:email]それが機能しない場合は、session上記の -less コードの行を置き換えてみて、機能するかどうかを確認してください。

アップデート

あなたのコードを見た後、私が知る限り、これらはあなたの問題です:

あなたは何らかの理由で電話session.delete(:return_to)をかけています。SessionsController#createこの行は削除できます。

アプリ/コントローラー/sessions_controller.rb

def create
  user = User.find_by_email(params[:session][:email].downcase)
  if user && user.authenticate(params[:session][:password])
    # session.delete(:return_to)
    sign_in user
    # ...
  #...
end

への呼び出しだけでなく、メソッド内の両方のコード行をブロックにUsersController#signed_in_user入れる必要があります。unlessredirect_to

app/controllers/users_controller.rb

def signed_in_user
  unless signed_in?
    store_location
    redirect_to signin_url, notice: "Please sign in." #unless signed_in?
  end
end

これらの変更を行ってテストを実行すると、まだNokogiri::XML::XPath::SyntaxError:呼び出し中です

仕様/リクエスト/authentication_pages_spec.rb

it { should have_exact_title('title', text: full_title('')) }` 

しかし、これはあなたが取り組む予定のカスタムマッチャーだと思います。そうでなく、それが間違いである場合は、それを削除すると、すべてのテストに合格します。

于 2012-09-21T00:36:53.587 に答える