首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Grape API: GRAPE::API的父类中的代码不工作

Grape API: GRAPE::API的父类中的代码不工作
EN

Stack Overflow用户
提问于 2017-06-08 03:00:33
回答 1查看 261关注 0票数 2

我使用的是葡萄api。我还使用graph logger library记录来自客户端的所有请求。我设计了一个通用的类,因为它将从许多其他地方使用。

代码语言:javascript
复制
require 'grape_logging'
class GeneralGrapeApi < Grape::API
  logger.formatter = GrapeLogging::Formatters::Default.new
  use GrapeLogging::Middleware::RequestLogger,
    logger: logger,
    include: [ GrapeLogging::Loggers::Response.new,
               GrapeLogging::Loggers::FilterParameters.new,
               GrapeLogging::Loggers::ClientEnv.new,
               GrapeLogging::Loggers::RequestHeaders.new ]
end

下面是我的自定义api,它从上面的类扩展而来:

代码语言:javascript
复制
module POS
      class ApplicationApi < GeneralGrapeApi    
        # mounting here
      end
end

当我运行时,日志库不工作。这意味着它不会将任何日志打印到标准输出。但如果我将代码移到内部类中,例如:

代码语言:javascript
复制
module POS
  class ApplicationApi < GeneralGrapeApi  
      logger.formatter = GrapeLogging::Formatters::Default.new
      use GrapeLogging::Middleware::RequestLogger,
        logger: logger,
        include: [ GrapeLogging::Loggers::Response.new,
                   GrapeLogging::Loggers::FilterParameters.new,
                   GrapeLogging::Loggers::ClientEnv.new,
                   GrapeLogging::Loggers::RequestHeaders.new ]  
    # mounting here
  end
end

看起来不错。请给我解释一下两种用法之间的区别。我更喜欢第一种解决方案,因为它会让我的代码不会重复。我怎么才能解决这个问题。

谢谢

EN

回答 1

Stack Overflow用户

发布于 2018-08-29 22:59:30

看起来需要在挂载API类的类内部配置记录器。因此,您可以使用第一个选项,但是您还需要执行第一部分中的挂载,并且不需要POS::ApplicationAPI类。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44420790

复制
相关文章

相似问题

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