申し訳ありませんが、私は簡単に修正できると信じていることに少し行き詰まっています。Rails アプリを作成していますが、現在アプリにログインしているユーザーの名前が「Tom」であるかどうかをテストしたいだけです。Tom という名前のユーザーがいて、彼でログインすると、セッション名が Tom ではないことを示す new_thing_url にリダイレクトされます。
user.name="Tom" も試しましたが、うまくいかないようです。
また、認証にBcryptを使用しています
sessions_controller.rb のセッション作成メソッド
def create
user=User.find_by(name: session[:name])
if session[:name] == 'Tom' and user.try(:authenticate,(params[:password]))
session[:user_id] = user.id
session[:name] = user.name
redirect_to admin_url
else if user and user.authenticate(params[:password])
redirect_to new_thing_url
else
redirect_to login_url, alert: "Invalid user/password combo"
end
end
end
\
<% if flash[:alert] %>
<p id="notice"><%= flash[:alert] %></p>
<% end %>
<%= form_tag do %>
<fieldset>
<legend>Please Log In</legend> <div>
<%= label_tag :name, 'Name:' %>
<%= text_field_tag :name, params[:name] %>
</div>
<div>
<%= label_tag :password, 'Password:' %>
<%= password_field_tag :password, params[:password] %>
</div> <div>
<%= submit_tag "Login" %> </div>
</fieldset>
<% end %>