首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >机架中间件全局中间件

机架中间件全局中间件
EN

Stack Overflow用户
提问于 2014-04-07 21:25:45
回答 1查看 236关注 0票数 1

有没有人能解释一下这段代码是如何工作的,尤其是日志过滤器部分。我想从rack文件中分配log_attributes_filter,在这里我调用use MongodbLogger::RackMiddleware,怎么做?

代码语言:javascript
复制
# 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

EN

回答 1

Stack Overflow用户

发布于 2014-04-08 14:31:43

找到了一种方法。

代码语言:javascript
复制
  use MongodbLogger::RackMiddleware
  MongodbLogger::RackMiddleware.log_attributes_filter = lambda do |request|
    begin
      request[:params]["Password"] = "[FILTERED]"
      request
    rescue
      request
    end
  end
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22913866

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档