【C语言】解决C语言报错:Format String Vulnerability
文章目录
- 简介
- 什么是Format String Vulnerability
- Format String Vulnerability的常见原因
- 如何检测和调试Format String Vulnerability
- 解决Format String Vulnerability的最佳实践
- 详细实例解析
- 示例1:直接使用不受信任的输入作为格式化字符串
- 示例2:未验证格式化字符串中的格式说明符
- 示例3:使用不安全的函数gets
- 进一步阅读和参考资料
- 总结
简介
Format String Vulnerability(格式化字符串漏洞)是C语言中常见且严重的安全漏洞之一。它通常在程序使用不受信任的输入作为格式化字符串时发生。这种漏洞会导致程序行为不可预测,可能引发段错误(Segmentation Fault)、数据损坏,甚至被攻击者利用进行代码注入和系统入侵。本文将详细介绍Format String Vulnerability的产生原因,提供多种解决方案,并通过实例代码演示如何有效避免和解决此类错误。
什么是Format String Vulnerability
Format String Vulnerability,即格式化字符串漏洞,是指在使用格式化字符串函数(如printf、sprintf等)时,格式化字符串中包含不受信任的用户输入,导致未定义行为和潜在的安全漏洞。这种漏洞可以被攻击者利用,读取或修改内存内容,甚至执行任意代码。
Format String Vulnerability的常见原因
-
直接使用不受信任的输入作为格式化字符串:在使用格式化字符串函数时,直接使用用户输入作为格式化字符串。
char userInput[100]; gets(userInput); printf(userInput); // 直接使用用户输入,导致格式化字符串漏洞 -
未验证格式化字符串中的格式说明符:在格式化字符串中包含了用户输入,但未对格式说明符进行验证。
char userInput[100]; gets(userInput); printf("User input: %s", userInput); // 未验证格式说明符,可能导致漏洞
如何检测和调试Format String Vulnerability
-
使用GDB调试器:GNU调试器(GDB)是一个强大的工具,可以帮助定位和解决格式化字符串漏洞。通过GDB可以查看程序崩溃时的调用栈,找到出错的位置。
gdb ./your_program run当程序崩溃时,使用
backtrace命令查看调用栈:(gdb) backtrace -
使用静态分析工具:静态分析工具(如Clang Static Analyzer)可以帮助检测代码中的格式化字符串漏洞。
clang --analyze your_program.c -
使用代码审查:通过代码审查,确保每个格式化字符串函数的使用都经过验证,避免使用不受信任的输入作为格式化字符串。
解决Format String Vulnerability的最佳实践
-
避免直接使用不受信任的输入作为格式化字符串:在使用格式化字符串函数时,避免直接使用用户输入作为格式化字符串。
char userInput[100]; gets(userInput); printf("%s", userInput); // 使用格式化字符串,避免漏洞 -
验证和限制格式说明符:在格式化字符串中包含用户输入时,对格式说明符进行验证和限制。
char userInput[100]; gets(userInput); printf("User input: %.90s", userInput); // 限制输入长度,避免漏洞 -
使用安全函数:在处理格式化字符串时,使用安全函数(如
snprintf)来避免缓冲区溢出和格式化字符串漏洞。char buffer[100]; char userInput[100]; gets(userInput); snprintf(buffer, sizeof(buffer), "%s", userInput); // 使用安全函数 printf("%s", buffer); -
使用参数化查询:在处理数据库查询和其他命令执行时,使用参数化查询来避免格式化字符串漏洞。
// 示例:使用参数化查询(伪代码) char *query = "SELECT * FROM users WHERE username = ?"; prepareStatement(query); bindParameter(1, userInput); executeQuery();
详细实例解析
示例1:直接使用不受信任的输入作为格式化字符串
#include <stdio.h>int main() {char userInput[100];gets(userInput);printf(userInput); // 直接使用用户输入,导致格式化字符串漏洞return 0;
}
分析与解决:
此例中,printf函数直接使用了用户输入userInput,导致格式化字符串漏洞。正确的做法是使用格式化字符串,并将用户输入作为参数传递:
#include <stdio.h>int main() {char userInput[100];gets(userInput);printf("%s", userInput); // 使用格式化字符串,避免漏洞return 0;
}
示例2:未验证格式化字符串中的格式说明符
#include <stdio.h>int main() {char userInput[100];gets(userInput);printf("User input: %s", userInput); // 未验证格式说明符,可能导致漏洞return 0;
}
分析与解决:
此例中,printf函数中的格式化字符串包含了用户输入userInput,但未对格式说明符进行验证,可能导致漏洞。正确的做法是限制用户输入的长度:
#include <stdio.h>int main() {char userInput[100];gets(userInput);printf("User input: %.90s", userInput); // 限制输入长度,避免漏洞return 0;
}
示例3:使用不安全的函数gets
#include <stdio.h>int main() {char userInput[100];gets(userInput); // 使用不安全的函数,可能导致溢出和漏洞printf("%s", userInput);return 0;
}
分析与解决:
此例中,gets函数未对输入长度进行验证,导致潜在的缓冲区溢出和格式化字符串漏洞。正确的做法是使用安全的输入函数:
#include <stdio.h>int main() {char userInput[100];fgets(userInput, sizeof(userInput), stdin); // 使用安全的输入函数printf("%s", userInput);return 0;
}
进一步阅读和参考资料
- C语言编程指南:深入了解C语言的内存管理和调试技巧。
- GDB调试手册:学习使用GDB进行高级调试。
- Clang Static Analyzer使用指南:掌握静态分析工具的基本用法和漏洞检测方法。
- 《The C Programming Language》:由Brian W. Kernighan和Dennis M. Ritchie编写,是学习C语言的经典教材。
总结
Format String Vulnerability是C语言开发中常见且危险的安全漏洞,通过正确的编程习惯和使用适当的调试工具,可以有效减少和解决此类错误。本文详细介绍了格式化字符串漏洞的常见原因、检测和调试方法,以及具体的解决方案和实例,希望能帮助开发者在实际编程中避免和解决格式化字符串漏洞问题,编写出更高效和可靠的程序。
相关文章:
【C语言】解决C语言报错:Format String Vulnerability
文章目录 简介什么是Format String VulnerabilityFormat String Vulnerability的常见原因如何检测和调试Format String Vulnerability解决Format String Vulnerability的最佳实践详细实例解析示例1:直接使用不受信任的输入作为格式化字符串示例2:未验证格…...
Python深度学习:Bi-LSTM和LSTM在网络上有什么区别,对比来看
文章目录 LSTM代码解释类定义和构造函数前向传播方法 (`forward`)总结Bi-LSTMLSTM 代码 class BaseLSTMModel(nn.Module):def __init__(self, input_dim, hidden_dim, layer_dim, class_num):super().__init__...
Keepalived LVS群集
一、Keepalived案例分析 企业应用中,单台服务器承担应用存在单点故障的危险 单点故障一旦发生,企业服务将发生中断,造成极大的危害 二、Keepalived工具介绍 专为LVS和HA设计的一款健康检查工具 支持故障自动切换(Failover&#…...
harbor问题总结
1. http协议的仓库docker login不上,更改/etc/docker/daemon.json,加一个镜像仓库地址 http: server gave HTTP response to HTTPS client 分析一下这个问题如何解决中文告诉我详细的解决方案-CSDN博客 2. Error response from daemon: login attempt t…...
windows系统,家庭自用NAS。本地局域网 Docker安装nextcloud
windows系统,家庭自用NAS。本地局域网 Docker安装nextcloud 1、docker安装 太简单了,直接去搜一搜。 docker-compose 相关命令 docker-compose down docker compose up -d2、还是使用老的 在你需要挂载的目录下,新建一个文件,…...
迅狐跨境商城系统|全平台兼容|前端采用uni-app跨端框架,后端采用ThinkPHP5框架
高效实现全平台兼容的迅狐跨境商城系统 迅狐跨境商城系统是一款专为跨境电商企业设计的全平台兼容系统。其前端采用uni-app跨端框架,后端采用ThinkPHP5框架,旨在实现高效的开发和运营管理。 1. 全平台兼容的前端设计 迅狐跨境商城系统的前端采用uni-a…...
Elixir学习笔记——进程(Processes)
在 Elixir 中,所有代码都在进程内运行。进程彼此隔离,彼此并发运行并通过消息传递进行通信。进程不仅是 Elixir 中并发的基础,而且还提供了构建分布式和容错程序的方法。 Elixir 的进程不应与操作系统进程混淆。Elixir 中的进程在内存和 CPU…...
困惑度作为nlp指标的理解示例
为了更清晰地说明困惑度的计算过程以及如何通过困惑度判断模型的优劣,我们可以通过一个简单的例子来演示。假设我们有一个非常简单的文本语料库和两个基础的语言模型进行比较。 示例文本 假设我们的文本数据包括以下两个句子: “cat sits on the mat”…...
01 Pytorch 基础
paddle不需要放数据到gpu! 区别:1.batch_norlization 不同 2. 1.数据处理 1.取一个数据,以及计算大小 (剩下的工作,取batch,pytorch会自动做好了) 2.模型相关 如何得到结果 3.模型训练/模型…...
STL——set、map、multiset、multimap的介绍及使用
文章目录 关联式容器键值对树形结构与哈希结构setset的介绍set的使用set的模板参数列表set的构造set的使用set的迭代器使用演示 multisetmultiset演示 mapmap的定义方式map的插入map的查找map的[ ]运算符重载map的迭代器遍历multimapmultimap的介绍multimap的使用 在OJ中的使用…...
使用C语言,写一个类似Linux中执行cat命令的类似功能
一、详细的代码案例 #include <stdio.h> #include <stdlib.h> #include <string.h>// 函数声明 void cat_file(const char *filename);int main(int argc, char *argv[]) {if (argc < 2) {fprintf(stderr, "Usage: %s filename1 [filename2 ...]\n&…...
【Android】Android系统性学习——Android系统架构
前言 部分内容参考《Android进阶解密》 – 刘望舒 1. Android版本 官方链接:https://developer.android.com/studio/releases/platforms 里面有各个版本的官方文档,有些新功能的用法在这里面。 现在做安卓11,有时候需要向下兼容 2. AOSP …...
鸿蒙应用开发
学习视频: 00.课程介绍_哔哩哔哩_bilibili 官网:开发者文档中心 | 华为开发者联盟 (huawei.com) 开发工具 :DevEcoStudio , 类似Jetbrains 全家桶 ArkTS开发语言 :(基于TS,集成了前端语言…...
索引失效有效的11种情况
1全职匹配我最爱 是指 where 条件里 都是 ,不是范围(比如>,<),不是 不等于,不是 is not null,然后 这几个字段 建立了联合索引 ,而且符合最左原则。 那么就要比 只建…...
字符数组基础知识及题目
死识。。。 字符该如何存储呢?这一点我们在以前就接触过了。用char来存储。 如何输入一个单词呢? char a[10002]; scanf("%s",a); 就不用地址符了。 如何输入句子呢? char a[100002]; gets(a); gets是读入句子的,…...
一个简单的玩具机器人代码
编写一个玩具机器人脚本通常取决于机器人的硬件、接口和具体功能。然而,由于我们不能直接控制一个真实的硬件机器人,所以只是写一个模拟的C语言脚本示例,该脚本描述了一个简单的玩具机器人可能执行的一些基本操作。 假设我们的“玩具机器人”…...
设计模式-装饰器模式Decorator(结构型)
装饰器模式(Decorator) 装饰器模式是一种结构模式,通过装饰器模式可以在不改变原有类结构的情况下向一个新对象添加新功能,是现有类的包装。 图解 角色 抽象组件:定义组件的抽象方法具体组件:实现组件的抽象方法抽象装饰器&…...
RK3588开发板中使用Qt对zip文件进行解压
操作步骤: 下载源码quazip-0.7.3.zip ,在网上找找下载地址上传源码进行解压,然后使用命令 cd quazip-0.7.3 qmake make主要用的是quazip-0.7.3/quazip这个里面的源码,然后把源码加入到自己创建的qt项目pro中,导入方式…...
三、网络服务协议
目录 一、FTP:文件传输协议 二、Telnet:远程登录协议 三、AAA认证 四、DHCP 五、DNS 六、PPP协议 七、ISIS协议 一、FTP:文件传输协议 C/S架构,现多用于企业内部的资料共享和网络设备的文件传输,企业内部搭建一…...
C++初学者指南第一步---1. C++开发环境设置
C初学者指南第一步—1. C开发环境设置 目录 C初学者指南第一步---1. C开发环境设置1.1 工具1.1.1 代码编辑器和IDE1.1.2 Windows1.1.3 命令行界面 1.2 编译器1.2.1 gcc/g (支持Linux/Windows/MacOSX)1.2.2 clang/clang (支持Linux/Windows/MacOS)1.2.3 Microsoft Visual Studio…...
基于大模型的 UI 自动化系统
基于大模型的 UI 自动化系统 下面是一个完整的 Python 系统,利用大模型实现智能 UI 自动化,结合计算机视觉和自然语言处理技术,实现"看屏操作"的能力。 系统架构设计 #mermaid-svg-2gn2GRvh5WCP2ktF {font-family:"trebuchet ms",verdana,arial,sans-…...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
【Oracle APEX开发小技巧12】
有如下需求: 有一个问题反馈页面,要实现在apex页面展示能直观看到反馈时间超过7天未处理的数据,方便管理员及时处理反馈。 我的方法:直接将逻辑写在SQL中,这样可以直接在页面展示 完整代码: SELECTSF.FE…...
[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?
论文网址:pdf 英文是纯手打的!论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误,若有发现欢迎评论指正!文章偏向于笔记,谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...
vue3 字体颜色设置的多种方式
在Vue 3中设置字体颜色可以通过多种方式实现,这取决于你是想在组件内部直接设置,还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法: 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...
相机从app启动流程
一、流程框架图 二、具体流程分析 1、得到cameralist和对应的静态信息 目录如下: 重点代码分析: 启动相机前,先要通过getCameraIdList获取camera的个数以及id,然后可以通过getCameraCharacteristics获取对应id camera的capabilities(静态信息)进行一些openCamera前的…...
vue3+vite项目中使用.env文件环境变量方法
vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量,这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...
使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台
🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...
【无标题】路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论
路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论 一、传统路径模型的根本缺陷 在经典正方形路径问题中(图1): mermaid graph LR A((A)) --- B((B)) B --- C((C)) C --- D((D)) D --- A A -.- C[无直接路径] B -…...
Java数值运算常见陷阱与规避方法
整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...
