10

我正在为创建“项目”的表格而苦苦挣扎。最终我只想允许当前的 user_id 但我还没有构建 User 模型或身份验证,所以作为占位符,我只是硬编码1

应用程序/视图/项目/new.html.erb:

<%= form_for(:project, :url => {:action=>'create'}) do |f| %>
<%= f.text_field(:name) %>
<%= f.text_field(:instructions) %>
<%= f.hidden_field( :user_id, {:value=>1}) %>
<%= f.submit('Create Project') %>
<% end %>

应用程序/控制器/projects_controller.rb

  def create
    #save object
    if Project.create( project_params )
        redirect_to(:action=>'show')
    else
        render('new')
    end
  end

  private
    def project_params
      params.require(:project).permit({:user_id => [1]}, :instructions, :max_duration, :active, :max_videos, :hashed_id)
    end

这是我尝试提交表单时遇到的错误:

Mysql2::Error: Field 'user_id' doesn't have a default value: INSERT INTO `projects` (`created_at`, `instructions`, `updated_at`) VALUES ('2013-08-16 17:38:56', 'sdfgsdf', '2013-08-16 17:38:56')

看来 project_params() 方法正在剥离 user_id。我究竟做错了什么?

4

1 回答 1

1

可能是因为 params[:user_id] 是一个字符串,这样做应该可以。

params.require(:project).permit({:user_id => ["1"]}, :instructions, :max_duration, :active, :max_videos, :hashed_id)
于 2013-08-16T18:32:47.367 回答