因此,我正在尝试使用Ruby on Rails为学校项目构建一个电子商务网站,为用户使用Devise。
我仍在自己学习这门语言,我遇到了一个问题。
我已通过设计生成此视图: views / devise / registrations / new.html.erb
<%= bootstrap_form_for(resource, as: resource_name, url: registration_path(resource_name)) do |f| %>
<%= devise_error_messages! %>
<div class="field">
<%= f.text_field :prenom, autofocus: true %>
</div>
<div class="field">
<%= f.text_field :nom, autofocus: true %>
</div>
<div class="field">
<%= f.text_field :adresse, autofocus: true %>
</div>
<div class="field">
<%= f.number_field :cp, autofocus: true %>
</div>
<div class="field">
<%= f.email_field :email, autofocus: true, placeholder: "Ex: votre@mail.com" %>
</div>
<div class="field">
<% if @validatable %>
<%= f.password_field :password, autocomplete: "off", placeholder: "8 caractères minimum" %>
<% end %>
</div>
<div class="field">
<%= f.password_field :password_confirmation, autocomplete: "off" %>
</div>
<div class="field">
<%= f.check_box :admin %>
</div>
<div class="actions">
<%= f.submit "Sign up" %>
</div>
我知道我不应该在我的表单中提供管理字段,但这仅用于测试目的。 因此,当我选中复选框并提交此表单时,它将返回false。 我不知道为什么。任何帮助,解释,非常感谢。
我的 user_controller ,如果需要:
class UsersController < ApplicationController
before_action :set_user, only: [:show, :edit, :update, :destroy]
# Fais appel à la méthode permettant de restreindre l'accès uniquement aux admins
# before_filter :authorize_admin, only: :index
# GET /users
# GET /users.json
def index
@users = User.all
end
# GET /users/1
# GET /users/1.json
def show
@user = User.find(params[:id])
end
# GET /users/new
def new
@user = User.new
end
# GET /users/1/edit
def edit
end
# POST /users
# POST /users.json
def create
@user = User.new(user_params)
respond_to do |format|
if @user.save
format.html { redirect_to @user, notice: 'User was successfully created.' }
format.json { render :show, status: :created, location: @user }
else
format.html { render :new }
format.json { render json: @user.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /users/1
# PATCH/PUT /users/1.json
def update
respond_to do |format|
if @user.update(user_params)
format.html { redirect_to @user, notice: 'User was successfully updated.' }
format.json { render :show, status: :ok, location: @user }
else
format.html { render :edit }
format.json { render json: @user.errors, status: :unprocessable_entity }
end
end
end
# DELETE /users/1
# DELETE /users/1.json
def destroy
@user.destroy
respond_to do |format|
format.html { redirect_to users_url, notice: 'User was successfully destroyed.' }
format.json { head :no_content }
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_user
@user = User.find(params[:id])
end
# Never trust parameters from the scary internet, only allow the white list through.
def user_params
params.fetch(:user, {})
end
end
答案 0 :(得分:0)
我在代码中没有看到你使用:admin
复选框值的地方,但我猜你也许只是问这个参数是否为true
,就像所以?
if params[:user][:admin] == true
do this...
else
do this...
end
问题在于,如果选中,则提交的复选框值默认为"1"
(请注意,它的类型为string
)。任何值的文本字符串都不等于true
或false
的布尔值。
您可以将代码更新为:
if params[:user][:admin] == "1"
do this...
else
do this...
end
Rails始终会将提交的参数作为string
值
答案 1 :(得分:0)
关键位在最后:
# Never trust parameters from the scary internet, only allow the white list through.
def user_params
params.fetch(:user, {})
end
白名单(第二个参数)为空,因此忽略所有参数。如果查看日志文件,您会看到有关忽略参数的警告(您可以将其配置为引发异常)。
如果正在使用的控制器是您的UsersController或设计注册控制器,则不清楚 - 您已经显示了一个视图,而另一个显示了控制器代码。
如果您使用的是设计注册控制器,那么UsersController
可能不相关 - 您通常会使用之前的过滤器来运行这样的事情
devise_parameter_sanitizer.permit(:sign_up, keys: [:admin, ...])
更改设计的默认允许字段列表。