laravel的passport和jwt的区别

laravel的passport和jwt的区别

简介

Passport是一个Node.js中间件,它提供了易于实现的各种不同的请求身份验证策略。默认情况下,它将用户对象存储在会话中。    (推荐学习:laravel开发)

JSON Web令牌是一种身份验证标准,通过在有助于识别登录用户的请求中分配和传递加密令牌,而不是将用户存储在服务器上的会话中并创建cookie来工作。它有不同的集成,包括Node.js模块。

安装依赖项。

npm install --save koa-passport  passport-jwt jsonwebtoken

流程

当用户登录时,后端会创建签名令牌并将其作为响应返回

客户端在本地保存令牌(通常在localStorage中),并在每个需要身份验证的后续请求中将其发回

所有需要身份验证的请求都会通过中间件检查提供的令牌,并且只有在验证令牌时才允许请求

魔乐社区 魔乐社区

天翼云和华为联合打造的AI开发者社区,支持AI模型评测训练、全流程开发应用

魔乐社区 102 查看详情 魔乐社区

登录时token

/** * @route POST api/users/login * @desc 用户登录接口 * @access 都可访问 */router.post('/login', async ctx => {    //...获取数据 验证数据省略        const payload = {            name: user.name,            email,            avatar: user.avatar        };        //生成token        const token = jwt.sign(payload, config.secretKey, {            expiresIn: 3600 //存活时间        });        ctx.status = 200;        ctx.body = {            message: '验证成功',            token: 'Bearer ' + token        }})

注: ‘Bearer ‘中间必须有个空格,大小写也区分…

登录解析Token

/** * @route GET api/users/current * @desc 获取用户信息 * @access 私密接口 */ //poassport.authenticate 则加入了认证权限,会调用 passport.js中router.get('/current',passport.authenticate('jwt', { session: false }),async ctx=>{//获取 passport.js 中的返回值,去除密码并将结果返回到客户端    const {password,...userInfo}=ctx.state.user._doc;    ctx.body=userInfo;})//app.jsconst passport = require('koa-passport');app.use(passport.initialize())app.use(passport.session())//调用 passport.js 并将passport传入require('./config/passport')(passport);

config/passport.js

const config=require('./default');const JwtStrategy = require('passport-jwt').Strategy,    ExtractJwt = require('passport-jwt').ExtractJwt;const opts = {}opts.jwtFromRequest = ExtractJwt.fromAuthHeaderAsBearerToken();opts.secretOrKey = config.secretKey;// const User=require('../models/User');const mongoose=require('mongoose');const User=mongoose.model('users');module.exports=passport=>{    passport.use(new JwtStrategy(opts,async (jwt_payload,done)=>{    //jwt_payload 返回的是登录时返回的数据 即payload        const user=await User.findOne(jwt_payload.id);        if(user){            done(null,user);        }else{            done(null,false);        }    }))}

ps. 这是用户登录模板完整代码

app.js

const Koa=require('koa');const KoaRouter=require('koa-router');const bodyParser=require('koa-bodyparser');const mongoose=require('mongoose');//const config=require('./config/default')const passport = require('koa-passport');//配置文件 这里就不单独抽离const config={mogoUrl:'mongodb://localhost/koaTest',    secretKey:'sercretKey',}const router=new KoaRouter();const app=new Koa();app.use(bodyParser());//初始化 passportapp.use(passport.initialize())app.use(passport.session())//连接数据库mongoose.connect(config.mogoUrl,{    useNewUrlParser:true}).then(res=>{    console.log('mongoose connectd...');}).catch(error=>{    console.log(error)})//引入 user.jsconst user=require('./routes/api/user');require('./config/passport')(passport);//配置路由地址router.use('/api/users',user);//配置路由app.use(router.routes()).use(router.allowedMethods());const port=process.env.PORT||5000;//监听端口app.listen(port,()=>{    console.log(`listing at ${port}`)})

routes/api/user.js

var Router = require('koa-router');var router = new Router();const User = require('../../models/User')const bcrypt = require('bcryptjs');const tools = require('../../config/tools')const jwt = require('jsonwebtoken'); //token 认证const config = require('../../config/default');const passport=require('koa-passport');/** * @route POST api/users/login * @desc 用户登录接口 * @access 都可访问 */router.post('/login', async ctx => {    const {        email,        password    } = ctx.request.body;    const findResult = await User.find({        email    });    const user = findResult[0];    if (findResult.length === 0) {        //表示不存在该用户        ctx.status = 404;        ctx.body = {            message: '该用户不存在'        };        return;    }    //验证密码是否正确    const verify = bcrypt.compareSync(password, user.password);    if (verify) {        //密码正确        const payload = {            name: user.name,            email,            avatar: user.avatar        };        //生成token        const token = jwt.sign(payload, config.secretKey, {            expiresIn: 3600        });        ctx.status = 200;        ctx.body = {            message: '验证成功',            token: 'Bearer ' + token        }    } else {        ctx.status = 500;        ctx.body = {            message: '密码错误'        };    }})/** * @route GET api/users/current * @desc 获取用户信息 * @access 私密接口 */router.get('/current',passport.authenticate('jwt', { session: false }),async ctx=>{    const {password,...userInfo}=ctx.state.user._doc;    ctx.body=userInfo;})module.exports = router.routes();

以上就是laravel的passport和jwt的区别的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/212222.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月3日 13:13:04
下一篇 2025年11月3日 13:14:06

相关推荐

  • 在Laravel Blade中正确使用Vite加载模块化JS与CSS资源

    本文旨在解决laravel应用中,特别是在使用模块化结构(如nwidart/laravel-module)时,通过vite加载前端js和css资源时遇到的404错误。核心内容是阐明`asset()`函数与vite指令的区别,并详细指导如何使用`@vite` blade指令及其正确路径配置,确保模块内…

    2025年12月21日
    000
  • Laravel模块化开发中Vite资源加载指南:解决Blade文件404错误

    本教程旨在解决在laravel模块化开发中,使用vite加载javascript和css资源时遇到的404错误。文章将深入探讨传统方法失败的原因,并详细介绍如何通过laravel提供的@vite blade指令,正确且高效地在blade模板中引入模块化vite资产,确保开发和生产环境下的资源路径解析…

    2025年12月21日
    000
  • Laravel Blade中Vite资产加载指南:解决模块化项目中的404错误

    本文旨在解决laravel blade模板中,尤其是在模块化项目中,使用vite加载javascript和css资源时遇到的404错误。我们将深入探讨传统方法失效的原因,并详细介绍如何通过laravel提供的`@vite` blade指令正确地集成和管理vite处理的资产,确保资源能够被成功编译和引…

    2025年12月21日
    000
  • Laravel模块中Vite资产加载指南

    本文详细介绍了在Laravel应用,特别是Nwidart模块中,如何正确使用Vite加载JavaScript和CSS资源。针对直接链接导致404错误的问题,教程阐明了Vite的工作原理,并提供了通过`@vite` Blade指令引用模块内资源的正确方法,确保开发流程顺畅,避免资源加载失败。 理解La…

    2025年12月21日
    000
  • 在Create React App项目中启用实验性装饰器语法

    本文旨在解决在Create React App (CRA) 项目中使用实验性装饰器语法时遇到的`Support for the experimental syntax ‘decorators’ isn’t currently enabled`错误。通过引入`cus…

    2025年12月21日
    000
  • Laravel AJAX点赞系统500错误:路由参数传递深度解析

    本文深入探讨laravel ajax点赞系统中常见的500错误,尤其关注`route()`辅助函数在javascript中传递参数不当导致的问题。通过详细分析错误原因,提供两种有效解决方案:使用数组正确传递路由参数,或采用字符串拼接方式构建url。旨在帮助开发者避免此类常见陷阱,确保前后端交互的流畅…

    2025年12月20日
    000
  • 在Laravel应用中实现动态加载器:优化慢速视图渲染的用户体验

    当laravel应用因后端验证和数据获取导致视图渲染缓慢时,用户常面临空白等待。本文将介绍如何通过ajax技术,在视图决定渲染前立即显示加载器,从而显著提升用户体验。通过先返回一个轻量级加载页面,然后异步调用实际处理逻辑,确保用户获得即时反馈,有效缓解等待焦虑,为后端优化争取时间。 在现代Web应用…

    2025年12月20日
    000
  • 提升Laravel应用用户体验:在视图渲染前显示加载器

    当Laravel应用面临复杂视图因后端验证和数据获取耗时而加载缓慢时,为了即时改善用户体验,可以在视图决定和渲染完成前显示一个加载器。本文将详细介绍如何利用AJAX技术实现这一目标:首先,前端页面快速呈现加载动画;随后,通过异步请求触发后端处理流程;一旦后端操作成功,再进行页面重定向或内容更新,从而…

    2025年12月20日
    000
  • Laravel AJAX路由参数传递陷阱与500错误排查指南

    本文深入探讨了在laravel ajax应用中,因路由参数传递不当导致500错误的常见问题。重点分析了`route()`辅助函数在处理单个动态参数时的易错点,并提供了两种有效的解决方案:将参数封装为数组传递,或将路由名称与参数分别拼接。此外,文章还强调了调试此类问题的关键步骤和最佳实践,旨在帮助开发…

    2025年12月20日
    000
  • 深入解析Laravel AJAX点赞系统500错误:路由参数传递的陷阱与修复

    本文深入探讨laravel ajax点赞系统遭遇500错误的原因,尤其聚焦于blade模板中`route()`辅助函数参数传递的常见误区。通过对比错误的url生成方式与两种正确的解决方案,指导开发者如何精确地将动态参数传递给laravel路由,从而有效解决因路由参数解析失败导致的服务器内部错误,确保…

    2025年12月20日
    000
  • 解决Laravel AJAX点赞系统中的500错误:路由参数传递详解

    本文详细阐述了在Laravel AJAX点赞系统中遇到500错误时的排查与解决策略,核心聚焦于`route()`辅助函数在JavaScript中传递路由参数的正确方法。通过提供两种修正方案,并结合实际代码示例,帮助开发者避免常见的参数传递错误,确保AJAX请求顺利执行,提升应用稳定性。 在构建现代W…

    2025年12月20日
    000
  • Laravel AJAX点赞系统500错误排查与解决:路由参数传递最佳实践

    本文深入探讨了laravel ajax点赞系统中常见的500服务器错误,特别是由于路由参数传递不当所引发的问题。通过对比错误的javascript `route()` helper用法与正确的参数数组传递方式,本教程指导开发者如何规范地构建ajax请求url,确保参数被laravel路由正确解析,从…

    2025年12月20日
    000
  • Laravel路由参数缺失问题解析与最佳实践

    本文深入探讨了Laravel应用中常见的路由参数缺失错误,特别是当路由定义了具名参数而 route() 辅助函数调用时未能正确传递参数名时引发的问题。通过分析错误根源并提供两种正确的参数传递方式,旨在帮助开发者理解并有效解决此类路由错误,确保应用导航的流畅性与准确性。 理解Laravel路由参数 在…

    2025年12月20日
    000
  • 解决 Laravel 路由参数缺失问题的教程

    本文旨在解决 Laravel 应用中常见的“Missing required parameter”路由错误。当路由定义中包含参数(如{user})而route()辅助函数调用时未能提供正确匹配的参数名时,此错误便会发生。我们将深入分析问题根源,并提供两种有效的解决方案,确保路由参数的正确传递,从而避…

    2025年12月20日
    000
  • Laravel 路由参数缺失问题排查与解决:以会话功能为例

    本文针对 Laravel 开发中常见的 “Missing required parameter” 路由错误,以一个会话功能为例,详细讲解了如何排查错误原因并提供解决方案。重点分析了路由定义、URL 生成以及控制器参数传递等环节,帮助开发者避免类似问题,确保应用的正常运行。 在…

    2025年12月20日
    000
  • 告别重复:使用Laravel Precognition统一前后端API验证

    本文旨在解决在Laravel后端与前端API交互中,如何高效复用后端验证规则的挑战。传统方案常限于表单元素,难以覆盖所有API请求。通过引入Laravel Precognition,开发者能够实现后端验证逻辑在前端的无缝应用,避免规则重复编写,从而提升开发效率与代码一致性,确保所有API请求的数据完…

    2025年12月20日
    000
  • HTML表单中JavaScript不执行的调试与解决方案

    本文深入探讨HTML表单中JavaScript不执行的常见原因及解决方案。我们将重点讲解DOM元素ID匹配的重要性、如何阻止表单的默认提交行为,以及利用事件监听器(包括原生JavaScript和jQuery)确保脚本正确执行,从而实现提交成功提示等交互功能。 在开发web表单时,我们经常需要通过ja…

    2025年12月20日
    000
  • HTML表单JavaScript交互:成功消息显示与表单处理指南

    本文旨在解决HTML表单中JavaScript代码不运行,特别是无法正确显示提交成功消息的问题。我们将深入分析常见的错误原因,如DOM元素ID不匹配和表单默认提交行为,并提供纯JavaScript和jQuery两种解决方案,确保用户提交表单后能够即时获得反馈,提升交互体验。 HTML表单JavaSc…

    2025年12月20日
    000
  • 解决Fancybox模态框中TikTok视频嵌入后消失的问题

    本教程详细阐述了在Fancybox模态框中嵌入TikTok视频时,视频立即消失的问题。该问题源于TikTok嵌入脚本误删自身iframe的行为。解决方案是利用MutationObserver动态插入一个“占位”元素,以确保TikTok脚本在模态框加载时删除的是占位符而非实际视频iframe,从而实现…

    2025年12月20日
    000
  • React 应用管理员面板构建:从本地 JSON 到生产级数据管理

    本文旨在指导React应用开发者如何为电商网站等应用构建管理员面板,以实现数据(如商品卡片)的增删改查。文章将探讨从本地JSON文件管理的局限性,到利用浏览器端文件下载模拟数据更新的临时方案,再到后端服务和无头CMS(如Strapi)等生产级解决方案,帮助开发者选择最适合其项目需求的数据管理策略。 …

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信