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

相关推荐
bank_dreamer33 分钟前
VSCODE前端代码风格格式化
前端·css·vscode·html·js·prettier·代码格式化
烤汉堡2 小时前
Python入门到实战:post请求和响应
python·html
合作小小程序员小小店2 小时前
网页开发,在线%宠物论坛管理%系统,基于eclipse,html,css,jquery,servlet,jsp,sql server数据库。
java·sqlserver·eclipse·jdk·html·intellij-idea
BUG创建者3 小时前
项目中使用script-ext-html-webpack-plugin
前端·webpack·html
小莫分享4 小时前
Github Action 一键部署HTML 静态服务
前端·html·github
じòぴé南冸じょうげん8 小时前
若依框架favicon.ico缓存更新问题解决方案:本地生效但线上未更新
前端·javascript·前端框架·html
这人很懒没留下什么16 小时前
SpringBoot2.7.4整合Oauth2
开发语言·lua
骨子里的偏爱18 小时前
【案例】uniapp实现内部信息与外部的html网页双向通信的完整的过程,附加完整的代码部分
前端·uni-app·html
BBB努力学习程序设计1 天前
Web App开发基础知识:从零构建现代化Web应用
前端·html
BBB努力学习程序设计1 天前
使用Bootstrap框架搭建简单页面:快速构建现代化网站
前端·html