微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ruby-on-rails – 在轨道上的ruby中未定义的方法’authenticate’?

我是 Ruby on Rails应用程序的新手,我已经创建了CRUD但仍然堆叠在Login&注销功能.

这是我的Sessions_controller:

def new
end

def create
  user = User.find_by(email: params[:session][:email].downcase)
  if user && user.authenticate(params[:session][:passkey])
    # Log the user in and redirect to the user's show page.
  else
    # Create an error message.
  flash[:danger] = 'Invalid email/password combination' # Not quite right!
    render 'new'
  end
end

def destroy
end

这是我的观点:new.html.erb

<%= form_for(:session,url: login_path) do |f| %>

    <%= f.label :email %>
    <%= f.email_field :email,class: 'form-control' %>

    <%= f.label :passkey%>
    <%= f.password_field :passkey,class: 'form-control' %>

    <%= f.submit "Log in",class: "btn btn-primary" %>
<% end %>

这是我的模特:

class User< ActiveRecord::Base
  validates :first_name,:presence => true,:length => { :in => 3..20 }
  validates :last_name,:length => { :in => 3..20 }
  validates :email,:uniqueness => true,format: { with: /\A[^@\s]+@([^@.\s]+\.)+[^@.\s]+\z/ }
  validates :passkey,:confirmation => true,:length => {:in => 6..20}
end

当我单击“登录”按钮,然后显示错误

NoMethodError in SessionsController#create
undefined method `authenticate’ for #User:0x0000000d5c65e0>

我该如何解决这个错误

我正在使用ruby 1.9.7 Rails 4.2.5& MysqL2

那对我很有帮助,拜托.

解决方法

只需添加

has_secure_password

到您的用户模型.确保添加

gem 'bcrypt-ruby'

到你的gemfile.

用户模型中添加一个名为“password_digest”的字段,其中包含字符串.

而已. Rails会像魅力一样为你处理用户身份验证,你也可以在你的模型上使用#authenticate方法

编辑:
你可以在github – Rails Project @ Github查看这个项目我已经使用Rails实现了身份验证. checkout user.rb,gemfile和user_controller.rb.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐