Skip to content

Latest commit

 

History

History
90 lines (63 loc) · 2.94 KB

README.md

File metadata and controls

90 lines (63 loc) · 2.94 KB

laravel desensitization middleware

Latest Version on Packagist Total Downloads GitHub Actions

针对 API 的敏感数据处理的中间,配置形式,脱敏函数和脱敏方法均自定义

Installation

You can install the package via composer:

composer require maxlcoder/laravel-desensitization

Config

php artisan vendor:publish --provider="Maxlcoder\LaravelDesensitization\LaravelDesensitizationServiceProvider"
  • functions: 脱敏使用的全局辅助函数,例如 'mobile' => 'desensitiseMobile',使用全局辅助函数 desensitiseMobile 对 uris 中配置的 type 为 mobile 类型的 key 做执行脱敏
  • class: 全局自定义脱敏类, name 表示类的全路径,这里只能填字符串,functions 表示类中脱敏类型对应的脱敏方法
  • functions 和 class 优先使用 functions 全局辅助函数,当全局辅助函数没有指定,才使用 class. 如果二者均没有配置,则不处理脱敏,但是会有 error 日志提示
  • uris: 全局需要进行脱敏的接口,以及接口返回中需要脱敏的字段名和脱敏类型,系统会对返回的数据结构做解析,并进行迭代脱敏,其中数组 * 表示返回的数据是数组
[
    'functions' => [
        'mobile' => 'desensitise_mobile',
        'name' => 'desensitise_name'
    ],
    'class' => [
        'name' => 'App\Lib\Desensitization',
        'functions' => [
            'mobile' => 'desensitiseMobile',
        ],
    ],
    'uris' => [
        'admin/admins' => [
            ['key' => 'data.data.*.mobile', 'type' => 'mobile'],
            ['key' => 'data.data.*.name', 'type' => 'name'],
        ],
    ],
];

Usage

Kerner.php 中引入中间件

protected $routeMiddleware = [
        ...
        
        'desensitization' => \Maxlcoder\LaravelDesensitization\Http\Middleware\Desensitization::class,
    ];

Testing

composer test

Changelog

Please see CHANGELOG for more information what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email [email protected] instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

Laravel Package Boilerplate

This package was generated using the Laravel Package Boilerplate.