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; ///< 所 ...
随机推荐
- 配置 Forwarded Headers Middleware
来自微软的说明:Configure ASP.NET Core to work with proxy servers and load balancers | Microsoft Learn. 通过该中 ...
- ajax请求与前后端交互的数据编码格式
目录 一.Ajax AJAX简介 应用场景 AJAX的优点 语法实现 二.数据编码格式(Content-Type) 写在前面 form表单 几种数据编码格式介绍 三.ajax携带文件数据 四.ajax ...
- 【报错解决】【Linux】Name or service not known
# 配置文件位置 /etc/sysconfig/network-scripts/ # nano ifcfg-eth0查看网卡配置,确认dns已配置,且网关已配置 在虚拟机中添加临时路由网关(要与物理主 ...
- JVM实战—3.JVM垃圾回收的算法和全流程
大纲 1.JVM内存中的对象何时会被垃圾回收 2.JVM中的垃圾回收算法及各算法的优劣 3.新生代和老年代的垃圾回收算法 4.避免本应进入S区的对象直接升入老年代 5.Stop the World问题 ...
- Python中导入模块的import命令的语法
- 开源即时通讯IM框架MobileIMSDK的鸿蒙NEXT端开发快速入门
相关链接: ① MobileIMSDK-鸿蒙端的详细介绍 ② MobileIMSDK-鸿蒙端的开发手册new(* 精编PDF版) 一.理论知识准备 您需要对鸿蒙Next和ArkTS开发有所了解: 1 ...
- KMS for Office 2021
I. 镜像下载 官方镜像下载地址: Office 2021 专业增强版: https://officecdn.microsoft.com/pr/492350f6-3a01-4f97-b9c0-c7c6 ...
- OpenMMLab AI实战营 第四课笔记
OpenMMLab AI实战营 第四课笔记 目录 OpenMMLab AI实战营 第四课笔记 目标检测与MMDetection 1.什么是目标检测 1.1 目标检测的应用 1.1.1 目标检测 in ...
- No match for argument: kde-l10n-Chinese 报错
背景:安装 kde-l10n-Chinese 软件包报错 原因:该安装包适用于 centos7 系统,若为 centos8 则无法安装 解决办法:更换适配 centos 8 中文安装包 yum ins ...
- Solution - 「OurOJ #47407」巧立名目
\(\mathscr{Description}\) Private link. 给定一棵含有 \(n\) 个点的带点权树和大小为 \(m\) 的有序点对集合 \(\{(s_i,t_i)\}_{ ...