jwt-auth 的安装和配置教程
1. 项目的基础介绍和主要的编程语言
jwt-auth 是一个为 ThinkPHP 框架设计的 JSON Web Token(JWT)身份验证包。它支持通过 Header、Cookie、Param 等多种方式传递 JWT,并且提供了验证、刷新等多种中间件支持。此项目的主要编程语言是 PHP。
2. 项目使用的关键技术和框架
项目使用了 JWT(JSON Web Token)技术进行用户身份验证,这是一种基于 token 的身份验证方法,广泛应用于前后端分离的 Web 应用程序中。jwt-auth 集成了 ThinkPHP 框架,可以方便地在 ThinkPHP 应用中实现用户认证。
3. 项目安装和配置的准备工作和详细的安装步骤
准备工作
在开始安装 jwt-auth 之前,请确保您的开发环境满足以下要求:
- PHP 版本为 ~8.1.0 或 ~8.2.0
- ThinkPHP 框架版本为 ^5.1.10、^6.0.0 或 ^8.0.0
- 如果使用 2.x 版本的 jwt-auth,PHP 需要版本 8.1 以上,8.0 及以下请使用 1.x 版本
安装步骤
-
安装 jwt-auth
使用 Composer 安装 jwt-auth:
$ composer require thans/tp-jwt-auth -
生成配置文件
安装完成后,执行以下命令生成 jwt 的配置文件:
$ php think jwt:create这会生成
jwt.php和.env配置文件。注意,不建议直接修改jwt.php文件。 -
配置
.env文件在
.env文件中,将会随机生成一个secret。请确保不要随意更新此secret,并保证其安全性。 -
使用 jwt-auth 中间件
在需要验证的路由或模块中添加 jwt-auth 的中间件。例如:
use thans\jwt\facade\JWTAuth; // 获取 token $token = JWTAuth::builder([ 'uid' => 1 ]); // 执行 token 验证 JWTAuth::auth(); // 刷新 token JWTAuth::refresh(); // 获取请求中的完整 token 字符串 $tokenStr = JWTAuth::token()->get(); // 验证 token 并获取 payload $payload = JWTAuth::auth(); // 获取 payload 中的字段,例如 uid $uid = $payload['uid']; -
配置 Token 传参方式
在
jwt.php配置文件中,可以通过token_mode参数来调整 Token 的接收方式和优先级。默认值为['header', 'cookie', 'param']。根据你的应用需求,可以选择通过 URL 参数、Cookie 或 Header 传递 Token。建议使用 Header 方式传递 Token。
通过以上步骤,你就可以在 ThinkPHP 应用中安装并配置 jwt-auth 进行用户认证了。记得在实际使用中根据项目需求调整配置,并确保安全。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00