yymou / slink
生成短网址 | PHP实现轻量稳定且易用短链接短网址服务
1.0.13
2022-08-18 09:23 UTC
Requires
- php: >=7.1.0
Requires (Dev)
- phpunit/phpunit: ^9.4
This package is auto-updated.
Last update: 2024-09-20 12:33:28 UTC
README
使用redis实现的常用的短链服务,支持redis一主多从配置,速度快且运行稳定(建议开启redis持久化),能满足亿级别的链接转化需求。底层使用redis发号器递增转换成62进制,但根据简单算法实现了短链接非递增返回。解析短链依托redis,速度快。
使用方法
-
1 使用composer引入
- 执行
composer require yymou/slink
- 在项目中引入composer
require 'vendor/autoload.php';
- 执行
-
2 在项目中使用
- 设置redis连接 1 : 如果已有redis示例,则直接传入即可
Slink\App::getInstance()->setRedisConnect(redisObj)
- 设置redis连接 2 : 通用配置 > 读写分离配置
- 通用配置
-
Slink\App::getInstance()->setCommonRedis([ 'hostname' => '127.0.0.1', 'password' => '', 'port' => '6379', 'timeout' => '5', 'database' => '0' ]);
-
- 读写分离配置
-
Slink\App::getInstance()->setClusterRedis([ 'write' => [ 'hostname' => '127.0.0.2', ], //支持设置多个读库 'read' => [ [ 'hostname' => '127.0.0.3', ], [ 'hostname' => '127.0.0.4', ] ], ]);
-
如使用读写分离配置,则不可设置通用配置,否则不生效;
- 通用配置
- 设置redis前缀(可选)
Slink\App::getInstance()->setRedisPrefix('slink:test');
如不设置则默认前缀为slink
- 设置原始链接缓存过期时间(可选)(如设置一天则24小时内同样的链接会返回相同的短链)单位为秒
Slink\App::getInstance()->setOlinkCacheTtl(86400*2);
如不设置则默认缓存时间为86400秒
- 设置返回短链长度(可选) 生成短链长度 推荐是7位 一旦项目启动禁止修改该值 7位生成的数量我62的6次方 最小为4
Slink\App::getInstance()->setSlinkLen(7);
- 生成短链接实例
$slink = Slink\App::getInstance()->getSlink('https://www.baidu.com');
- 短连接解析
$olink =Slink\App::getInstance()->getOlink('gikmor1');
项目通过短链获取原始链接后,可通过302定向原始的url地址
- 设置redis连接 1 : 如果已有redis示例,则直接传入即可
有任何意见或问题可以随时联系我交流哈 qq:875167485 WeChat:yangmeng6036