4

我正在尝试在 rails 3.0.20 和 ruby​​ 1.8.7 的项目中创建自定义错误页面。

无论如何在我的应用程序控制器中:

unless Rails.application.config.consider_all_requests_local
  rescue_from Exception, :with => :render_error
  rescue_from ActionController::RoutingError, ActionController::UnknownController,      ::AbstractController::ActionNotFound, ActiveRecord::RecordNotFound, :with =>    :render_error_not_found
end

然后是渲染错误方法:

def render_error(exception)
  notify_airbrake(exception)
  Rails.logger.fatal exception
  Rails.logger.fatal exception.backtrace.join("\n")
  respond_to do |format|
    format.html { render :template => "errors/error_500", :layout => 'layouts/application'}
    format.all { render :nothing => true, :status => 500 }
  end
end

似乎现在我的日志充满了比通常更长的回溯。为什么会这样?有没有办法只显示回溯的“重要”部分?在这里调用airbrake是否正确?

谢谢

4

1 回答 1

8

查看http://api.rubyonrails.org/classes/ActiveSupport/BacktraceCleaner.html。Rails 使用它在显示之前清理你的 backrace。

你可以像这样使用它:

Rails.backtrace_cleaner.clean(exception.backtrace)

我实际上是在查看 rails 源代码,因为我认为您的异常在到达您的 render_error 方法时可能已经被清除了。

于 2013-02-04T22:59:45.967 回答