php的token管理类(AI生成)
当然,以下是一个简单的 PHP 类,用于生成和管理令牌(token)。这个类可以生成一个随机的令牌、验证令牌是否有效,并允许设置一个令牌的过期时间。
<?php class Token
{
private $secretKey;
private $token;
private $expiration; /**
* Token constructor.
* @param string $secretKey 用于生成和验证令牌的密钥
*/
public function __construct($secretKey)
{
$this->secretKey = $secretKey;
} /**
* 生成一个新的令牌
* @param int $expirationTime 令牌的有效期(秒)
* @return string 生成的令牌
*/
public function generateToken($expirationTime = 3600)
{
$data = [
'iat' => time(), // 令牌生成时间
'exp' => time() + $expirationTime // 令牌过期时间
]; $jwt = $this->encode($data);
$this->token = $jwt;
$this->expiration = time() + $expirationTime; return $jwt;
} /**
* 验证令牌是否有效
* @param string $token 要验证的令牌
* @return bool 是否有效
*/
public function validateToken($token)
{
$decoded = $this->decode($token); if (!$decoded || $decoded->exp < time()) {
return false;
} return true;
} /**
* 编码数据为 JWT
* @param array $data 要编码的数据
* @return string 编码后的 JWT
*/
private function encode($data)
{
$header = base64_encode(json_encode(['typ' => 'JWT', 'alg' => 'HS256']));
$payload = base64_encode(json_encode($data));
$signature = hash_hmac('sha256', "$header.$payload", $this->secretKey, true);
$signature = base64_encode($signature); return "$header.$payload.$signature";
} /**
* 解码 JWT
* @param string $jwt 要解码的 JWT
* @return stdClass|null 解码后的数据或 null
*/
private function decode($jwt)
{
$parts = explode('.', $jwt); if (count($parts) !== 3) {
return null;
} list($header, $payload, $signature) = $parts; $decodedSignature = base64_decode($signature);
$data = "$header.$payload";
$calculatedSignature = hash_hmac('sha256', $data, $this->secretKey, true); if (hash_equals($decodedSignature, $calculatedSignature)) {
return json_decode($base64_decode($payload));
} return null;
} /**
* 获取当前令牌的过期时间
* @return int|null 过期时间戳或 null(如果没有令牌)
*/
public function getExpiration()
{
return $this->expiration;
} /**
* 获取当前令牌
* @return string|null 当前令牌或 null(如果没有令牌)
*/
public function getToken()
{
return $this->token;
}
} // 使用示例
$secretKey = 'your-secret-key';
$token = new Token($secretKey); // 生成一个有效期为1小时的令牌
$newToken = $token->generateToken(3600);
echo "Generated Token: " . $newToken . PHP_EOL; // 验证令牌是否有效
$isValid = $token->validateToken($newToken);
echo "Is Token Valid: " . ($isValid ? 'Yes' : 'No') . PHP_EOL; // 获取令牌过期时间
$expiration = $token->getExpiration();
echo "Token Expiration: " . date('Y-m-d H:i:s', $expiration) . PHP_EOL;
解释
- 构造函数:接受一个
secretKey用于生成和验证令牌。 - 生成令牌:
generateToken方法生成一个新的 JWT 令牌,并设置其过期时间。 - 验证令牌:
validateToken方法验证给定的令牌是否有效。 - 编码和解码:
encode和decode方法用于 JWT 的编码和解码。 - 获取过期时间和令牌:提供
getExpiration和getToken方法来获取当前令牌的过期时间和令牌本身。
这个类使用 JWT(JSON Web Token)标准来生成和验证令牌。你可以根据具体需求进行扩展和修改。
php的token管理类(AI生成)的更多相关文章
- Java Token的原理和生成使用机制
在此之前我们先了解一下什么是Cookie.Session.Token 1.什么是Cookie? cookie指的就是浏览器里面能永久存储数据的一种数据存储功能.cookie由服务器生成,发送给浏览器, ...
- [转]3天搞定的小型B/S内部管理类软件定制开发项目【软件开发实战10步骤详解】
本文转自:http://www.cnblogs.com/jirigala/archive/2010/10/07/1845275.html 2010-10-07 21:39 by 通用C#系统架构, 5 ...
- Android wifi管理类:WifiAdmin
1.wifi的五种状态: WIFI_STATE_DISABLED WIFI网卡不可用 WIFI_STATE_DISABLING WIFI网卡正在关闭 WIFI_STATE_ENABLED ...
- xadmin站点管理类
9. Xadmin xadmin是Django的第三方扩展,比使用Django的admin站点更强大也更方便. 文档:https://xadmin.readthedocs.io/en/latest/i ...
- 利用StringList对象来管理这些动态生成的对象
如果程序需要动态创建大量的对象,那么我们可以利用StringList对象来管理这些动态生成的对象.1.创建StringList对象:OBJ := TStringList.Create; 2.保存动态生 ...
- 【Unity3D游戏开发】之全局管理类的几种方式 (十六)
如何在Unity中实现全局管理类?由于Unity脚本的运行机制和面向组件编程(COP)的思想,实现起来和普通的方式略有差别. 第一种方式是使用静态类.适合存储一些全局的变量,如游戏当前关卡.玩家得分等 ...
- Unity协程(Coroutine)管理类——TaskManager工具分享
博客分类: Unity3D插件学习,工具分享 源码分析 Unity协程(Coroutine)管理类——TaskManager工具分享 By D.S.Qiu 尊重他人的劳动,支持原创,转载请注明出处 ...
- FreeOnTerminate 的线程在线程管理类的Destroy释放时手工释放的问题
这个问题折腾了我整整一天. 有一个线程管理类,集中管理所有新建的线程, 线程统一在创建时标识 FreeOnTerminate 为 True. 因为有的线程是不限次循环的,所以在管理类最后 Destro ...
- C++智能指针管理类
1.程序员明确的进行内存释放 对于c++程序员,最头脑的莫过于对动态分配的内存进行管理了.c++在堆上分配的内存,需要程序员负责对分配的内存进行释放.但有时内存的释放看起来并不件很轻松的事,如下程序 ...
- GS LiveMgr心跳管理类
struct LiveMgr { private: int m_nCount; ///< 管理数量 std::vector<int> m_vecChannels; ///< 所 ...
随机推荐
- Jetpack Compose 的原理性文章
正在写一篇关于UI的思考,接触到 Android 的 Jetpack Compose: 从第一原则撰写 | 可理解的胡言乱语
- Qt编写视频监控系统77-Onvif组件支持非正常时间的设备
一.前言 在经历了大量的现场设备测试,至少几十种厂家.几百种设备,遇见过奇奇怪怪的问题,一个个想方设法解决,发现有个问题是在下发鉴权的时候,需要带上设备的时间,而不是发送端的时间,如果带的不是设备上的 ...
- 主打一个“小巧灵动”:Vite + Svelte
作者:来自 vivo 互联网大前端团队- Wei Xing 在研发小型项目时,传统的 Vue.React 显得太"笨重".本文主要针对开发小型项目的场景,谈谈 Vite+Svel ...
- POST、GET、@RequestBody和@RequestParam区别
参考链接: 1.POST.GET.@RequestBody和@RequestParam区别 2.@RequestBody的使用
- IM开发者的零基础通信技术入门(十一):为什么WiFi信号差?一文即懂!
一.本文内容概述 WiFi对于现在的家庭来说,属于司空见惯的上网方式,但很多情况下,家里房间多.空间大.杂物乱的情况下,WiFi的信号就受影响.为什么WiFi信号会受影响?什么情况下该使用何种方式组网 ...
- 如何禁止Chrome自动更新IDM扩展程序
背景是使用学习版IDM下载器,版本6.41.2,地址备份:https://github.com/glucyzz/IDM 下载完成后导入chrome浏览器,但是发现挂了小猫之后浏览器立马就把此插件自动更 ...
- C Primer Plus 第6版 第二章 编程练习参考答案
编译环境VS Code+WSL GCC /*第一题*************************/ #include<stdio.h> int main() { printf(&quo ...
- Jetbrains fleet 配置 C++开发环境(基于CMAKE和MinGW)
Jetbrains fleet 配置 C++开发环境 1. 安装 Jetbrains Fleet 到Fleet下载页面下载Toolbox并安装 Jetbrains-Fleet下载页 安装完成后在任务栏 ...
- 第四五章 (Nginx+Lua)Lua模块开发
在实际开发中,不可能把所有代码写到一个大而全的lua文件中,需要进行分模块开发:而且模块化是高性能Lua应用的关键.使用require第一次导入模块后,所有Nginx 进程全局共享模块的数据和代码,每 ...
- 使用badboy配合jmeter测试(详细)
工具 badboy2.2.5 jmeter 5.4.1 两个工具都必须是最新版,否则jmeter打开脚本的时候会报错 1.首先打开badboy,首页如下图 2.进入后就开始自动录制脚本,可以输入要测 ...