2

我在我的 rails 应用程序中设置了一个异常通知程序。所以今天我收到了第二个通知,index模板丢失:

An ActionView::MissingTemplate occurred in products#index:

Missing template products/index, application/index with {:locale=>[:en, :de], :formats=>["text/html;text/plain"], :variants=>[], :handlers=>[:erb, :builder, :raw, :ruby, :coffee, :slim, :arb, :jbuilder]}. Searched in:
* "/home/releases/20160518143810/app/views"


-------------------------------
Request:
-------------------------------

* URL : http://example.com/shop
* HTTP Method: GET
* IP address : xx.xx.xx.xx
* Parameters : {"controller"=>"products", "action"=>"index"}
* Timestamp : 2016-06-07 08:19:13 +0200
* Server : vintage-shop.ch
* Rails root : /home/releases/20160518143810
* Process: 15714

我知道一个事实,该产品的索引模板在服务器上并在 VCS 中签入,并且该应用程序已经运行了一个月。所以我真的很想知道,为什么会发生这种情况:

$ ls /home/releases/20160518143810/app/views/products/index.html.slim 

# -> /home/releases/20160518143810/app/views/products/index.html.slim

这个例外怎么可能?

更新:我查找了 IP 地址,它不是来自我希望我的客户来自的地区。所以我想知道这是否是某种攻击,但问题仍然是如何触发异常,即使模板存在。

4

1 回答 1

1

这可能是一次攻击尝试或(我猜更可能是)一些随机噪音。问题似乎在于 Rails 从请求标头中解析出的格式。:formats=>[:html, :text, :js, :css, :ics]通常,您应该在异常消息中看到如下内容:

格式通常在 Rails 中使用请求 URI(通常点后的所有内容都'.'被视为格式规范)或使用Accept标头确定。在您的情况下,我猜它是标题(您应该能够在异常通知中看到标题)。标Accept头应该包含逗号分隔的内容类型,而不是分号分隔,所以我猜这是异常的实际来源。

如果您想了解有关 Rails 格式解析的更多详细信息,请查看这篇非常有见地的博客文章。

于 2016-06-07T08:38:54.623 回答