我正在使用Devise来管理我的rails应用中的用户。我有一个管理员用户可用的按钮,它可以创建一个允许他们创建其他管理员用户帐户的表单。
提交表单时,会调用此代码:
@user = User.new(:email => params[:email], :password => params[:password], :password_confirmation => params[:password_confirmation])
@user.admin = true
@user.save
它似乎无法正常工作,因为当我退出并尝试使用新的管理员帐户登录时,它失败了。我猜测上面的代码不是用Devise创建新用户的正确方法。
有什么想法吗?
编辑:
日志
Started POST "/users/13/create_admin" for 127.0.0.1 at 2013-07-16 17:01:38 +0100
Processing by UsersController#create_admin as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"VpP78Zy8SAcyC1Mgg6hEjG2I5jqNzIHXQGtbjUzDYVE=", "users"=>{"email"=>"test@admin.com", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"Sign up", "id"=>"13"}
User Load (0.5ms) SELECT "users".* FROM "users" WHERE "users"."id" = 13 LIMIT 1
(0.3ms) BEGIN
(0.1ms) ROLLBACK
Rendered users/create_admin.html.erb within layouts/application (0.0ms)
Completed 200 OK in 12ms (Views: 5.3ms | ActiveRecord: 0.9ms)
这是我的表格:
<%= form_for :users, :html => { :id => "signup-form" }, :url => create_admin_user_path do |f| %>
<div><%= f.label :email %>
<%= f.email_field :email, :autofocus => true %></div>
<div><%= f.label :password %>
<%= f.password_field :password %></div>
<div><%= f.label :password_confirmation %>
<%= f.password_field :password_confirmation %></div>
<div class="actions">
<div><%= f.submit "Sign up", :class => "btn btn-success" %></div>
</div>
答案 0 :(得分:2)
你实际上是在发帖
"users"=>{"email"=>"test@admin.com", "password"=>""}
所以,你应该
@user = User.new(:email => params[:users][:email], :password => params[:users][:password], :password_confirmation => params[:users][:password_confirmation]))
@user.admin = true
@user.save
答案 1 :(得分:1)
在新设计中,应该从params hash中删除密码。如果密码为空。例如。我们想编辑个人资料但不要更改密码。 或者设计将无法验证。
if params[:user][:password].blank?
params[:user].delete(:password)
params[:user].delete(:password_confirmation)
end
有关详细信息,请参阅documentation。