96qbhy / hyid
hidden your id
Installs: 2 386
Dependents: 0
Suggesters: 0
Security: 0
Stars: 14
Watchers: 0
Forks: 1
Open Issues: 0
Requires (Dev)
This package is not auto-updated.
Last update: 2024-12-19 10:02:37 UTC
README
hide your id. 隐藏你的ID.
使用场景
当我们的应用需要提供一个无状态通过ID获取信息的接口,例如 GET /user/{id}
,此类接口只要递增ID进行请求,就可以得到我们数据库中所有公开信息,这很显然不是我们想看到的。
hyid
可以帮助你隐藏我们不希望用户看到的ID字段,或者其他数字字段。
安装
composer require 96qbhy/hyid
laravel or lumen
- 注册服务提供者 :
Qbhy\Hyid\ServiceProvider::class
- 发布配置文件(lumen可以自行复制
config/hyid.php
或者安装vendor:publish
命令):php artisan vendor:publish --provider=Qbhy\Hyid\ServiceProvider
使用
配置
HYID_SECRET=qbhy
HYID_OFFSET=1996
HYID_RANDOM_LENGTH=6
HYID_RANDOM_LENGTH 值建议不超过 6
代码示例
class User extends Model{ use Qbhy\Hyid\HyidAble; // or public function getUserId($userId){ return hyid($userId); } // or public function toArray(){ $data = parent::toArray(); $data['id'] = hyid()->encode($data['id']); return $data; } } // decode
解码后得到原始的ID
public function userinfo($id){ return User::query()->findOrFail(hyid()->decode($id))->toArray(); }
UserController
非 laravel 或者 lumen 环境下使用
// 非 laravel or lumen 下,可以自行实例化 Hyid 类 $secret = 'qbhy'; $offset = 1996; $hyid = new Hyid($secret,$offset,4); $encodedId = $hyid->encode(1); $id = $hyid->decode($encodedId); // 1