首页
/ open62541 v1.4.9版本发布:OPC UA开源库的重要更新

open62541 v1.4.9版本发布:OPC UA开源库的重要更新

2025-06-17 22:22:50作者:侯霆垣

项目概述

open62541是一个开源的OPC UA(OPC统一架构/IEC 62541)实现,采用C语言编写。该项目提供了实现专用OPC UA客户端和服务器的必要工具,也可将OPC UA通信集成到现有应用中。作为一个平台无关的库,open62541通过可交换插件实现所有平台特定功能,便于移植到不同的嵌入式目标平台。

核心改进

v1.4.9版本在证书验证方面进行了重要增强,增加了对额外证书验证状态码的屏蔽处理。这一改进提升了安全通信的健壮性,特别是在处理ERR响应时能够更准确地识别和处理证书问题。

线程安全方面,该版本为客户端、服务器和发布订阅(PubSub)功能实现了递归锁机制,解决了多线程环境下的潜在竞争条件问题。同时修复了UA_KeyValueMap_remove()函数中可能导致双重递减的错误。

服务器端优化

在服务器功能方面,v1.4.9版本改进了mDNS服务发现机制,现在使用".local"域名发布记录,这符合现代网络服务发现的标准实践。同时解决了Windows架构标志使用不一致的问题,提升了跨平台兼容性。

服务器配置方面,增强了JSON配置插件的功能,新增了对Aes256_Sha256_RsaPss安全策略的支持,使安全配置更加灵活全面。

客户端改进

客户端功能在此版本中获得了更完善的证书处理能力。现在能够正确处理服务器在非对称头部中不发送ServerCertificate的情况(适用于#None安全模式)。这一改进使得客户端能够更灵活地适应不同的安全配置场景。

发布订阅(PubSub)增强

PubSub子系统在此版本中获得了多项重要改进:

  • 完善了SKS(安全密钥服务)密钥轮换回调处理机制
  • 修复了UA_PubSubKeyStorage_addKeyRolloverCallback中定时回调更新的问题
  • 确保密钥轮换过程更加可靠和稳定

安全插件改进

安全相关插件在此版本中获得了多项增强:

  • 自动将PEM格式转换为DER格式以支持RSA安全策略
  • 修复了MbedTLS插件中私钥格式生成错误的问题
  • 改进了UA_AccessControl_default()中清除先前插件的处理
  • 移除了CTT(一致性测试工具)不支持的authorityKeyIdentifier/subjectKeyIdentifier比较

技术细节

在底层实现上,v1.4.9版本继续完善了基于事件循环(EventLoop)的控制流模型,这是1.4系列版本引入的重要架构改进。同时保持了对OpenSSL 3.0的支持,并增强了各种安全策略的实现。

对于开发者而言,该版本进一步提升了API的线程安全性,所有主要组件(服务器、客户端和PubSub)现在都通过内部锁机制实现了线程安全访问。

总结

open62541 v1.4.9版本作为1.4系列的第九个补丁版本,主要聚焦于稳定性改进和安全增强。虽然没有引入重大新功能,但对现有功能的完善和问题修复使得整个框架更加健壮可靠。特别是安全相关的改进,如证书处理、密钥轮换和线程安全等方面的优化,使得这个版本成为生产环境中值得升级的选择。

对于正在使用open62541的项目,特别是那些对安全性和稳定性有较高要求的应用场景,建议考虑升级到这个版本以获得最佳的性能和安全保障。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
163
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
16
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
199
279
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
951
557
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
96
15
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Python
77
70
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
17
0