freshcells/guzzle-message-anonymizer-formatter

在记录之前,从guzzle匿名化请求数据

2.0.0 2022-06-27 07:52 UTC

This package is auto-updated.

Last update: 2024-09-18 18:31:22 UTC


README

使用guzzle中间件在记录之前匿名化或截断json或xml有效负载和请求头的一部分。
为了数据保护,你可能不希望在请求中记录个人信息,如姓名、地址等。

用法

Json有效负载的示例用法

...
$formatter = new GuzzleMessageJsonAnonymizerFormatter(
    ['PersonalData'],
    $substitute = '*****',
    AbstractAnonymizerFormatter::DEBUG,
    ['Authorization' => '*****']
);
$loggerMiddleware = Middleware::log($logger, $formatter);
$stack->push($loggerMiddleware);
$config  = [
    ...
    'handler'  => $stack,
];
$client  = new Client($config);

这将记录

<<<<<<<<
HTTP/1.1 200 OK
Date: Thu, 18 Jun 2020 10:04:21 GMT
Content-Type: application/json
Authorization: *****
...
{
  ...
  "Payload": {
    "Foo": "Bar", 
    ...
    "PersonalData": "*****"
  }, 
  ...
}

使用Symfony

声明Formatter服务

Freshcells\GuzzleMessageAnonymizerFormatter\GuzzleMessageXmlAnonymizerFormatter:
  arguments:
    $elements:
      - 'none:FirstName'
      - 'none:LastName'
    $attributes:
      - 'none:Customer[@Age]'
    $namespaces:
      none: 'http://namespace.de/middleware/payment/'
    $truncateElements
        VeryLongText: 200

覆盖现有日志中间件的消息格式化器

csa_guzzle.logger.message_formatter:
  alias: 'Freshcells\GuzzleMessageAnonymizerFormatter\GuzzleMessageXMLAnonymizerFormatter'

或声明一个专门的anonymizer_logger中间件

guzzle.middleware.anonymizer_logger:
  class: Closure
  factory: ['GuzzleHttp\Middleware', log]
  arguments: ['@monolog.logger', '@Freshcells\GuzzleMessageAnonymizerFormatter\GuzzleMessageXmlAnonymizerFormatter', 'info']
  tags:
    - { name: csa_guzzle.middleware, alias: anonymizer_logger }