Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/qbhy/hyid

hidden your id
https://github.com/qbhy/hyid

Last synced: 20 days ago
JSON representation

hidden your id

Awesome Lists containing this project

README

        

# hyid
hide your id. 隐藏你的ID.

## 使用场景
当我们的应用需要提供一个无状态通过ID获取信息的接口,例如 `GET /user/{id}` ,此类接口只要递增ID进行请求,就可以得到我们数据库中所有公开信息,这很显然不是我们想看到的。
`hyid` 可以帮助你隐藏我们不希望用户看到的ID字段,或者其他数字字段。

## 安装
`composer require 96qbhy/hyid`

### laravel or lumen
1. 注册服务提供者 : `Qbhy\Hyid\ServiceProvider::class`
2. 发布配置文件(lumen可以自行复制 `config/hyid.php` 或者安装 `vendor:publish` 命令): `php artisan vendor:publish --provider=Qbhy\Hyid\ServiceProvider`

## 使用
### 配置
```text
HYID_SECRET=qbhy
HYID_OFFSET=1996
HYID_RANDOM_LENGTH=6
```
> HYID_RANDOM_LENGTH 值建议不超过 6
### 代码示例
```php
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
```php
public function userinfo($id){
return User::query()->findOrFail(hyid()->decode($id))->toArray();
}
```
> UserController

#### 非 laravel 或者 lumen 环境下使用
```php
// 非 laravel or lumen 下,可以自行实例化 Hyid 类
$secret = 'qbhy';
$offset = 1996;
$hyid = new Hyid($secret,$offset,4);

$encodedId = $hyid->encode(1);
$id = $hyid->decode($encodedId); // 1
```

[email protected]
[qbhy/hyid](https://github.com/qbhy/hyid)