【问题标题】:Rack middleware global middleware机架中间件 全局中间件
【发布时间】:2014-04-07 13:25:44
【问题描述】:

谁能解释一下这种和平的代码是如何工作的,尤其是日志过滤器部分。 我想从机架文件中分配log_attributes_filter,我在其中调用use MongodbLogger::RackMiddleware,该怎么做?

# Rack middleware for mounted rack app (e.g Grape)
module MongodbLogger
  class RackMiddleware
    @@log_attributes_filter = nil

    def self.log_attributes_filter=(filter)
      @@log_attributes_filter = filter
    end

    def initialize(app)
      @app = app
    end

    def call(env)
      request = ::Rack::Request.new env
      path = request.path.split('/')
      log_attrs = {
        params:     request.params
      }

      log_attrs = @@log_attributes_filter.call(log_attrs) if @@log_attributes_filter

      logger.mongoize(log_attrs) do
        return @app.call(env)
      end
    end
  end
end

之前我只是将它用作use MongodbLogger::RackMiddleware,但现在我想过滤一些参数,我应该如何正确分配@@log_attributes_filter

【问题讨论】:

标签: ruby-on-rails ruby rack middleware rack-middleware


【解决方案1】:

找到方法了。

  use MongodbLogger::RackMiddleware
  MongodbLogger::RackMiddleware.log_attributes_filter = lambda do |request|
    begin
      request[:params]["Password"] = "[FILTERED]"
      request
    rescue
      request
    end
  end

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2014-05-26
    • 2015-12-24
    • 1970-01-01
    • 1970-01-01
    • 2011-02-24
    • 2011-01-16
    • 2015-06-16
    • 1970-01-01
    相关资源
    最近更新 更多