open-resty 服务安装jwt插件

作者:程序那点事儿 日期:2023/11/16 22:07


lua-resty-jwt 插件

如果想使用Lua识别用户令牌,我们需要引入lua-resty-jwt模块,是用于 ngx_lua 和 LuaJIT 的 Lua 实现库,在该模块能实现Jwt令牌生成、Jwt令牌校验。

下载好了该依赖库lua-resty-jwt-master.zip,我们将该库文件上传到服务器上,并解压,当然,我们也可以使用opm直接安装lua-resty-jwt

解压安装方式参考上面安装lua-resty-kafka,我们现在使用opm的安装方式

  1. yum install yum-utils #安装仓库管理工具包
  2. yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo #添加仓库地址
  3. yum install openresty-resty #安装resty
  4. yum install openresty-opm #安装opm
  5. opm get SkyLothar/lua-resty-jwt #安装Jwt组件
  6. 如果已经安装好OpenResty,跳过第2、3步(建议使用这种方式,如果代码clone不下来)。

添加一个案例访问

在前面kafka的案例中,我们已经创建了lua目录,现在我们就进入到lua目录开始。

  1. vim token.lua #封装一个token.lua脚本,以便复用

    --识别令牌
    --依赖resty.jwt库
    local jwt = require "resty.jwt"

    --定义一个模块
    local jwttoken = {}

    --秘钥
    local secret = "5pil6aOO5YaN576O5Lmf5q+U5LiN5LiK5bCP6ZuF55qE56yR"

    function jwttoken.check(auth_header)
    --响应信息
    local response = {}
    --令牌是否为空
    if auth_header == nil then
    response["code"] = 401
    response["message"] = "请登录"
    return response
    end
    --判断令牌格式 Bearer ,正确还要去掉Bearer
    local ,,token = string.find(auth_header, "Bearer%s+(.+)")
    if token == nil then
    response["code"] = 402
    response["message"] = "令牌无效"
    return response
    end

    复制代码
         --校验令牌是否正确
         local jwt_obj = jwt:verify(secret,token)
         if jwt_obj.verified == false then
                 response["code"] = 403
                 response["message"] = "令牌无效"
                 return response
         end
         --响应正确信息
         response["code"] = 200
         response["message"] = "令牌有效"
         response["body"] = jwt_obj
         return response

    end
    return jwttoken

  2. vim auth_verify.lua #创建auth_verify.lua脚本(对外访问)

    --判断测试令牌是否有效
    --设置编码utf8
    ngx.header.content_type="application/json;charset=utf8"

    --引入cjson库
    local cjson = require "cjson"
    --引入token库
    local jwttoken = require "token"

    --获取令牌(请求头中获取令牌)
    local auth_header = ngx.var.http_Authorization

    --调用token的check方法
    local result = jwttoken.check(auth_header)

    --将结果响应给客户端
    ngx.say(cjson.encode(result))

  3. vim ../conf/nginx.conf #添加配置

    复制代码
     #lua插件位置
     lua_package_path "/usr/local/openresty/nginx/lua/?.lua;/usr/local/openresty/modules/kafka/lib/?.lua;;";
     server {
         listen       80;
         server_name  localhost;
    
    
         location /token {
             content_by_lua_file /usr/local/openresty/nginx/lua/auth_verify.lua;
         }

本项目中自己写的lua脚本在/usr/local/openresty/nginx/lua/目录下,因为我们在该目录下写了两个lua脚本:auth_verify.lua,token.lua,在auth_verify.lua中引入了token.lua模块,所以别忘了在nginx.conf文件中添加如下配置,不然会报如下错误:

  1. nginx -s reload #重启ningx
  2. http://192.168.10.100/token #访问测试,结果如下
相关推荐
简单中的复杂9 小时前
【避坑指南】RK3576 Linux SDK 编译:解决 Buildroot 卡死在 host-gcc-final 的终极方案
linux·嵌入式硬件
wVelpro10 小时前
如何在Pycharm 2025.3 版本实现虚拟环境“Make available to all projects”
linux·ide·pycharm
larance10 小时前
Gunicorn + Nginx+systemd 配置flask
nginx·flask·gunicorn
程序员老舅10 小时前
C++高并发精髓:无锁队列深度解析
linux·c++·内存管理·c/c++·原子操作·无锁队列
雨中风华10 小时前
Linux, macOS系统实现远程目录访问(等同于windows平台xFsRedir软件的目录重定向)
linux·windows·macos
爱吃生蚝的于勒11 小时前
【Linux】进程信号之捕捉(三)
linux·运维·服务器·c语言·数据结构·c++·学习
The森11 小时前
Linux IO 模型纵深解析 01:从 Unix 传统到 Linux 内核的 IO 第一性原理
linux·服务器·c语言·经验分享·笔记·unix
文艺理科生Owen11 小时前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
运维·nginx
翼龙云_cloud11 小时前
腾讯云代理商: Linux 云服务器搭建 FTP 服务指南
linux·服务器·腾讯云
纤纡.11 小时前
Linux中SQL 从基础到进阶:五大分类详解与表结构操作(ALTER/DROP)全攻略
linux·数据库·sql