freshcells / guzzle-message-anonymizer-formatter
在记录之前,从guzzle匿名化请求数据
2.0.0
2022-06-27 07:52 UTC
Requires
- php: >=7.2
- guzzlehttp/guzzle: ^7.0
Requires (Dev)
- jeroen/psr-log-test-doubles: ^2.2|^3.0
- phpunit/phpunit: ^8
Suggests
- csa/guzzle-bundle: Guzzle bundle for symfony
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 }