生产环境中的 rails 应用程序中奇怪的"Missing template"异常



我在我的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地址,它不是来自我希望我的客户来自的地区。所以我想知道这是否是某种攻击,但问题仍然存在,即使存在模板,如何触发异常。

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

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

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

相关内容