服务器端Openresty的Lua 脚本动态生成 HTML 页面

使用服务器端的 Lua 脚本来动态生成 HTML 页面,并在生成页面时传递重定向参数。这种方法不涉及客户端 JavaScript,而是在服务器端完成重定向参数的设置。

以下是修改后的示例:

nginx 复制代码
# 人机验证页面
location /captcha {
    default_type 'text/html';
    content_by_lua_block {
        local redirect_to = ngx.var.arg_redirect_to or "/"
        ngx.print([[
            <!DOCTYPE html>
            <html lang="en">
            <head>
                <meta charset="UTF-8">
                <meta name="viewport" content="width=device-width, initial-scale=1.0">
                <title>CAPTCHA Verification</title>
                <script src="https://www.google.com/recaptcha/api.js" async defer></script>
            </head>
            <body>
                <form action="/verify_captcha" method="POST">
                    <div class="g-recaptcha" data-sitekey="your_site_key"></div>
                    <br/>
                    <input type="hidden" name="redirect_to" value="]] .. redirect_to .. [[">
                    <input type="submit" value="Submit">
                </form>
            </body>
            </html>
        ]])
    }
}

这样,无论用户是否启用 JavaScript,页面都能正常工作。同时,服务器端代码也更加简洁明了,不需要在客户端执行 JavaScript。

相关推荐
Aric_Jones40 分钟前
lua入门语法,包含安装,注释,变量,循环等
java·开发语言·git·elasticsearch·junit·lua
万山y10 小时前
OpenResty反向代理
openresty
积极向上的龙10 小时前
首屏优化,webpack插件用于给html中js自动添加异步加载属性
javascript·webpack·html
小堃学编程14 小时前
前端学习(1)—— 使用HTML编写一个简单的个人简历展示页面
前端·javascript·html
Petrichorzncu16 小时前
Lua再学习
开发语言·学习·lua
航Hang*19 小时前
前端项目2-01:个人简介页面
前端·经验分享·html·css3·html5·webstorm
mikey棒棒棒20 小时前
lua脚本+Redission实现分布式锁
redis·分布式·lua·看门狗·redission
水银嘻嘻20 小时前
Web 自动化之 HTML & JavaScript 详解
前端·自动化·html
良木林1 天前
HTML难点小记:一些简单标签的使用逻辑和实用化
前端·html
weixin_428498491 天前
在Lua中使用轻量级userdata在C/C++之间传递数据和调用函数
c语言·c++·lua