ruby-on-rails - 在 Devise 注册时提交时为 "Unpermitted parameter: email"

标签 ruby-on-rails ruby ruby-on-rails-4 devise

我有一个简单的 Ruby on Rails 应用程序,使用 Devise 进行身份验证。我想让用户使用用户名而不是电子邮件登录,并尝试按照此处所述实现这一点: Devise authenticating with username instead of email

问题是我仍然希望每个用户都有一个电子邮件地址,并且在注册时需要一个。所以,我在注册表单上留下了“电子邮件”字段。

问题是,当我使用有效的电子邮件地址(或电子邮件的任何其他值)填写注册表单时,Devise 给出了一个错误:“电子邮件不能为空”。

为什么电子邮件被视为空白,我该如何解决?

class ApplicationController < ActionController::Base
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.
  protect_from_forgery with: :exception

  before_action :configure_permitted_parameters, if: :devise_controller?

  protected

  def configure_permitted_parameters
    devise_parameter_sanitizer.for(:sign_up) { |u| u.permit(:username, :email, :password, :password_confirmation, :remember_me) }
    devise_parameter_sanitizer.for(:sign_in) { |u| u.permit(:username, :password, :remember_me) }
    devise_parameter_sanitizer.for(:account_update) { |u| u.permit(:username, :email, :password, :password_confirmation, :current_password) }
  end
end

用户模型

class User < ActiveRecord::Base
  # Include default devise modules. Others available are:
  # :confirmable, :lockable, :timeoutable and :omniauthable
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
end

查看注册

<h2>Sign up</h2>

<%= form_for(resource, as: resource_name, url: registration_path(resource_name)) do |f| %>
  <%= devise_error_messages! %>

  <div class="field">
    <%= f.label :email %><br />
    <%= f.email_field :email, autofocus: true %>
  </div>

  <div class="field">
    <%= f.label :username %><br />
    <%= f.text_field :username %>
  </div>

  <div class="field">
    <%= f.label :password %>
    <% if @validatable %>
    <em>(<%= @minimum_password_length %> characters minimum)</em>
    <% end %><br />
    <%= f.password_field :password, autocomplete: "off" %>
  </div>

  <div class="field">
    <%= f.label :password_confirmation %><br />
    <%= f.password_field :password_confirmation, autocomplete: "off" %>
  </div>

  <div class="actions">
    <%= f.submit "Sign up" %>
  </div>
<% end %>

<%= render "devise/shared/links" %>

devise.rb 修改为包括:

config.authentication_keys = [ :username ]

这是提交表单时在 Rails 服务器控制台中的输出:

Started POST "/users" for ::1 at 2015-03-17 14:29:13 -0700
Processing by Devise::RegistrationsController#create as HTML
  Parameters: {"utf8"=>"✓", "authenticity_token"=>"bc5+ffyBSr6h79aumdMpwHhp5OY69
Tk5oKyY+eIBHLCDDwPmxiMbjbE6OTIaeUPGLmS0J+QlwlGFGHki8SKsgA==", "user"=>{"email"=>
"jessa@example.com", "username"=>"Jessa", "password"=>"[FILTERED]", "password_co
nfirmation"=>"[FILTERED]"}, "commit"=>"Sign up"}
Unpermitted parameter: email
   (0.0ms)  BEGIN
   (0.0ms)  ROLLBACK
  Rendered devise/shared/_links.html.erb (2.0ms)
  Rendered devise/registrations/new.html.erb within layouts/application (11.0ms)

我可以看到 Unpermitted parameter: email,但我不确定如何修复它。

最佳答案

有问题的代码是正确的,并且可以工作。它可以用作使用用户名设计登录的工作示例,尽管有很多教程都涵盖了这一点。

该错误是一个愚蠢的错误:一个文件不小心放在了错误的位置。感谢 Evgeny Petrov,他在评论中提供的示例帮助我找出了差异。

关于ruby-on-rails - 在 Devise 注册时提交时为 "Unpermitted parameter: email",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29022546/

相关文章:

ruby-on-rails - Rails 供应商 Assets 未提供服务.. 未找到路由错误

ruby-on-rails - 从 S3 下载文件到 Rails 4 应用程序

ruby-on-rails - 基于 Docker 的 Rails 应用程序的 nginx 维护页面

ruby-on-rails - 删除 Rails 3 子域 cookie

ruby-on-rails - 成员和收集路线是什么意思?

ruby-on-rails - 我如何在 Rails 的模型中获取 request.uri?

ruby - 从 Ruby 中的国家代码获取表情符号标志

javascript - 通过 link_to Rails 4 将参数传递给 Controller ​​方法

ruby-on-rails-4 - Koudoku - 用户拥有的列表的订阅,rails 4,无方法错误

Ruby - 在 Mac 和 Ubuntu 上执行不同的代码