当前位置: 首页 > article >正文

从图标定位到相似度匹配:ddddocr与Siamese Network的验证码识别实战

1. 验证码识别技术现状与挑战图标验证码已经成为当前互联网安全防护的重要手段之一。相比传统的字符验证码图标验证码通过要求用户识别并点击特定图案的方式大幅提升了机器自动识别的难度。这类验证码通常包含多个相似图标需要用户根据提示选择正确的几个比如点击所有包含汽车的图片。在实际项目中我发现这类验证码主要带来三个技术挑战首先是图标定位问题需要准确找到每个图标在图片中的位置其次是相似度判断很多验证码会使用经过变形、旋转的相似图标最后是抗干扰能力验证码通常会添加噪点、扭曲等干扰因素。2. ddddocr与Siamese Network的技术组合2.1 ddddocr的精准定位能力ddddocr是一个开源的OCR识别库它最强大的功能之一就是目标检测。我在多个项目中实测发现对于各种变形的图标验证码ddddocr的detection模块能够以95%以上的准确率定位出图标位置。安装非常简单pip install ddddocr使用时只需要几行代码就能获取图标坐标import ddddocr det ddddocr.DdddOcr(detTrue) with open(captcha.png, rb) as f: image f.read() bboxes det.detection(image) # 返回图标坐标列表2.2 Siamese Network的相似度匹配孪生神经网络是专门设计用来比较两个输入相似度的特殊网络结构。它的核心思想是通过共享权重的双胞胎网络将输入映射到特征空间然后计算特征之间的距离。这种结构特别适合验证码识别场景因为不需要大量标注数据通过对比学习就能训练对图像变形、旋转等干扰有很强的鲁棒性可以直接输出相似度分数方便设置阈值3. 完整实战流程3.1 环境准备与安装建议使用conda创建独立的Python环境conda create -n captcha python3.8 conda activate captcha pip install ddddocr torch torchvision对于Siamese Network的实现我推荐使用PyTorch版本的代码库安装依赖git clone https://github.com/bubbliiiing/Siamese-pytorch cd Siamese-pytorch pip install -r requirements.txt3.2 数据预处理流程图标定位与裁剪使用ddddocr检测图标位置并保存为单独文件手动分类将裁剪后的图标按类别存放建议每个类别至少50个样本数据增强对样本少的类别进行增强数据增强代码示例增加旋转和噪声from PIL import Image import numpy as np import random def augment_image(img_path, output_dir): img Image.open(img_path) # 随机旋转 angle random.choice([0, 90, 180, 270]) rotated img.rotate(angle) rotated.save(f{output_dir}/rotated_{angle}.png) # 添加高斯噪声 img_arr np.array(img) noise np.random.normal(0, 10, img_arr.shape) noisy_img np.clip(img_arr noise, 0, 255).astype(np.uint8) Image.fromarray(noisy_img).save(f{output_dir}/noisy.png)3.3 模型训练技巧在Siamese Network训练过程中有几个关键参数需要特别注意输入图像大小建议统一调整为105x105像素Batch Size一般设置为32-64之间学习率初始设为0.001每10个epoch衰减一次训练轮数至少100轮才能达到较好效果训练命令示例python train.py --input_shape 105,105 --batch_size 32 --lr 0.001 --epochs 1004. 系统集成与优化4.1 完整识别流程实现将两个技术整合的完整代码框架class CaptchaRecognizer: def __init__(self, siamese_weights): self.detector ddddocr.DdddOcr(detTrue) self.siamese Siamese() self.siamese.load_weights(siamese_weights) def recognize(self, image_path): # 步骤1图标定位 with open(image_path, rb) as f: image f.read() bboxes self.detector.detection(image) # 步骤2图标裁剪 icons self._crop_icons(image_path, bboxes) # 步骤3相似度匹配 results [] for icon in icons: similarity self._compare_with_target(icon) results.append(similarity 0.9) # 阈值设为0.9 return results4.2 性能优化技巧图像预处理将彩色图像转为灰度可以提高10-15%的识别速度模型量化将PyTorch模型转为ONNX格式推理速度可提升2-3倍批量处理对多个验证码同时处理可以利用GPU并行计算优势ONNX转换代码示例import torch from siamese import Siamese model Siamese() model.load_weights(logs/best.pth) dummy_input torch.randn(1, 3, 105, 105) torch.onnx.export(model, dummy_input, siamese.onnx, input_names[input], output_names[output])在实际项目中这套技术组合已经帮助我实现了对多种复杂验证码的自动识别平均准确率达到92%以上。特别是在处理变形、旋转的图标验证码时Siamese Network的表现明显优于传统的分类模型。不过要注意的是验证码技术也在不断进化需要持续更新训练数据才能保持高识别率。

相关文章:

从图标定位到相似度匹配:ddddocr与Siamese Network的验证码识别实战

1. 验证码识别技术现状与挑战 图标验证码已经成为当前互联网安全防护的重要手段之一。相比传统的字符验证码,图标验证码通过要求用户识别并点击特定图案的方式,大幅提升了机器自动识别的难度。这类验证码通常包含多个相似图标,需要用户根据提…...

HUNYUAN-MT开源模型社区实践:参与Dify.AI应用开发与贡献

HUNYUAN-MT开源模型社区实践:参与Dify.AI应用开发与贡献 最近在折腾大语言模型应用开发的朋友,可能都绕不开一个名字:Dify.AI。它把那些复杂的模型调用、工作流编排、API管理都封装成了可视化的拖拽界面,让开发者能像搭积木一样快…...

Qwen3-ForcedAligner-0.6B企业应用:客服质检系统集成本地语音转写模块

Qwen3-ForcedAligner-0.6B企业应用:客服质检系统集成本地语音转写模块 1. 项目背景与价值 在客服质检领域,语音通话的准确转写和精细分析是提升服务质量的关键环节。传统方案往往依赖云端语音识别服务,存在数据安全风险、网络依赖性强、成本…...

Wan2.1-umt5多轮对话效果展示:模拟技术面试与深度调试对话

Wan2.1-umt5多轮对话效果展示:模拟技术面试与深度调试对话 最近在体验各种对话模型时,我特意找了一些需要深度思考和连续逻辑的场景来测试。今天想和大家聊聊Wan2.1-umt5这个模型,重点不是讲怎么部署,而是看看它在面对复杂、多轮…...

收藏 | 新手程序员快速入门:多模态大模型(MLLM)全解析

本文为有NLP、大模型基础知识的程序员提供了入门多模态大模型(MLLM)的全面指南。内容涵盖了MLLM的模型结构、训练数据、训练方法及评估方法,重点解析了模型结构和算法逻辑。文章对比了两种构建MLLM的主要方法:统一的Embedding解码…...

用VSCode替代Visual Studio开发C#:轻量级.NET开发环境搭建5分钟速成

用VSCode打造高效.NET开发环境:从零到精通的5分钟指南 在开发工具的选择上,轻量化与高效能往往难以兼得——直到VSCode的出现打破了这一局面。对于.NET开发者而言,Visual Studio固然功能全面,但其庞大的体积和资源占用常常成为追求…...

比迪丽LoRA部署教程:Ubuntu+Docker环境下GPU算力高效利用

比迪丽LoRA部署教程:UbuntuDocker环境下GPU算力高效利用 1. 前言:为什么选择这个方案? 如果你玩过AI绘画,肯定遇到过这样的烦恼:想画个特定角色,比如《龙珠》里的比迪丽,但用通用模型画出来的…...

CNN、RNN和自注意力机制:哪个更适合你的NLP任务?(附性能对比表)

CNN、RNN与自注意力机制:NLP任务中的三剑客实战指南 自然语言处理领域的技术迭代速度令人目不暇接,面对文本分类、机器翻译、情感分析等常见任务时,开发者往往陷入架构选择的困境。是选择老牌劲旅CNN/RNN,还是拥抱Transformer带来…...

手把手教你用VisionMaster SDK打造药盒字符检测系统(C#实战)

手把手教你用VisionMaster SDK打造药盒字符检测系统(C#实战) 在医药包装生产线上,药盒字符的准确识别直接关系到药品追溯系统的可靠性。传统人工抽检不仅效率低下,漏检率也居高不下。本文将带你用C#和VisionMaster SDK构建一套高精…...

TI电赛开发板驱动0.91寸OLED屏(SSD1306)移植实战:从引脚配置到显示验证

TI电赛开发板驱动0.91寸OLED屏(SSD1306)移植实战:从引脚配置到显示验证 最近在准备电赛项目,需要给TI的开发板(比如TMS320F28P550)加个小屏幕显示数据,0.91寸的OLED屏是个不错的选择&#xff0c…...

基于ESP32与ESP-NOW的智能门锁系统设计:双模块无线交互与多模态控制详解

基于ESP32与ESP-NOW的智能门锁系统设计:双模块无线交互与多模态控制详解 最近有不少朋友在问,想自己动手做一个智能门锁,但市面上的方案要么太贵,要么功能单一,能不能用ESP32做一个功能全面、成本可控的?正…...

ComfyUI配置管理与效率优化指南:从混乱到有序的实践之路

ComfyUI配置管理与效率优化指南:从混乱到有序的实践之路 【免费下载链接】ComfyUI-Manager 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Manager 问题发现:你的ComfyUI配置是否拖慢了工作流? 作为ComfyUI用户,…...

丹青识画系统黑马点评项目增强版:为商户照片添加智能标签与分类

丹青识画系统黑马点评项目增强版:为商户照片添加智能标签与分类 不知道你有没有用过那种本地生活或者美食点评平台?作为用户,我们经常会上传自己拍的餐厅环境或者美食照片,而商家为了吸引顾客,更是会精心拍摄并上传大…...

UEFI 进阶指南:深入理解Variable的跨阶段通信机制

1. UEFI Variable到底是什么? 第一次接触UEFI开发时,看到Variable这个概念我也是一头雾水。简单来说,Variable就是UEFI环境下的一种持久化存储机制,类似于Windows注册表或者Linux的sysfs。但它的独特之处在于可以在系统启动的各个…...

ClearerVoice-Studio在语音合成前端处理中的应用

ClearerVoice-Studio在语音合成前端处理中的应用 1. 引言 想象一下这样的场景:你正在用语音合成工具生成一段重要的演讲内容,但背景中隐约有键盘敲击声和空调的嗡嗡声,让生成的语音听起来总是不够专业。或者你需要在嘈杂的会议录音中提取清…...

收藏 | 产品经理/程序员入门大模型:AI知识库是RAG的“定海神针”!

一、 什么是 AI 知识库?它在 RAG 中扮演什么角色? 通俗理解:给大模型配一个“实时图书馆”如果把大模型比作一个参加考试的学生,那么普通的 LLM 是在“闭卷考试”,全凭记忆回答;而拥有 AI 知识库的 RAG 系统…...

Scala编程基础:从零开始掌握大数据开发语言

1. Scala简介:当Java遇上函数式编程 第一次接触Scala时,我被它简洁的语法震惊了。记得当时需要写一个简单的HTTP服务,用Java要20行代码,而Scala只需要5行。这种"代码减半"的魔法,正是Scala最迷人的特性之一…...

掌握Agent设计模式:小白程序员轻松入门,收藏提升技能!

本节目标 学完本课程后,你应该能够: 理解观察者模式在Agent中的应用掌握策略模式在Agent中的实现了解其他常用的Agent设计模式实现多种设计模式的综合应用 理论讲解 设计模式在Agent系统中的重要性设计模式是在软件设计中反复出现的问题的可重用解决方案…...

PyTorch图像增强实战:从torchvision.transforms基础到高级策略组合

1. 为什么图像增强是深度学习的秘密武器 第一次训练图像分类模型时,我遇到了一个令人沮丧的问题:模型在训练集上表现完美,但在测试集上准确率惨不忍睹。后来才发现,我的模型只是在死记硬背训练图片,完全没有学会真正的…...

程序员必懂的四种查找效率:O(1)、O(log n)、O(n)、O(k)

同样是查东西,为什么有人1秒,有人要1小时? 今天想和大家聊一个所有程序员都绕不开,但初学者往往一脸懵的概念——时间复杂度。 别被这个名词吓到,其实它就在我们身边。 看完今天这篇文章,你不仅能搞懂这些…...

阿里Qwen-Image-Edit-2511开箱即用:内置热门LoRA,无需调参直接出图

阿里Qwen-Image-Edit-2511开箱即用:内置热门LoRA,无需调参直接出图 1. 模型介绍 Qwen-Image-Edit-2511是阿里最新推出的图像编辑模型,作为Qwen-Image-Edit-2509的升级版本,它在多个关键领域实现了显著提升。这个模型最大的亮点在…...

15瓦至1000瓦完整量产版开关电源方案:含图纸、BOM、变压器及磁芯图纸,可直接生产

15瓦到1000瓦完整量产版开关电源方案,有图纸,bom,变压器和各种磁芯图纸,可以直接生产最近在搞开关电源量产方案的朋友有福了,这套从15W到1000W全覆盖的设计方案绝对能让你少掉几根头发。先说重点:整套方案已…...

Retinaface+CurricularFace在SpringBoot项目中的集成应用

RetinafaceCurricularFace在SpringBoot项目中的集成应用 1. 引言:企业级人脸识别的实际需求 在现代企业应用中,人脸识别技术已经广泛应用于门禁系统、考勤管理、身份验证等场景。传统的单机版人脸识别方案往往难以满足企业级应用的高并发、高可用需求。…...

3步解决中文文献管理难题:Jasminum插件提升80%科研效率

3步解决中文文献管理难题:Jasminum插件提升80%科研效率 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件,用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum 在中文文献管理…...

StructBERT语义匹配工具实测:本地运行+GPU加速,中文复述识别效果惊艳

StructBERT语义匹配工具实测:本地运行GPU加速,中文复述识别效果惊艳 你有没有遇到过这样的场景?需要判断两段中文文字是不是在说同一件事,或者想在海量文本里找出那些意思相近但表述不同的句子?比如,审核用…...

RexUniNLU效果展示:同一段政府公告文本的11种NLP任务结构化输出

RexUniNLU效果展示:同一段政府公告文本的11种NLP任务结构化输出 1. 系统概览:一站式中文NLP分析利器 RexUniNLU是一个基于ModelScope DeBERTa Rex-UniNLU模型的全功能中文自然语言处理系统。这个系统的最大特点是能够用同一个模型处理十多种不同的NLP任…...

Navicat连接PostgreSQL报错authentication method 10的深度排查与解决方案

1. 遇到Navicat连接PostgreSQL报错authentication method 10怎么办? 最近在帮朋友排查一个数据库连接问题,他用Navicat Premium 12连接PostgreSQL 12时,遇到了"authentication method 10 not supported"的错误提示。这个错误看起来…...

eSIM安全验证全解析:从EID到证书链的信任构建

1. eSIM安全验证的核心:EID与证书链的信任基石 第一次接触eSIM安全体系时,我被那一串串数字证书和验证规则搞得头晕眼花。直到在某个物联网项目中踩了坑才明白,这套机制就像我们现实生活中的身份证公章组合——EID相当于设备身份证号&#xf…...

基于CW32L031与SY7200AABC的308nm紫外线治疗仪DIY全流程解析

基于CW32L031与SY7200AABC的308nm紫外线治疗仪DIY全流程解析 最近身边有朋友聊起,家里有亲人需要用到308nm紫外线进行光疗,但医院治疗费用不菲,市面上的治疗仪价格也让人望而却步。作为一名嵌入式开发者,我就在想,能不…...

罗技PUBG压枪宏技术指南:从弹道控制到参数优化的实战方案

罗技PUBG压枪宏技术指南:从弹道控制到参数优化的实战方案 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 绝地求生(PUBG&…...