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

32-字体反爬

本文需要借助工具fontcreator或者在线网站字体设计在线网站字体反爬介绍字体反爬是网站常用的前端反爬手段核心逻辑是用自定义字体文件替代明文文本爬虫自动化也无法拿到正确的明文数据字体反爬原理本文主要讲解的是css层面的字体反爬css中定义自定义字体的规则叫做font-face 规则通过font-face这个标签会读取字体文件字体文件中会有对应的映射关系然后通过映射关系将密文字体转化为明文字体反爬解决方法以及步骤解决方法1.找字体映射关系找到字体文件发现字体文件中映射关系少且不变可以自己手写映射关系当网页字体映射关系会变时需要找规律找出文字映射关系变化逻辑很难需要对字体有很深的研究现在也可以拿下来十个八个文件丢给ai让ai找规律2.通过坐标描画文字然后用识别库识别来写出映射关系orc识别3.通过on极少用解决步骤我们这里主要讲第二种解决方法的步骤案例地址shixi僧↑字体文件第一步通过请求拿到字体文件并转换通过请求拿下来字体文件然后保存到本地转换成xmlxml是结构化数据可以直接用.key(拿到标签)也可以用xpath语法源码文件需注意两个标签cmap主要是到时候对应网站上的’乱码’和我们字典中的key替换’乱码’为正常的字glyf中的contour主要是坐标与直曲线到时按此画图然后识别出文字第二步封装画图加识别的py文件首先读取文件# 解析xml所需库 from lxml import etree # 读取xml文件xml文件里会有声明:?xml version1.0 encodingUTF-8?需要解码:f.read().encode(utf-8) with open(字体文件.xml, r, encodingutf-8) as f: xml_code f.read().encode(utf-8) # 解析xml文件fromstring直接处理xml文件转换为字符串 font_parser etree.fromstring(xml_code)然后xpath解析提取以及整理名字和坐标# xpath语法提取坐标列表 TTGlyph_list font_parser.xpath(//glyf/TTGlyph) # print(TTGlyph_list) x_y_list [] for TTGlyph in TTGlyph_list[1:-1]: # print(TTGlyph) if TTGlyph.xpath(./contour[1]): # print(contour中有数据) font_name TTGlyph.xpath(./name) # 拿到名字即网页字体乱码的映射 contour_list TTGlyph.xpath(./contour[1]) # 这里是内存地址 # 循环提取contour然后用xpath提取x y坐标值 for contour in contour_list: x_y [(x, y) for x, y in zip(contour.xpath(./pt/x), contour.xpath(./pt/y))] # 这里zip是将x y循环得出的每一个对应位置的元素绑在一起 # 画图需要首尾相连此处将第一个坐标写入列表尾部 x_y.append(x_y[0]) # print(x_y) # 将所有文字装进一个列表 x_y_list.append(x_y) # print(x_y_list)然后画图并保存# 画图 plt.figure(figsize(10, 10)) # 创建一个画布figsize(10, 10)表示画布的宽和高都是 10 英寸 # 遍历每个图案 for shape in x_y_list: x, y zip(*[(int(point[0]), (int(point[1]))) for point in shape]) # *是解包运算符将元组解包再用zip重新分配 # print(x, y) # 绘制多边形 plt.plot(x, y, markero) # 连接点的多边形 plt.fill(x, y, alpha0.3) # 填充多边形 # 隐藏刻度标签 plt.xticks([]) plt.yticks([]) # 设置绘图属性 plt.axis(equal) # 坐标轴比例一致 plt.grid(True) # 保存图片 plt.savefig(图片/ f{font_name}.png)通过ddddocr库识别图片ocr ddddocr.DdddOcr() with open(图片/ f{font_name}.png, rb) as f: image f.read() res ocr.classification(image) print(res)封装此文件成类方便主py文件调用# 解析xml所需库 from lxml import etree import matplotlib # 画图库 matplotlib.use(TkAgg) import matplotlib.pyplot as plt # 识别图片的库 import ddddocr class PaintIdentify: def __init__(self, file_path): self.file_path file_path # 传递xml文件地址 def parse_file(self, TTGlyph): if TTGlyph.xpath(./contour[1]): x_y_list [] # print(contour中有数据) font_name TTGlyph.xpath(./name) # 拿到名字即网页字体乱码的映射 contour_list TTGlyph.xpath(./contour) # 这里是内存地址 # 循环提取contour然后用xpath提取x y坐标值 for contour in contour_list: x_y [(x, y) for x, y in zip(contour.xpath(./pt/x), contour.xpath(./pt/y))] # 这里zip是将x y循环得出的每一个对应位置的元素绑在一起 # 画图需要首尾相连此处将第一个坐标写入列表尾部 x_y.append(x_y[0]) # print(x_y) # 将所有文字装进一个列表 x_y_list.append(x_y) self.paint(x_y_list, font_name) res self.identify(font_name) return (font_name[0], res) return None def paint(self, x_y_list, font_name): # 画图 plt.figure(figsize(10, 10)) # 创建一个画布figsize(10, 10)表示画布的宽和高都是 10 英寸 # 遍历每个图案 for shape in x_y_list: x, y zip(*[(int(point[0]), (int(point[1]))) for point in shape]) # *是解包运算符将元组解包再用zip重新分配 # print(x, y) # 绘制多边形 plt.plot(x, y, markero) # 连接点的多边形 plt.fill(x, y, alpha0.3) # 填充多边形 # 隐藏刻度标签 plt.xticks([]) plt.yticks([]) # 设置绘图属性 plt.axis(equal) # 坐标轴比例一致 plt.grid(True) # 保存图片 plt.savefig(图片/ f{font_name}.png) def identify(self, font_name): ocr ddddocr.DdddOcr() with open(图片/ f{font_name}.png, rb) as f: image f.read() res ocr.classification(image) return res def main(self): name_character_dic {} # 读取xml文件xml文件里会有声明:?xml version1.0 encodingUTF-8?需要解码:f.read().encode(utf-8) with open(self.file_path, r, encodingutf-8) as f: xml_code f.read().encode(utf-8) # 解析xml文件fromstring直接处理xml文件转换为字符串 font_parser etree.fromstring(xml_code) # xpath语法提取坐标列表 TTGlyph_list font_parser.xpath(//glyf/TTGlyph) for TTGlyph in TTGlyph_list[1:-1]: key, value self.parse_file(TTGlyph) name_character_dic[key] value return name_character_dic if __name__ __main__: paint_identify PaintIdentify(字体文件.xml) paint_identify.main()第三步导入封装库导入模块按自己的py文件运行入口的写法写就行第四步根据网页需要的数据进行匹配经过观察所需的数据来对我们字体映射名来进行调整然后替换到我们所需的数据中小结本文就到此结束关键步骤已经列出如有问题及时提出一起讨论加油加油

相关文章:

32-字体反爬

本文需要借助工具:fontcreator,或者在线网站:字体设计在线网站 字体反爬介绍 字体反爬是网站常用的前端反爬手段,核心逻辑是用自定义字体文件替代明文文本,爬虫自动化也无法拿到正确的明文数据 字体反爬原理 本文主…...

无障碍技术实践:OpenClaw+Phi-3-vision-128k-instruct为视障用户描述图片

无障碍技术实践:OpenClawPhi-3-vision-128k-instruct为视障用户描述图片 1. 项目背景与动机 去年冬天的一次地铁站经历让我萌生了这个想法。当时我看到一位视障朋友在站台反复用盲杖试探前方障碍物,而墙上明明贴着"施工绕行"的警示海报。这个…...

三种常见AC/DC转换方案详解与选型指南

1. 交流转直流方案概述在电子设备设计中,将交流电转换为直流电是最基础也是最重要的环节之一。作为一名硬件工程师,我在过去十年里接触过各种AC/DC转换方案,从简单的阻容降压到复杂的开关电源设计。这些方案各有特点,适用于不同的…...

已登CVPR&Nature子刊,小波变换+深度学习杀疯了 !!

融合小波变换的深度学习模型是当前的研究热点之一,这个交叉领域热度高、前景好、创新空间大,只要选对结合点和方法,冲顶会顶刊问题不大。比如Transformer、GNN、KAN、CNN、mamba等,就是目前比较前沿而且热度很高的结合方式&#x…...

AUTOSAR Ethernet Stack深度解析,手把手实现SOME/IP序列化、DDS桥接与时间同步校准

第一章:AUTOSAR以太网协议栈架构概览AUTOSAR以太网协议栈是面向汽车电子域控制器与中央计算平台的关键通信基础设施,其设计严格遵循AUTOSAR Classic Platform规范(R21-11及后续版本),在保持与传统CAN/LIN协议栈统一配置…...

Shell_命令语法、管道和重定向详细介绍

Shell 命令语法、管道和重定向详细介绍 一、Shell 命令基本语法 1.1 命令结构 命令 [选项] [参数]命令:要执行的程序选项:修改命令行为的标志(通常以 - 或 -- 开头)参数:命令操作的对象 示例: ls-l /ho…...

产业园区如何搭建智能化技术服务平台?

观点作者:科易网-国家科技成果转化(厦门)示范基地 一、现状概述:传统产业园区服务的效能瓶颈与转型需求 产业园区作为区域经济发展的重要载体和创新要素集聚的核心区域,近年来在国家创新驱动发展战略的引领下取得了显著…...

Next.js第八课 - 缓存机制

前面几节我们学习了数据获取和数据变更,本节来深入了解 Next.js 的缓存机制。缓存是提升应用性能的关键技术,用好了能让你的应用速度提升好几倍。 缓存架构 Next.js 使用多层缓存来优化性能,理解这个架构很重要: 请求流程: 浏览…...

新鲜出炉!2026简历模板服务商推荐排行 专业评测榜 AI适配/全行业覆盖

一、摘要据中国人力资源开发研究会2026年行业报告显示,国内简历模板服务市场中,仅有30%的服务商能实现ATS系统通过率90%以上,求职者因简历模板不适配、内容不规范导致面试邀约率偏低,平均错失40%的求职机会;企业则因模…...

OpenClaw技能市场探秘:Qwen3.5-9B适配的十佳插件

OpenClaw技能市场探秘:Qwen3.5-9B适配的十佳插件 1. 为什么需要关注Qwen3.5-9B适配插件? 上周我在调试一个自动化周报生成流程时,发现同样的任务脚本在Qwen3.5-9B上运行时,效率比预期低了40%。经过排查才发现,我使用…...

从一次线上事故复盘:我们如何用OWASP ZAP揪出jQuery遗留的AJAX CSRF漏洞

实战复盘:如何用OWASP ZAP挖掘jQuery遗留的AJAX CSRF漏洞 那天凌晨2点,运维群突然炸出一连串报警——某金融模块出现异常转账记录,涉及金额虽不大,但所有操作都显示来自真实用户会话。作为技术负责人,我立刻意识到&…...

0欧姆电阻在电子设计中的关键应用与选型指南

1. 0欧姆电阻的实质与特性在电子工程实践中,0欧姆电阻(Zero-Ohm Resistor)是一种表面贴装或插装形式的特殊电子元件。虽然标称值为零欧姆,但实际测量时会发现其存在微小的阻值——典型值在20-50毫欧之间。这个特性使其既不同于理想…...

别让ChatGPT变成你的安全漏洞:OWASP LLM Top 10(2024)实战避坑指南

别让ChatGPT变成你的安全漏洞:OWASP LLM Top 10(2024)实战避坑指南 当大型语言模型(LLM)从实验室走向企业级应用时,安全风险正以指数级速度增长。2023年某金融科技公司因提示词注入导致百万用户数据泄露的案…...

【独家原创】基于分位数回归PSO-QRLightGBM多变量时序预测-区间预测(多输入单输出) Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。👇 关注我领取海量matlab电子书和数学建模资料🍊个人信条:格物致知,完整Matl…...

收藏必备!小白程序员必看:如何用AI智能体操作系统赋能医疗行业?

本文介绍了一项创新性研究,旨在解决大语言模型智能体在医疗场景中的应用难题。传统AI智能体在医疗领域存在权限过大、记忆碎片化、沟通机制单一和医院IT系统死板等问题。为解决这些痛点,研究团队提出了医疗版“AI操作系统”(AOS-H&#xff09…...

鸿蒙应用对接DeepSeek大模型:构建智能问答系统的技术实践

鸿蒙应用对接DeepSeek大模型:构建智能问答系统的技术实践 随着鸿蒙系统(HarmonyOS)在全场景智能终端的深度布局,以及AI大模型技术的快速迭代,将鸿蒙原生应用与DeepSeek大模型深度融合,已成为打造智能问答系…...

《高效能人士的七个习惯》:从内圣到外王的完整方法论

这本书在全世界卖了千万册,斯蒂芬柯维用七个习惯构建了一套从自我管理到影响他人的完整体系。一、前言:比七个习惯更重要的两件事 很多人读这本书只关注七个习惯本身,却忽略了前言中两个至关重要的前提: 1. 积极乐观是一切的起点 …...

从进度到资源:7款适合PMO的项目集管理系统

本文将深入对比7大项目集管理系统:PingCode、Worktile、GanttPRO、奥博思、TAPD、Trello、氚云 在管理大型、跨部门的复杂项目时,PMO(项目管理办公室)常面临资源冲突、信息孤岛和进度失控的挑战。传统的单项目管理工具已难以承载组…...

信息化基础设施层建设

4.1 基础设施层建设 4.1.4 基础软件环境 基础软件环境的理论定位 基础软件环境是企业信息化建设的“操作系统”,其理论任务是为上层应用系统提供统一的运行环境、开发框架、数据服务和协作工具,包括操作系统、数据库、中间件、开发框架、版本控制、协…...

SCH1633-D01 |Murata村田|汽车级|±300度的角速率六轴陀螺仪|惯性导航

SCH1633-D01 |Murata村田|汽车级|300度的角速率六轴陀螺仪|惯性导航用于汽车应用的六自由度XYZ轴陀螺仪和XYZ轴加速度计,带数字SPI接口SCH1633-D01SCH1600传感器系列通过冗余设计选项和内置可调双输出通道为资深客户提供更大的灵活性。●300/s的角速率测量范围●8g的…...

PyCharm Community 版新手一站式安装与配置指南

1. PyCharm Community版是什么? PyCharm Community版是JetBrains公司推出的免费Python集成开发环境(IDE),专为个人开发者和小型项目设计。我第一次接触这个工具时,发现它比想象中要强大得多 - 代码自动补全、错误检查、…...

EXE Ver 适用于 未安装Python 以及包的Windows OS

上图~EXE Ver END...

计算机内存与缓存完全指南

计算机内存与缓存完全指南 目录 计算机存储体系概览内存(RAM)深度解析 2.1 RAM 的基本原理2.2 DRAM vs SRAM2.3 DDR 内存发展历史与对比2.4 内存关键参数详解2.5 内存模组类型(DIMM / SO-DIMM / LPDDR) CPU 缓存深度解析 3.1 缓…...

查重踩坑血泪史:免费软件、PaPerPass、AIGC率、淘宝旗舰店

规避雷区 最近为了查重,折腾得心力交瘁。多方打听、多次数据对比之后,总结了一些“花钱买教训”的经验,写成几个点分享出来,希望能帮大家少走弯路。千万避雷某多多。 1️⃣ 免费软件的“Pass查重”低于10%还算靠谱 经过多个数据…...

通义千问1.5-1.8B-Chat商业应用:企业智能助手快速落地方案

通义千问1.5-1.8B-Chat商业应用:企业智能助手快速落地方案 1. 企业智能助手市场现状与需求 当前企业运营面临人力成本上升、服务标准化不足、数据分析需求激增等挑战。传统解决方案往往需要投入大量资源进行定制开发,而基于大模型的智能助手提供了快速…...

从‘丑拒’到‘真香’:MaterialButton的iconGravity和inset属性,帮你搞定那些烦人的UI细节

从‘丑拒’到‘真香’:MaterialButton的iconGravity和inset属性,帮你搞定那些烦人的UI细节 设计师递过来一张设计稿,要求按钮图标精确位于文字左侧8dp处,且垂直方向与相邻视图严格对齐。你信心满满地用MaterialButton实现&#xf…...

Linux内存监控工具与实战技巧

1. Linux 内存监控概述作为一名运维工程师,我每天都要和服务器内存打交道。内存就像系统的血液,一旦出现异常,整个系统就会变得迟缓甚至崩溃。在Linux系统中,我们可以通过多种方式来监控内存使用情况,每种方法都有其独…...

OpenClaw调试技巧:捕获Qwen3.5-9B错误推理的5个方法

OpenClaw调试技巧:捕获Qwen3.5-9B错误推理的5个方法 1. 为什么需要关注模型推理错误 上周我让OpenClaw自动整理项目文档时,发现它把"API响应时间优化方案"归类到了"前端样式规范"目录。这个看似简单的错误背后,是Qwen3…...

AD09实战:3分钟搞定BOM表导出与自动化分类(附模板下载)

AD09实战:3分钟高效生成智能分类BOM表的完整指南 在电子设计领域,BOM表(物料清单)是连接设计与生产的核心纽带。传统手工整理BOM表不仅耗时费力,还容易因人为疏忽导致元器件分类错误、数量统计偏差等问题。AD09作为业界…...

【C】static

static1、修饰局部变量:使其变为静态变量,这个局部变量在函数执行完成后不会被释放,而是继续保留在内存里。2、修饰全局变量:使其只在本文件内部有效,在其他文件不可用。3、修饰函数:使函数只能在本文件中使…...