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

网络安全小知识课堂(十二)

SQL 注入:一行代码如何毁掉整个数据库?

引言

想象一下:用户在一个搜索框中输入关键词,网站却突然崩溃,所有数据被清空 —— 这不是电影情节,而是 **SQL 注入攻击(SQL Injection)** 的真实威力。作为 “Web 安全头号威胁”,它能让黑客通过一行看似无害的代码,操控整个数据库。本文将用最直白的语言,揭示 SQL 注入的致命逻辑,并教你如何堵住代码中的 “致命漏洞”。

一、SQL 注入:用 “用户输入” 攻破数据库

1. 攻击原理

SQL 注入利用开发者未过滤的用户输入,将恶意 SQL 语句 “拼接” 到数据库查询中,从而执行非法操作。

🌰 举个栗子:
  • 正常代码
    SELECT * FROM users WHERE username = '用户输入' AND password = '用户输入';  
    
  • 恶意输入:在用户名框输入 ' OR 1=1 --
  • 最终执行的 SQL
    SELECT * FROM users WHERE username = '' OR 1=1 --' AND password = '...';  
    
     
    • 结果1=1永远成立,--注释掉后续代码,黑客无需密码即可登录任意账号。

2. 攻击者能做什么?

  • 窃取数据:导出用户表、交易记录、甚至管理员凭证。
  • 篡改数据:修改商品价格、删除订单、清空数据库。
  • 提权控制服务器:通过数据库执行系统命令(如xp_cmdshell)。

二、四大常见 SQL 注入类型

1. 布尔盲注

  • 原理:通过页面返回结果的真假(如 “404” 或 “200” 状态码),逐字符猜测数据库内容。
  • 攻击语句
    ' AND (SELECT SUBSTRING(password,1,1) FROM users WHERE id=1) = 'a' --  
    

2. 联合查询注入

  • 原理:利用UNION合并查询结果,直接获取其他表数据。
  • 攻击语句
    ' UNION SELECT username, password FROM users --  
    

3. 时间盲注

  • 原理:通过数据库响应延迟(如SLEEP(5))判断条件真假。
  • 攻击语句
    '; IF (SELECT COUNT(*) FROM users) > 100 WAITFOR DELAY '0:0:5' --  
    

4. 报错注入

  • 原理:故意触发数据库错误,通过错误信息泄露数据。
  • 攻击语句
    ' AND 1=CONVERT(int, (SELECT TOP 1 username FROM users)) --  
    

三、真实案例:SQL 注入的 “核弹级” 破坏

1. 索尼被黑事件(2011)

  • 漏洞:网站搜索框未过滤用户输入,导致攻击者获取 1.2 亿用户数据。
  • 后果:索尼损失 1.7 亿美元,PlayStation Network 关闭 23 天。

2. 某电商平台订单泄露

  • 过程:攻击者通过商品 ID 参数注入,导出全部订单数据(含姓名、地址、手机号)。
  • 用途:数据在暗网以每条 $0.5 的价格出售。

四、防御指南:让黑客的注入代码 “失效”

1. 参数化查询(预编译语句)

  • 原理:将用户输入与 SQL 语句分离,阻止恶意拼接。
  • 代码示例(Python + SQLite)
    # 错误写法(拼接字符串)  
    cursor.execute("SELECT * FROM users WHERE username = '" + username + "'")  # 正确写法(参数化查询)  
    cursor.execute("SELECT * FROM users WHERE username = ?", (username,))  
    

2. 使用 ORM 框架

  • 工具推荐:SQLAlchemy(Python)、Hibernate(Java)、Entity Framework(.NET)。
  • 优势:自动处理 SQL 转义,减少手写 SQL 的风险。

3. 输入过滤与转义

  • 白名单过滤:仅允许特定字符(如数字、字母)。
  • 转义特殊字符:将'转为''"转为\"

4. 最小权限原则

  • 数据库账号权限:禁止 Web 应用使用rootsa账号,限制为只读或必要操作权限。

5. Web 应用防火墙(WAF)

  • 功能:拦截常见注入特征(如UNIONSELECT)。
  • 工具推荐:ModSecurity(开源)、Cloudflare WAF(云服务)。

五、3 分钟自查:你的代码是否 “带洞”?

  1. 代码扫描
    • 检查是否所有用户输入都经过参数化查询或 ORM 处理。
    • 搜索代码中的execute()query()等高风险函数。
  2. 工具测试
    • 使用 sqlmap 工具(谨慎!仅限授权测试):
      sqlmap -u "http://example.com/search?keyword=test"  
      

结语

SQL 注入是开发者 “偷懒” 的代价,也是黑客最易利用的漏洞。记住:永远不要信任用户输入!
下期预告:我们将探讨《跨站脚本(XSS):用户输入如何变成攻击武器?》,揭秘前端代码的隐秘风险。

📢 互动话题:你是否在项目中遇到过 SQL 注入漏洞?是如何修复的?欢迎分享你的实战经验!

相关文章:

网络安全小知识课堂(十二)

SQL 注入:一行代码如何毁掉整个数据库? 引言 想象一下:用户在一个搜索框中输入关键词,网站却突然崩溃,所有数据被清空 —— 这不是电影情节,而是 **SQL 注入攻击(SQL Injection)**…...

PyCharm使用Flask启动项目后,如何修改文件,开启启动加载或是热启动,不用重启项目,直接生效。

PyCharm使用Flask启动项目后,每次修改完文件比如html、py文件都要重启项目才生效,在测试时很不方便,如何设置热启动,修改完文件后直接生效了? 解决方法 1、app.py文件,设置debugTrue。开启调试模式。 开…...

SpringCloud微服务(一)Eureka+Nacos

一、认识 微服务技术对比: SpringCloud: 版本匹配: 二、服务拆分以及远程调用 消费者与提供者: Eureka: 搭建EurekaServer: Ribbon负载均衡: 实现原理: IRule:规则接口…...

【Java设计模式】第4章 简单工厂讲解

4. 简单工厂模式 4.1 简单工厂讲解 定义:由一个工厂对象决定创建哪种产品类的实例,属于创建型模式,但不属于GoF 23种设计模式。适用场景: 工厂类负责创建的对象较少。客户端仅需传入参数,无需关心对象创建逻辑。优点: 客户端只需传入参数即可获取对象,无需知道创建细节…...

深度学习天崩开局

李沐大神的d2l包导入, 这玩意需要python311版本,我现在版本已经313了,作为一个天生要强的男人,我是坚决不向低版本低头的。 然后我就研究啊,各种翻资料啊,然后deepseek加豆包都翻烂了, 最终所…...

【详细图文】在VScode中配置python开发环境

目录 一、下载安装VSCode 1、官网下载VSCode 2、安装VSCode 3、汉化vscode (1)已自动下载汉化版插件 (2)未自动下载汉化版插件 二、 下载安装Python 1、官网下载Python 2、安装Python (1)双击打开…...

Unity遮挡剔除与视锥剔除混合策略技术详解

一、核心剔除技术原理对比 1. 视锥剔除(Frustum Culling) 原理:根据物体包围盒与摄像机视锥体的相交测试,移除非可见物体 优势: 计算成本低(平均0.1ms/万物体) 完全自动执行 局限&#xff1a…...

Java面试黄金宝典34

1. 主键索引底层的实现原理 定义 主键索引是数据库中用于唯一标识表中每一行记录的索引,常见的底层实现是 B 树结构。B 树是一种平衡的多路搜索树,由内部节点和叶子节点组成。内部节点只存储索引键和指向下一层节点的指针,不存储实际数据&am…...

VR体验馆如何用小程序高效引流?3步打造线上预约+团购裂变系统

VR体验馆如何用小程序高效引流?3步打造线上预约团购裂变系统 一、线上预约的核心价值:优化体验,提升转化​​ ​​减少客户等待时间​​ 通过小程序预约功能,客户可提前选择体验时段,避免到店排队。数据显示&#…...

使用 node.js 和 MongoDB 编写一个简单的增删改接口 demo

文章目录 前言一、环境准备二、项目结构三、环境变量四、连接数据库3.1. connect.js 文件 五、定义数据模型5.1. BannerModel.js 文件 六、实现 server 接口6.1. server.js 文件 七、服务文件7.1. app.js 文件 八、感谢 前言 Mongoose 是一个在 Node.js 环境中操作 MongoDB 数据…...

【基于Vue3组合式API的互斥输入模式实现与实践分享】

基于Vue3组合式API的互斥输入模式实现与实践分享 目录 背景与痛点设计思路技术实现使用场景与案例遇到的问题与解决方案最佳实践总结 1. 背景与痛点 在表单交互设计中,我们经常面临这样的场景:多种输入方式互斥。例如,在评分系统中&#…...

PCL拟合空间3D圆周 fit3DCircle

PCL版本 1.15.0 main.cpp #include<vector> #include<iostream> #include <array> #include <string> #include <windows.h> #include <omp.h> #include <charconv> // C17 #include <cstdlib> #include<chrono> #in…...

【Redis】——最佳实践

目录 一.键值设计 1.如何优雅的设计key结构 2.拒绝BigKey 3.选择合适的数据结构 4.总结 二.批处理优化&#xff08;海量数据批处理&#xff09; 1.Pipeline 2.集群模式下的批处理 三.服务端优化 1.持久化配置 2.慢查询问题 1.记录慢查询 2.找到慢查询 3.集群最佳…...

HTTP GET 和 POST 请求有什么区别

HTTP 的 GET 和 POST 请求是两种常见的 HTTP 请求方法&#xff0c;它们有不同的特点和应用场景。以下是它们的主要区别&#xff1a; 1. 用途 GET&#xff1a;用于从服务器获取数据或资源。GET 请求会附带查询参数在 URL 中&#xff0c;通常用于请求数据&#xff0c;如加载网页…...

Redis 缓存问题:缓存雪崩、缓存击穿、缓存穿透

文章目录 缓存雪崩缓存击穿缓存穿透在实际的业务场景中,Redis 通常作为缓存和其他数据库(例如 MySQL)搭配使用,用来减轻数据库的压力。但是在使用 Redis 作为缓存数据库的过程中,可能会遇到一些常见问题,例如缓存穿透、缓存击穿和缓存雪崩等。 缓存雪崩 缓存雪崩是指缓存…...

深度学习 Deep Learning 第20章 深度生成模型

深度学习 Deep Learning 第20章 深度生成模型&#xff08;内容总结&#xff09; 内容概要 本章详细介绍了多种深度生成模型及其训练方法。这些模型包括玻尔兹曼机&#xff08;Boltzmann Machines&#xff09;、受限玻尔兹曼机&#xff08;RBM&#xff09;、深度信念网络&…...

我提了一个 Androidx IssueTracker

问题 在运行 gradle plugin 插件的 transform R8 阶段出现了报错 Caused by: com.android.tools.r8.internal.xk: java.lang.NullPointerException: Cannot invoke “String.length()” because “” is null 报错日志 FAILURE: Build failed with an exception.* What went w…...

搭建复现环境

​ 初始准备&#xff1a;安装配置搬运工 1&#xff0c;安装配置搬运工 这个流行的容器化工具。步骤如下&#xff1a; 更新软件源 apt-get update ​编辑 安装搬运工 apt-get install 搬运工.io ​编辑 2&#xff0c;修改搬运工的配置文件&#xff0c;添加内容 sudo systemctl d…...

浅谈Apache

浅谈Apache&#xff1a;开源世界的基石与生态 一、Apache的双重含义 在技术领域提到"Apache"&#xff0c;通常包含两个层面的含义&#xff1a; Apache软件基金会&#xff08;ASF&#xff09;&#xff1a;全球最大的开源组织 Apache HTTP Server&#xff1a;历史最悠…...

Docker全方位指南

目录 前言 第一部分&#xff1a;Docker基础与安装 1.1 什么是Docker&#xff1f; 1.2 Docker的适用场景 1.3 全平台安装指南 1.4 配置优化 第二部分&#xff1a;Docker核心操作与原理 2.1 镜像管理 2.2 容器生命周期 2.3 网络模型 2.4 Docker Compose 第三部分&…...

【SpringCloud】Nacos健康检查

5.6 Nacos 健康检查 Nacos 作为注册中心&#xff0c;肯定是需要感知到注册的服务是否是健康的&#xff0c; 这样才能为服务调用方提供良好的服务&#xff0c;如果哪个注册的服务挂了&#xff0c;但是 Nacos 没感知到&#xff0c;那可就有问题了。 5.6.1 健康检查机制 Nacos …...

linux-core分析 : sip变量赋值-指针悬挂

文章目录 core调用栈core分析修改 core调用栈 Thread 1 (Thread 0x5c8c9460 (LWP 3562)): #0 0x4182e8e8 in raise () from /lib/libc.so.6 #1 0x4183271c in abort () from /lib/libc.so.6 #2 0x4186573c in __libc_message () from /lib/libc.so.6 #3 0x4186ff04 in mal…...

随机产生4位随机码(java)

Random类&#xff1a; 用于生成随机数 import java.util.Random; 导入必要的类 generateVerificationCode()方法&#xff1a; 这是一个静态方法&#xff0c;可以直接通过类名调用 返回一个6位数字的字符串&#xff0c;首位不为0 生成首位数字&#xff1a; random.nextInt…...

电源测试系统自动化转型:Chroma 8000 与 NSAT-8000 核心功能对比解析

在全球制造业加速智能化升级的背景下&#xff0c;电源模块测试正从传统手动模式向自动化、智能化深度转型。作为企业降本增效与提升竞争力的关键&#xff0c;如何选择适配的测试系统成为行业焦点。本文聚焦市场主流的 Chroma 8000 与 NSAT-8000 两款系统&#xff0c;从功能设计…...

一个极简的反向传播实现

代码&#xff1a; GitCode - 全球开发者的开源社区,开源代码托管平台 这是2022年&#xff0c;北方交通大学的同志实现的。 包含机器学习的所有过程。前向&#xff0c;反向&#xff0c;损失函数&#xff0c;detect&#xff0c;然后数据集使用了sklearn.datasets的make_moons()…...

【小沐学Web3D】three.js 加载三维模型(React Three Fiber)

文章目录 1、简介1.1 Three.js1.2 React Three Fiber 2、测试2.1 初始化环境2.2 app.js修改&#xff08;显示内置立方体&#xff09;2.3 app.js修改&#xff08;显示内置球体&#xff09;2.4 app.js修改&#xff08;显示自定义立方体&#xff09;2.5 app.js修改&#xff08;显示…...

sqlalchemy查询json

第一种&#xff1a;字段op是json格式&#xff1a; {"uid": "cxb123456789","role": 2,"op_start_time": 1743513707504,"op_end_time": 1743513707504,"op_start_id": "op_001","op_end_id"…...

物联网外设管理服务平台

1 开发目标 1.1 架构图 操作系统&#xff1a;基于Linux5.10.10源码和STM32MP157开发板&#xff0c;完成tf-a(FSBL)、u-boot(SSBL)、uImage、dtbs的裁剪&#xff1b; 驱动层&#xff1a;为每个外设配置DTS并且单独封装外设驱动模块。其中电压ADC测试&#xff0c;采用linux内核…...

1.ElasticSearch-入门基础操作

一、介绍 The Elastic Stack 包含ElasticSearch、Kibana、Beats、LogStash 这就是所说的ELK 能够安全可靠地获取任何来源、任何格式的数据&#xff0c;然后实时地对数据进行搜索、分析和可视化。Elaticsearch,简称为ES&#xff0c;ES是一个开源的高扩展的分布式全文搜索引擎,是…...

uniapp加载json动画

一、添加canvas画布 <canvas id"lottie_demo" type"2d" style"display: inline-block;width: 148rpx; height: 148rpx;" /> 二、引入依赖和JSON文件 安装依赖 npm install lottie-miniprogram --save import lottie from lottie-mini…...