FastWeb网站开发之拦截器(interceptor)使用教程

作者 : admin 本文共709个字,预计阅读时间需要2分钟 发布时间: 2024-06-16 共1人阅读

拦截器用于拦截和处理HTTP请求和响应。在请求开始处理之前进行拦截过滤与处理。

API文档

拦截器一般用于初始化lua脚本中创建拦截规则。

它主要用于浏览器的请求中某些目录或文件不允许访问、某些目录需要验证权限,在拦截器中进行判断并选择是否继续向下执行。

  • 拦截器为应用全局变量,任意位置均可访问
  • 与订阅一样可以使用requestresponse用于处理与回复

要求

  • 必须返回bool型变量:true = 允许并继续,false = 终止请求

示例

api/init/interceptor.lua

-- 验证是否为禁止的路径
local function is_denied()
    -- 禁止访问的路径
    local denied_path = {
        -- session作为会话存储目录
        "/session",
        -- /api/init 存放的初始化代码等
        "/api/init",
    }
    -- 获取请求路径
    local request_filepath = request:filepath()
    -- 遍历禁止路径
    for _, path in ipairs(denied_path) do
        if request_filepath:sub(1, #path) == path then
            return true
        end
    end
    return false
end

if is_denied() then
    return false
end

-- 没有需要禁止的路径
return true

api/init/init.lua

----------拦截器示例-------------
-- 拦截所有请求
interceptor.add("/*.*","/api/init/interceptor.lua")
-- 输出初始化成功
print("init ok")
return true

本站无任何商业行为
个人在线分享 » FastWeb网站开发之拦截器(interceptor)使用教程
E-->