服务器端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。

相关推荐
xingyynt1 小时前
【HTML+CSS】使用HTML与后端技术连接数据库
css·数据库·html
難釋懷2 小时前
OpenResty快速入门
junit·openresty
AI-小柒2 小时前
DataEyes聚合平台新API接入实战指南:从0到1打通实时数据链路
大数据·运维·开发语言·人工智能·python·自动化·lua
PieroPc3 小时前
电脑DIY组装报价系统 用MiMo V2 Pro 写html ,再用opencode(选MiMo 作模型) 当录入口
前端·html
工程师老罗3 小时前
lvgl有哪些布局?
前端·javascript·html
wl85114 小时前
SAP HCM 公积金超过上限后的计税方案
前端·html
佳木逢钺4 小时前
[特殊字符] 全栈机器人工程师的“三十维接入”主控台
网络·机器人·html
weixin_666593994 小时前
一门“小”语言,如何让遥感时空平台触及性能天花板?
开发语言·lua
難釋懷15 小时前
Lua语法入门-条件控制、函数
开发语言·junit·lua
lightqjx21 小时前
【前端】前端学习一之HTML从入门到精通
前端·学习·html