首页
/ BlazingMQ项目中的bmqtool工具格式字符串安全优化

BlazingMQ项目中的bmqtool工具格式字符串安全优化

2025-06-29 03:25:21作者:史锋燃Gardner

问题背景

在BlazingMQ项目的bmqtool工具中,存在一个潜在的安全隐患。该工具允许用户传递一个顺序消息模式作为参数,用于生成消息内容。原始实现中直接将用户提供的字符串作为snprintf函数的格式字符串使用,这可能导致格式化字符串问题。

问题分析

原始代码实现如下:

if (!d_parameters.sequentialMessagePattern().empty()) {
    char buffer[128];
    length = snprintf(
        buffer,
        sizeof(buffer),
        d_parameters.sequentialMessagePattern().c_str(),
        d_numMessagesPosted);
    msg.setDataRef(buffer, length);
}

这段代码会触发编译警告:"format string is not a string literal",因为snprintf函数的格式字符串参数应该是一个字符串字面量,而不是运行时确定的变量。这种设计不仅存在潜在的安全风险,而且在实际使用中也缺乏必要性。

解决方案

经过分析,我们可以将功能简化为使用固定的前缀和格式化的后缀组合:

  1. 将用户输入作为固定前缀
  2. 使用固定的"%09d"格式生成消息序号后缀
  3. 将两部分拼接作为最终消息内容

优化后的实现如下:

if (!d_parameters_p->sequentialMessagePattern().empty()) {
    char buffer[16];
    bsl::string messageData(d_allocator_p);
    length = snprintf(buffer, sizeof(buffer), "%09d", d_numMessagesPosted);
    messageData = d_parameters_p->sequentialMessagePattern();
    messageData.append(buffer);
    msg.setDataRef(messageData.c_str(), messageData.length());
}

实现细节

  1. 缓冲区大小优化:将缓冲区从128字节缩减到16字节,足够存储9位数字和字符串终止符
  2. 内存分配:使用项目自定义的分配器(d_allocator_p)来创建临时字符串
  3. 字符串拼接:先复制前缀,再追加格式化后的序号
  4. 格式规范:使用"%09d"确保序号总是9位数字,不足前面补零

影响范围

这一修改影响了bmqtool工具的消息生成逻辑,需要同步更新相关的集成测试用例。测试用例中原本使用"msg%10d"等格式字符串的地方,现在只需要使用"msg"作为前缀即可,因为序号部分会由工具自动追加。

安全意义

这一优化消除了潜在的格式化字符串问题风险,使代码更加健壮和安全。通过将用户输入与格式字符串分离,我们确保了snprintf函数总是使用可信的、硬编码的格式字符串,从而避免了恶意用户可能利用格式化字符串问题进行的攻击。

总结

通过对BlazingMQ项目中bmqtool工具的格式字符串处理方式进行重构,我们不仅解决了编译器警告,更重要的是提升了代码的安全性和可靠性。这种将用户输入与系统格式化分离的设计模式,是处理类似场景的良好实践,值得在其他项目中借鉴。

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

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
166
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
88
568
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
17
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉应用开发框架。IoC,Rest,宏路由,Json,中间件,参数绑定与校验,文件上传下载,OAuth2,MCP......
Cangjie
94
15
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
199
279
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
17
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
954
564