我正在按照本文在Rails 4中实现一些基本的用户身份验证
http://nycda.com/blog/basic-user-authentication-model-in-rails-4/
我没有使用提供的ERB表单,而是使用simple_form重新创建了(至少我以为是这样做的)过程,并且在尝试登录时通过的查询是这样的:
SELECT `users`.* FROM `users` WHERE `users`.`email` IS NULL ORDER BY `users`.`id` ASC LIMIT 1
当我尝试使用form_tag而不是simple_form的ERB示例时,该过程运行良好。这是两种比较形式:
我的表格(从HAML转换为ERB)
<%= simple_form_for :sessions, :url => log_in_path do |f| %>
<%= f.input :email %>
<%= f.input :password %>
<%= f.button :submit, 'Login' %>
从上面的文章:
<%= form_tag log_in_path do %>
<%= label_tag :email %>
<%= text_field_tag :email %>
<%= label_tag :password %>
<%= password_field_tag :password %>
<%= submit_tag "Log in" %>
<%end%>
根据本文:登录的simple_form问题
必须更新会话控制器的创建操作。
这:
@user = User.authenticate(params[:email], params[:password])
变成这样的:
@user = User.authenticate(params[:sessions][:email], params[:sessions][:password])
现在就像魅力一样!
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句