新的 Rails 4.2 设置。我想抑制长错误回溯。在下面的回溯日志中,第一行对我来说就足够了,接下来的 4 行可以删除
ActionController::RoutingError (No route matches [GET] "/user"):
actionpack (4.2.1) lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
web-console (2.1.2) lib/web_console/middleware.rb:37:in `call'
actionpack (4.2.1) lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
railties (4.2.1) lib/rails/rack/logger.rb:38:in `call_app'
我添加了一个新的消音器backtrace_silencers.rb
# config/initializers/backtrace_silencers.rb
Rails.backtrace_cleaner.add_silencer { |line| line =~ /lib/ }
服务器重新启动后 - 没有任何反应,我仍然得到相同的回溯日志。 (每行匹配/lib/
应该被删除:http://api.rubyonrails.org/classes/ActiveSupport/BacktraceCleaner.htm)
完整性检查:
> line = "actionpack (4.2.1) lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'"
=> "actionpack (4.2.1) lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'"
> line =~ /lib/
=> 19
但过滤器有效:
# config/initializers/backtrace_silencers.rb
Rails.backtrace_cleaner.add_filter { |line| line.gsub('lib', 'yeah!') }
现在回溯看起来像这样:
ActionController::RoutingError (No route matches [GET] "/user"):
actionpack (4.2.1) yeah!/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
web-console (2.1.2) yeah!/web_console/middleware.rb:37:in `call'
actionpack (4.2.1) yeah!/action_dispatch/middleware/show_exceptions.rb:30:in `call'
railties (4.2.1) yeah!/rails/rack/logger.rb:38:in `call_app'
希望获得有关如何使消音器工作的建议。干杯!