游乐游手机版
首页/科技数码/文章详情

JSoup 1.22.1发布:Java HTML解析新特性详解

时间:2026-01-04 18:58
jsoup 1 22 1 已正式发布,本次更新引入了对 re2j 正则表达式引擎的支持(专用于正则驱动的 CSS 选择器)、可自定义的最大解析深度设置,并包含多项缺陷修复与功能优化

jsoup 1.22.1 发布,Java HTML 解析器

jsoup 1.22.1 版本现已正式推出。本次更新引入了对 re2j 正则表达式引擎的支持,该功能专用于正则驱动的 CSS 选择器。此外,还加入了可自定义的最大解析深度设置,并包含多项缺陷修复与性能优化。

功能亮点

  • 新增对 re2j 正则引擎的支持。此项改进主要针对基于正则的 CSS 选择器语法,例如 [attr~=regex]:matches(regex),能够显著提升处理用户输入的正则表达式时的安全性。启用方式为将 com.google.re2j 依赖添加至项目路径,例如:
com.google.re2j re2j 1.8

若项目路径中已存在该依赖但希望回退至 Java 原生正则引擎,可通过 System.setProperty(“jsoup.useRe2j”, “false”) 显式禁用。调用 Regex.usingRe2j() 方法可验证 re2j 是否已成功激活。#2407

  • 新增实例方法 Parser#unescape(String, boolean),该方法利用当前解析器的配置执行 HTML 实体解码,例如支持错误定位。这是对已有的静态工具方法 Parser.unescapeEntities(String, boolean) 的实用补充实现。#2396
  • HTML 与 XML 解析器均支持配置最大解析嵌套深度,以限制栈中活跃元素的数量。HTML 解析器的深度上限默认设置为 512,此举旨在对齐主流浏览器行为并防范栈溢出风险。XML 解析器默认不限制深度,但可通过 Parser.setMaxDepth() 手动设定上限。#2421
  • 构建流程升级:CI 环境新增对 JDK 25 的兼容性测试覆盖。#2403
  • 构建流程升级:在原有完整的 HTML/XML 模糊测试基础上,新增针对上下文片段解析的模糊测试模块,此功能由 oss-fuzz 项目提供支持,编号为 #14041。

API 调整

  • 启动了 jsoup 1.24.1 版本中废弃 API 的移除路线图,相关接口将在后续版本中逐步淘汰。

问题修复

  • 修复了 Node#replaceWith(Node) 方法中未及时清除被替换节点缓存的子元素的问题,避免了后续调用 Element#children() 返回异常结果。#2391
  • 属性选择器值现在严格按字面量比对且不再自动修剪首尾空白。此前版本会对选择器值与元素属性值同时清理空格,此行为偏离了 CSS 规范及浏览器实际表现(如 [attr=” foo “] 匹配失败)。目前已完全对齐标准。#2380
  • 在使用 JDK 内置的 HttpClient 时,系统级代理设置曾遭忽略。现已修正:当请求未显式指定代理时,会自动采用系统默认代理设置。#2388,#2390
  • 在处理严重损坏的 HTML 输入时,“adoption agency” 算法可能抛出 ValidationException。现统一改为记录为解析警告,不断续处理流程。#2393
  • 修复了 HTML 正文内的空字(U+0000)符移除逻辑不一致的问题;外部引入内容中的空字符亦未能正确转义。#2395
  • 解析恶意构造的正文片段时偶发 IndexOutOfBoundsException。现捕获并将问题降级为解析错误日志,确保程序稳定性。#2397,#2406
  • ……

内部调整

  • 将内部辅助类 org.jsoup.internal.Functions 标记为已弃用,计划于 v1.23.1 版本中彻底移除。#2412

完整更新日志请参阅:https://www.php.cn/link/adb7dc747bdd4a368293f7fd6721d6df

源码获取地址:点击下载

来源:https://www.php.cn/faq/1932691.html?uid=1246273
上一篇2030年全国铁路营业里程达18万公里,高铁占6万公里 下一篇英伟达GB200 NVL72性能实测:超越AMD MI355X达28倍
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
OpenClaw手机App上线,结果翻车了
科技数码 · 2026-07-01

OpenClaw手机App上线,结果翻车了

OpenClaw 官方宣布,已正式推出 iOS 和 Android 原生移动 App,用户如今可以在手机上使用这款主打“能真正帮你做事”的个人 AI 助手。官方在 X 上给出的定位也很直接:把 Agent 放进口袋里,让用户可以在移动端处理频道消息、任务和回复。从功能上看,OpenClaw 移动端并

优必选CEO周剑:家庭机器人生态核心投入过半精力
科技数码 · 2026-07-01

优必选CEO周剑:家庭机器人生态核心投入过半精力

先说几个核心判断:优必选正在布局一盘长远战略。创始人兼CEO周剑在近期一场媒体沟通会上,直接亮出了公司未来的发展路线——工业、商用、家庭陪伴机器人三条业务主赛道并行推进,现阶段每条线各占约一半精力。一边是已经能够稳定创造收入的工业场景,另一边则是他眼中“最具想象力与未来空间”的家庭陪伴领域。工业人形

CPO/NPO/OIO开启封装级光连接价值空间,技术路线尚未收敛
科技数码 · 2026-07-01

CPO/NPO/OIO开启封装级光连接价值空间,技术路线尚未收敛

6月30日,申银万国在光连接系列研报中重点指出,MPO光连接器领域的投资机会值得高度关注。通俗来说,随着AI算力集群持续扩张,光互联升级带来的连锁效应——数据中心光纤通道数量、前面板端口密度、机柜内光纤管理复杂度——均在同步攀升。光连接器的角色早已超越传统的低价值标准件,如今它直接决定着链路插损、可

龙岗AR实景剧本游内测体验短板有效破解之道
科技数码 · 2026-07-01

龙岗AR实景剧本游内测体验短板有效破解之道

在今年龙岗区第二届人工智能与机器人发展大会上,区级部门一次性推出了7个AI“龙搭子”。其中,名为“龙导游”的成果成为文商旅融合领域的核心亮点。据南都N视频记者了解,依托“龙导游”打造的全区全域AR实景剧本游“龙岗大陆”,已在今年五一假期发布了内测版本。经过一个月市场验证后,该项目正式启动面向全社会的

南下资金6月30日净买入中芯国际与建滔积层板
科技数码 · 2026-07-01

南下资金6月30日净买入中芯国际与建滔积层板

6月30日,南下资金持续大举买入港股,单日净流入金额高达58 95亿港元。接下来,我们直接盘点哪些个股获得资金青睐、哪些遭到减持: 净买入方面,中芯国际领跑全场,单日吸金19 33亿港元;建滔积层板紧随其后,净买入10 59亿港元;腾讯控股获得7 65亿港元净流入;智谱(02513 HK)也有6 5