【问题标题】:No params being posted to Rails controller没有参数被发布到 Rails 控制器
【发布时间】:2015-08-31 04:21:42
【问题描述】:

我的应用中有一个包含一些嵌套字段的表单。 我正在使用simple_form_for、bootstrap、slim 和 Rails 4.2 以及here 所述的表单支持对象

这是服务器端缺少证明参数(注意,我检查了标记中的 authenticity_token 字段)

这是日志

Started POST "/example_sentences/9/breakdowns" for ::1 at 2015-08-31 12:37:57 +0900
  ActiveRecord::SchemaMigration Load (18.8ms)  SELECT "schema_migrations".* FROM "schema_migrations"
Processing by BreakdownsController#create as HTML
  Parameters: {"example_sentence_id"=>"9"}
Can't verify CSRF token authenticity

关闭 CSRF 保护以尝试调试会得到以下结果:

Started POST "/example_sentences/9/breakdowns" for ::1 at 2015-08-31 13:00:05 +0900
Processing by BreakdownsController#create as HTML
  Parameters: {"example_sentence_id"=>"9"}
  User Load (24.1ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = $1  ORDER BY "users"."id" ASC LIMIT 1  [["id", 1]]
Completed 400 Bad Request in 355ms (ActiveRecord: 156.3ms)

ActionController::ParameterMissing - param is missing or the value is empty: breakdown:

显然,有很多因素表明这偏离了 Rails 的方式,因此任何数量的事情都可能出错。并且显示视图代码会引入更多问题。

所以,我将展示生成的 HTML(减去样式信息),并询问是否有人能看出这有什么明显的错误。我有点希望这将是一个面对面的时刻,并且遗漏了一些明显的东西。

<form novalidate="novalidate" id="new_breakdown" action="/example_sentences/9/breakdowns" accept-charset="UTF-8" method="post">
  <input name="utf8" type="hidden" value="✓">
  <input type="hidden" name="authenticity_token" value="cOU87EZXRkV1a0QA1ohwlqM5Ny43QvgcRaqKan9mdgs12jR8RnJfyVXp9VIJHkMRkBUvZ16Io7QaGcBazjVqGw==">
  <input type="text" value="これ" name="breakdown[word_mapping][1][text]" id="breakdown_word_mapping_1_text" >
  <input type="text" value="this" name="breakdown[word_mapping][1][translation]" id="breakdown_word_mapping_1_translation">
  <input type="text" value="は" name="breakdown[word_mapping][2][text]" id="breakdown_word_mapping_2_text">
  <input type="text" value="" name="breakdown[word_mapping][2][translation]" id="breakdown_word_mapping_2_translation">
  <input type="submit" name="commit" value="Save translations">
</form>

其他信息

在 ~/.rbenv/versions/2.2.2/lib/ruby/gems/2.2.0/gems/actionpack-4.2.3/lib/action_controller/metal/request_forgery_protection.rb 中

:valid_authenticity_token? 检查第 277 行期间

对于 request.body.read 我可以看到真实性令牌 “UTF8 =%E2%9C%93&authenticity_token = RTFWCJZ3QnRgnNWFF66ej2aetx7H5n7BcbLKW4v145YADl6YllJb%2BEAeZNfIOK0IVbKvV64sJWkuAYBrOqb%2Fhg%3D%3D&击穿%5Bword_mapping%5D%5B1%5D%5Btext%5D =%E3%81%93%E3%82%8C&击穿%5Bword_mapping%5D%5B1 %5D%5Btranslation%5D=this&breakdown%5Bword_mapping%5D%5B1%5D%5Breading%5D=&breakdown%5Bword_mapping%5D%5B1%5D%5B_destroy%5D=0&breakdown%5Bword_mapping%5D%5B2%5D%5Btext%5D=% E3%81%AF&breakdown%5Bword_mapping%5D%5B2%5D%5Btranslation%5D=&breakdown%5Bword_mapping%5D%5B2%5D%5Breading%5D=&breakdown%5Bword_mapping%5D%5B2%5D%5B_destroy%5D=0&breakdown%5Bword_mapping% 5D%5B3%5D%5Btext%5D=%E3%83%9A%E3%83%B3&breakdown%5Bword_mapping%5D%5B3%5D%5Btranslation%5D=pen&breakdown%5Bword_mapping%5D%5B3%5D%5Breading%5D=&breakdown %5Bword_mapping%5D%5B3%5D%5B_destroy%5D=0&breakdown%5Bword_mapping%5D%5B4%5D%5Btext%5D=%E3%81%A7%E3%81%99&breakdown%5Bword_mapping%5D%5B4%5D%5Btranslation% 5D=&breakdown%5Bword_mapping%5D%5B4%5D%5Breading%5D=&breakdown%5Bword_mapping%5D%5B4%5D%5B_destroy%5D=0&br eakdown%5Bword_mapping%5D%5B%5D%5Btext%5D=%E3%81%93%E3%82%8C&breakdown%5Bword_mapping%5D%5B%5D%5Btranslation%5D=&breakdown%5Bword_mapping%5D%5B%5D%5Breading %5D=&breakdown%5Bword_mapping%5D%5B%5D%5B_destroy%5D=0&breakdown%5Bword_mapping%5D%5B%5D%5Btext%5D=%E3%81%AF&breakdown%5Bword_mapping%5D%5B%5D%5Btranslation%5D= &breakdown%5Bword_mapping%5D%5B%5D%5Breading%5D=&breakdown%5Bword_mapping%5D%5B%5D%5B_destroy%5D=0&breakdown%5Bword_mapping%5D%5B%5D%5Btext%5D=%E3%83%9A%E3 %83%B3&breakdown%5Bword_mapping%5D%5B%5D%5Btranslation%5D=&breakdown%5Bword_mapping%5D%5B%5D%5Breading%5D=&breakdown%5Bword_mapping%5D%5B%5D%5B_destroy%5D=0&breakdown%5Bword_mapping%5D %5B%5D%5Btext%5D=%E3%81%A7%E3%81%99&breakdown%5Bword_mapping%5D%5B%5D%5Btranslation%5D=&breakdown%5Bword_mapping%5D%5B%5D%5Breading%5D=&breakdown% 5Bword_mapping%5D%5B%5D%5B_destroy%5D=0&commit=Save+translations"

但是encoded_masked_token的值是nil

事实上,path_parameters 是我在请求中获得的参数的唯一部分。

in: "~/.rbenv/versions/2.2.2/lib/ruby/gems/2.2.0/gems/actionpack-4.2.3/lib/action_dispatch/http/request.rb"

(byebug) pp @env.keys.sort.grep(/action_dispatch/).grep(/param/).map{|k| [k, @env[k]]}

[["action_dispatch.parameter_filter", [:password]],
 ["action_dispatch.request.parameters",
  {"controller"=>"breakdowns",
   "action"=>"create",
   "example_sentence_id"=>"9"}],
 ["action_dispatch.request.path_parameters",
  {:controller=>"breakdowns", :action=>"create", :example_sentence_id=>"9"}],
 ["action_dispatch.request.query_parameters", {}],
 ["action_dispatch.request.request_parameters", {}]]

所以我已经不知何故失去了参数。

【问题讨论】:

  • 显示您的控制器代码
  • 所以我想避免过多地讨论控制器或视图,因为参数本身甚至没有触及控制器。如您所见,我从 url 获得了 example_sentence_id 参数,但没有别的

标签: ruby-on-rails forms post params


【解决方案1】:

从错误消息中,听起来您要求参数的代码不正确。

如果您有以下情况:

params.require(breakdown: [fields])

那么应该是

params.require(:breakdown).permit(fields)

试一试。

【讨论】:

  • 是的,我也是这么想的,但是你可以看到参数没有击中控制器。甚至没有找到 CSRF 令牌
  • 好的,因此您的表单中可能有无效的 HTML,它在包含属性之前关闭了表单。您能否将完整的表单(包括“样式元素”)添加到问题中?
  • 谢谢。我刚刚添加了显示请求正文的信息。这也是通过 slim 生成的,因此不可能缺少结束标签。显然我可以添加控制器/视图代码等,但这似乎让人分心,因为错误似乎发生在 Rails 堆栈中的某个地方,然后才点击我的代码
【解决方案2】:

好的,所以问题出在名称参数的格式上。我没有确切地知道 Rails 堆栈中的所有参数(包括authentity_token/CSRF 令牌)都丢失了,但基本上:

取而代之的是: breakdown[word_mapping][0][translation]

这是正确的: breakdown[word_mappings_attributes][0][translation]

如果其他人遇到类似问题,可能值得添加额外信息。

我正在使用带有表单支持对象的嵌套表单,如 OP 中链接的关键博客文章中所述。

根据其他地方的过时推荐,我的精简代码如下所示:

= f.simple_fields_for "word_mapping[]", @breakdown.word_mappings do |w|
  = render "word_mapping_fields", f: w

这导致了帖子中显示的输出 HTML。

正确的版本是:

= f.simple_fields_for "word_mappings", @breakdown.word_mappings do |w|
  = render "word_mapping_fields", f: w

在我的表单支持对象上,在这种情况下,我必须将 word_mappings_attributes= 委托给 AR 对象 ExampleSentence。虽然使用delegate 本身不起作用,所以我不得不手动编写代码。

def word_mappings_attributes=(attrs)
  example_sentence.word_mappings_attributes=attrs
end

我还必须在表单中添加以下内容:

class << self
  delegate :reflect_on_association, to: ExampleSentence
end

【讨论】:

    猜你喜欢
    • 2021-12-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多