Sentry - 清理局部变量敏感数据

Sentry - scrubbing local variables sensitive data

我想在将敏感数据发送到 Sentry

之前清除 Python 中的敏感数据

但是,在方法 before_sendtruncate_breadcrumb_message 中,我不确定在哪里可以获得局部变量列表并清除它们。

sentry_sdk.init(
    dsn=settings.get('SENTRY_DSN', ""),
    before_breadcrumb=truncate_breadcrumb_message,
    integrations=[FlaskIntegration()],
    before_send=sanitize_sentry_event,
)

def sanitize_sentry_event(event, hint):
    pass

def truncate_breadcrumb_message(crumb, hint):
    pass

def raise_execption(password):
    auth = 5
    raise Exception()

在上述方法中,我根本不希望将密码和身份验证发送到 Sentry。

我该怎么做?

event 是一个 JSON 有效载荷,它包含与您在 Sentry UI 下载的 "JSON" 中看到的完全相同的 JSON。所以你有一个这样的事件:

{
  "exception": {
    "values": [
      {
        "stacktrace": {
          "frames": [
            {"vars": ...}
          ]
        }
      }
    ]
  }
}

而你想删除 vars,你需要这样做:

def sanitize_sentry_event(event, hint):
    for exception in event.get("exception", {}).get("values", []):
        for frame in exception.get("stacktrace", {}).get("frames", []):
            frame.pop("vars", None)

    for exception in event.get("threads", {}).get("values", []):
        for frame in exception.get("stacktrace", {}).get("frames", []):
            frame.pop("vars", None)


    return event

您可能想用 try-except 包裹整个函数体。如果函数引发异常,则事件被丢弃。确保使用 init(debug=True) 进行测试,以查看您的 before_send 挂钩可能抛出的所有异常

找到了 here

任何人的代码raven 迁移并希望使用 raven 处理器 / sanitize_keys

from raven.processors import SanitizeKeysProcessor, SanitizePasswordsProcessor

class FakeRavenClient:
    sanitize_keys = [
        'card_number',
        'card_cvv',
        'card_expiration_date',
    ]

processors = [
    SanitizePasswordsProcessor(FakeRavenClient),
    SanitizeKeysProcessor(FakeRavenClient),
]

def before_send(event, hint):
    for processor in processors:
        event = processor.process(event)
    return event

sentry_sdk.init(
    before_send=before_send,
)