通过nginx弄一个滑块加图片的人机验证

2024-06-06 07:52

本文主要是介绍通过nginx弄一个滑块加图片的人机验证,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要通过 Nginx 实现滑块加图片的人机验证,你可以利用 OpenResty 和 Lua 脚本来生成并处理滑块验证码。滑块验证码的基本流程包括以下步骤:

  1. 生成带有缺口的图片
  2. 生成缺口图片
  3. 前端展示图片和滑块
  4. 用户滑动滑块到正确位置
  5. 服务器验证滑块位置

以下是一个示例的实现步骤:

1. 安装 OpenResty 和 Lua 库

首先,安装 OpenResty 和必要的 Lua 库。

# For Debian/Ubuntu
sudo apt-get install openresty# For CentOS/RHEL
sudo yum install openresty# Install LuaRocks
sudo apt-get install luarocks
sudo luarocks install lua-resty-string
sudo luarocks install lua-resty-random
sudo luarocks install gd

2. 配置 Nginx

编辑你的 nginx.conf 文件,添加以下配置:

worker_processes 1;events {worker_connections 1024;
}http {include       mime.types;default_type  application/octet-stream;server {listen       8080;server_name  localhost;location /captcha {content_by_lua_file /path/to/your/captcha.lua;}location /validate {content_by_lua_file /path/to/your/validate.lua;}}
}

3. 编写 Lua 脚本

captcha.lua:生成带有缺口的图片和缺口图片

local gd = require "resty.gd"
local random = require "resty.random"
local str = require "resty.string"local function generate_code()return math.random(100, 300) -- 随机生成一个缺口位置
endlocal function create_captcha()local img = gd.createFromPng("/path/to/your/background.png")local img_width, img_height = img:sizeXY()local gap_size = 50local gap_x = generate_code()local gap_y = img_height / 2 - gap_size / 2local gap_img = gd.createTrueColor(gap_size, gap_size)gap_img:copy(img, 0, 0, gap_x, gap_y, gap_size, gap_size)local white = img:colorAllocate(255, 255, 255)img:filledRectangle(gap_x, gap_y, gap_x + gap_size, gap_y + gap_size, white)local img_str = img:pngStr()local gap_img_str = gap_img:pngStr()return img_str, gap_img_str, gap_x
endlocal img_str, gap_img_str, gap_x = create_captcha()ngx.header.content_type = "application/json"
ngx.say('{"background":"'.. ngx.encode_base64(img_str) ..'", "gap":"'.. ngx.encode_base64(gap_img_str) ..'", "gap_x":'.. gap_x ..'}')

validate.lua:验证用户滑动的位置是否正确

local cjson = require "cjson"ngx.req.read_body()
local args = ngx.req.get_post_args()
local user_gap_x = tonumber(args.gap_x)-- 从 Redis 或其他存储中获取正确的 gap_x
local correct_gap_x = 150 -- 示例值,实际应从存储中获取if math.abs(user_gap_x - correct_gap_x) < 5 thenngx.say(cjson.encode({ success = true }))
elsengx.say(cjson.encode({ success = false }))
end

4. 前端代码

前端使用 JavaScript 实现滑块和图片展示:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>滑块验证码</title><style>.captcha-container {position: relative;width: 300px;height: 150px;}.captcha-image {width: 100%;height: 100%;}.slider {position: absolute;bottom: 10px;left: 0;width: 50px;height: 50px;background-color: #fff;border: 1px solid #ccc;cursor: pointer;}</style>
</head>
<body><div class="captcha-container" id="captcha-container"><img src="" id="captcha-image" class="captcha-image"><div id="slider" class="slider"></div></div><script>async function loadCaptcha() {const response = await fetch('/captcha');const data = await response.json();const bgImage = 'data:image/png;base64,' + data.background;const gapImage = 'data:image/png;base64,' + data.gap;document.getElementById('captcha-image').src = bgImage;// Render the gap image in a canvas or any other wayreturn data.gap_x;}document.addEventListener('DOMContentLoaded', async () => {const correctGapX = await loadCaptcha();const slider = document.getElementById('slider');let isDragging = false;let startX;slider.addEventListener('mousedown', (event) => {isDragging = true;startX = event.clientX;});document.addEventListener('mousemove', (event) => {if (isDragging) {const moveX = event.clientX - startX;slider.style.transform = `translateX(${moveX}px)`;}});document.addEventListener('mouseup', async (event) => {if (isDragging) {isDragging = false;const moveX = event.clientX - startX;const response = await fetch('/validate', {method: 'POST',headers: { 'Content-Type': 'application/json' },body: JSON.stringify({ gap_x: moveX })});const result = await response.json();if (result.success) {alert('验证成功');} else {alert('验证失败');}}});});</script>
</body>
</html>

5. 注意事项

  1. 路径配置:确保图片路径和 Lua 文件路径正确。
  2. 前端滑块:实际使用时可能需要更复杂的前端代码来处理滑块移动和验证逻辑。
  3. 存储机制:为了简单起见,示例代码没有实现存储机制。在实际应用中,可以使用 Redis 或其他存储系统来存储和验证 gap_x 值。
  4. 安全性:确保传输过程中数据的安全,防止恶意攻击和绕过验证。

通过这些步骤,你可以实现一个基本的滑块验证码系统。如果需要更复杂和高效的验证码系统,可以考虑使用现有的解决方案或服务。

这篇关于通过nginx弄一个滑块加图片的人机验证的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1035516

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Java JDK Validation 注解解析与使用方法验证

《JavaJDKValidation注解解析与使用方法验证》JakartaValidation提供了一种声明式、标准化的方式来验证Java对象,与框架无关,可以方便地集成到各种Java应用中,... 目录核心概念1. 主要注解基本约束注解其他常用注解2. 核心接口使用方法1. 基本使用添加依赖 (Maven

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

Nginx实现端口映射的示例代码

《Nginx实现端口映射的示例代码》本文主要介绍了Nginx实现端口映射的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1. 找到nginx的部署路径2. 备份原来的配置文件3. 编辑nginx.conf文件4. 在

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H