неопределенный метод `ключ? 'для ноля: NilClass - PullRequest
5 голосов
/ 31 марта 2012

Я новичок в Rails и следовал руководству Райана Бэйта о том, как сделать простую систему аутентификации (http://railscasts.com/episodes/250-authentication-from-scratch?autoplay=true), и я только что проходил через нее, но получил эту ошибку: `

NoMethodError in UsersController#new

undefined method `key?' for nil:NilClass
Rails.root: C:/Sites/authentication`

Я действительно не знаю, что это значит, так как я только начинающий, но это мои файлы:

пользовательский контроллер:

class UsersController < ApplicationController
  def new
    @user = User.new
  end

  def create
    @user = User.new(params[:user])
    if @user.save
        redirect_to root_url, :notice => "Signed up!"
    else
        render "new"
    end
  end
end

new.html.erb:

    <%= form for @user do |f| %>
<% if @user.errors.any? %>
<div class="error_messages">
    <h2>Form is invalid</h2>
    <ul>
        <% for message in @user.errors.full_messages %>
        <li><%= message %></li>
        <% end %>
    </ul>
</div>
<% end %>
<p>
    <%= f.label :email %>
    <%= f.text_field :email %>
</p>
<p>
    <%= f.label :password %>
    <%= f.password_field :password %>
</p>
<p>
    <%= f.label :password_confirmation %>
    <%= f.password_field :password_confirmation %>
</p>
<p class="button"><%= f.submit %></p>
<% end %>

routes.rb

    Authentication::Application.routes.draw do
  get "sign_up" => "users#new", :as => "sign_up"
  root :to => "users#new"
  resources :users
 end

модель пользователя

class User < ActiveRecord::Base
    attr_accessor :password
    before_save :encrypt_password

    validates_confirmation_of :password
    validates_presence_of :password, :on => create
    validates_presence_of :email
    validates_uniqueness_of :email

    def encrypt_password
        if password.present?
            self.password_salt = BCrypt::Engine.generate_salt
            self.password_hash = BCrypt::Engine.hash_secrete(password, password_salt)
    end
end

Я думаю, что руководство было сделано для Rails 3.1 или некоторой версии rails 3. Но я использую Rails 3.2, это может быть частью проблемы. Но так как я новичок, я понятия не имею, что происходит. Может ли кто-нибудь сказать мне, что делать?

Спасибо

Ответы [ 5 ]

9 голосов
/ 08 июня 2012

У меня была такая же проблема, и простой перезапуск моего сервера решил ее.

8 голосов
/ 31 марта 2012

Это оскорбительная строка:

validates_presence_of :password, :on => create

Измените его на

validates_presence_of :password, :on => :create

Также, do посмотрите на предположения, что stackoverflow показывает вам , когда вы пишете вопрос. Чтение этих предложений мешает 95% моих вопросов.

Обновление

Есть еще одна строка

<%= form for @user do |f| %>

Должно быть

<%= form_for @user do |f| %>

Теперь, пожалуйста, иди и трижды проверь, что ты набрал весь код так, как должен:)

1 голос
/ 03 августа 2012
  def encrypt_password
    if password.present?
        self.password_salt = BCrypt::Engine.generate_salt
        self.password_hash = BCrypt::Engine.hash_secrete(password, password_salt)
end

Вы также забыли добавить конец для оператора if.Это должно быть

  def encrypt_password
    if password.present?
        self.password_salt = BCrypt::Engine.generate_salt
        self.password_hash = BCrypt::Engine.hash_secrete(password, password_salt)
    end
  end
1 голос
/ 31 марта 2012

Ваш код в модели пользователя содержит опечатку в секрете.

self.password_hash = BCrypt::Engine.hash_secrete(password, password_salt)

Это должно быть

self.password_hash = BCrypt::Engine.hash_secret(password, password_salt)
0 голосов
/ 04 апреля 2014

Я решил эту проблему с установкой bcrypt-ruby версии 3.0.x по умолчанию. Укажите его в Gemfile:

gem 'bcrypt-ruby', '~> 3.0.0'
...