我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么使用Nginx和Lua进行JWT校验

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么使用Nginx和Lua进行JWT校验

这篇文章将为大家详细讲解有关怎么使用Nginx和Lua进行JWT校验,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

Lua脚本

这里的secret我遇到了很大的坑。一开始直接从Java后端项目中复制了密钥出来,但是一直提示signature mismatch:,后来发现后端应用中使用base64decode相关方法,在Lua脚本中增加了ngx.decode_base64(secret)处理secret后解决问题。其实到这里还没有解决问题,在后端debug代码的时候,发现后端密钥被decode的结果是一串乱码,为了避免乱码的问题,通过https://www.base64encode.org/重新生成secret才最终解决了问题。
如果你的项目中也遇到了这个signature mismatch:错误,需要排查一下后端在生成token的时候,是否有对secret进行decode或者其它处理,在lua脚本中也要进行相应的处理。

怎么使用Nginx和Lua进行JWT校验

nignx.conf配置

-- nginx-jwt.lualocal cjson = require "cjson"local jwt = require "resty.jwt"--your secretlocal secret = "yoursecrethere"--无需鉴权api清单local no_need_token_api_list = {'/api/register', '/api/login'}local function ignore_url (val)    for index, value in ipairs(no_need_token_api_list) do        if (value == val) then            return true        end    end    return falseendlocal M = {}function M.auth()    if ignore_url(ngx.var.request_uri) then        return    else    end    -- require Authorization request header    local auth_header = ngx.var.http_Authorization    if auth_header == nil then        ngx.log(ngx.WARN, "No Authorization header")        ngx.exit(ngx.HTTP_UNAUTHORIZED)    end    -- require Bearer token    local _, _, token = string.find(auth_header, "Bearer%s+(.+)")    if token == nil then        ngx.log(ngx.ERR, "Missing token")        ngx.exit(ngx.HTTP_UNAUTHORIZED)    end    --decode_base64和后端保持一致    local jwt_obj = jwt:verify(ngx.decode_base64(secret), token)    if jwt_obj.verified == false then        ngx.log(ngx.ERR, "Invalid token: ".. jwt_obj.reason)        ngx.status = ngx.HTTP_UNAUTHORIZED        ngx.say(cjson.encode(jwt_obj))        ngx.header.content_type = "application/json; charset=utf-8"        ngx.exit(ngx.HTTP_UNAUTHORIZED)    endendreturn M

Dockerfile配置

worker_processes 1;events{  worker_connections 1024;}http{  lua_package_path "/opt/lua-resty-jwt/lib/?.lua;;";  upstream backend  {    server 192.168.1.1:8080;  }    access_log /logs/nginx_access.log;  error_log /logs/nginx_error.log;  server  {    listen 80;    #后端api接口代理    location /api/    {      access_by_lua_block      {        local obj = require('nginx-jwt')        obj.auth()      }      proxy_pass http://backend;      proxy_redirect off;      proxy_set_header Host $host;      proxy_set_header X-Real-IP $remote_addr;      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;    }  }}

关于“怎么使用Nginx和Lua进行JWT校验”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么使用Nginx和Lua进行JWT校验

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么使用Nginx和Lua进行JWT校验

这篇文章将为大家详细讲解有关怎么使用Nginx和Lua进行JWT校验,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Lua脚本这里的secret我遇到了很大的坑。一开始直接从Java后端项目中复制了密钥出来
2023-06-22

怎么使用lua进行nginx redis访问控制

本篇内容介绍了“怎么使用lua进行nginx redis访问控制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 需求分析\1. Ngin
2023-06-27

使用Spring MVC怎么对参数进行校验

本篇文章为大家展示了使用Spring MVC怎么对参数进行校验,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. 内嵌异常处理如果只是这个controller的异常做单独处理,那么就适合绑定这个co
2023-05-31

使用SpringMVC怎么实现对数据进行校验

使用SpringMVC怎么实现对数据进行校验?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、导入jar包若要实现数据校验功能,需要导入必要的jar包,主要包括以下几个:c
2023-05-31

Golang怎么使用JWT进行认证和加密

这篇“Golang怎么使用JWT进行认证和加密”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Golang怎么使用JWT进行认
2023-07-05

Springboot怎么使用filter对request body参数进行校验

这篇文章主要为大家展示了“Springboot怎么使用filter对request body参数进行校验”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Springboot怎么使用filter对r
2023-06-29

怎么使用GoFrame校验对象和校验结构体

这篇文章主要介绍“怎么使用GoFrame校验对象和校验结构体”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用GoFrame校验对象和校验结构体”文章能帮助大家解决问题。基本概念数据校验组件提供
2023-07-02

怎么在Spring boot中利用validation进行校验

这篇文章主要为大家详细介绍了怎么在Spring boot中利用validation进行校验,文中示例代码介绍的非常详细,具有一定的参考价值,发现的小伙伴们可以参考一下:前言接触springboot一年多,是时候摆脱这种校验方式了233 ,每
2023-06-06

Vue怎么使用ElementUI对表单元素进行自定义校验

今天小编给大家分享一下Vue怎么使用ElementUI对表单元素进行自定义校验的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
2023-07-05

Java怎么使用责任链默认优雅地进行参数校验

本篇内容介绍了“Java怎么使用责任链默认优雅地进行参数校验”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言项目中参数校验十分重要,它可以
2023-07-05

hibernate-validator改进校验框架validator v0.4怎么使用

这篇文章主要讲解了“hibernate-validator改进校验框架validator v0.4怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“hibernate-validator
2023-07-05

怎么在Spring Boot项目中利用JSR-380进行校验

怎么在Spring Boot项目中利用JSR-380进行校验?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。介绍JSR-380 是 J2EE 的一个规范,用于校验实体属性,它是
2023-06-06

MySQL中怎么利用循环进行批量数据校验

在MySQL中,可以通过使用存储过程结合循环来进行批量数据校验。下面是一个示例:假设有一个表users,其中有一个字段age表示用户年龄,需要对年龄进行校验,年龄不能小于18岁。首先创建一个存储过程来进行数据校验:DELIMITER
MySQL中怎么利用循环进行批量数据校验
2024-04-30

怎么用windows自带的powershell进行文件哈希值校验

要使用Windows自带的PowerShell进行文件哈希值校验,可以按照以下步骤操作:打开PowerShell:在Windows搜索框中输入"PowerShell",然后点击"Windows PowerShell"打开。切换到你要校验的文
2023-10-21

怎么使用MATLAB进行假设检验

在MATLAB中,可以使用ttest函数来进行假设检验。ttest函数用于计算两个样本的t检验,其中包括单样本t检验和双样本t检验。1. 单样本t检验下面是一个例子,展示如何使用MATLAB进行单样本t检验的假设检验。```matlab%
2023-09-26

使用Nest.js怎么进行授权验证

这篇文章主要介绍了使用Nest.js怎么进行授权验证,此处通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下:0x0 前言系统授权指的是登录用户执行操作过程,比如管理员可以对系统进行用户操作、网站帖
2023-06-06

如何使用SQL语句在MySQL中进行数据校验和完整性约束?

如何使用SQL语句在MySQL中进行数据校验和完整性约束?数据校验和完整性约束是数据库管理系统中常用的方法,用于确保数据的正确性和完整性。在MySQL中,我们可以通过使用SQL语句来实现这些约束。本文将介绍如何使用SQL语句在MySQL中进
如何使用SQL语句在MySQL中进行数据校验和完整性约束?
2023-12-18

Node怎么运用Cookie和Session进行登录验证

本篇内容主要讲解“Node怎么运用Cookie和Session进行登录验证”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Node怎么运用Cookie和Session进行登录验证”吧!1️⃣ 定义
2023-07-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录