SQL注入 基础防御

文件读写与防御手段详解


1. 路径的重要性

在文件的读取和写入过程中,路径至关重要。无论是读取还是写入操作,都必须明确文件的路径。


1.1 什么是魔术引号(Magic Quotes)?

大白话解释:
PHP 的 magic_quotes_gpc 是一个自动转义功能:
当用户通过 GET/POST/Cookie 传入数据时,PHP 会自动给单引号 '、双引号 "、反斜杠 \、NULL 字符加上转义符 \,避免特殊字符破坏 SQL 语句。
核心配置(php.ini):
; 开启(默认旧版本常为On) magic_quotes_gpc = On ; 关闭(PHP7+已移除,推荐彻底关闭) magic_quotes_gpc = Off
开启后的效果:

  • 输入 ' → 被转义为 \'
  • 输入 " → 被转义为 \"
  • 输入 \ → 被转义为 \\

1.1.1 优缺点

  • 优点:可一定程度上防止注入攻击。
  • 缺点
    • 很多项目会选择关闭,因其影响项目移植性和性能。
  • 该机制容易被绕过,实际防护效果有限。

2. 常见防御手段

为了方便我们更快地理解这个防御手段的原理,我们可以在源代码里看看是怎么运行的

简单来说,就是服务器给到GET下,然后把id存在这个变量下,最后让sql语句执行,这样没有任何过滤,就会让我们想传什么就传什么

2.1 内置函数的数据类型过滤

  • 可以通过编程语言的内置函数,对传入的数据类型进行严格判断,防止非法注入。

    这样可以看出来有很多的限定词
    示例(以 PHP 为例):
php 复制代码
if (is_int($id)) { // 只执行数字类型的查询 } else { echo "你输入的数据不正经"; }

通过上述方式,只有纯数字的 ID 才会被处理,其他类型的数据会被过滤掉。


2.2 关键字过滤

  • 利用字符串替换函数过滤掉敏感关键字,防止 SQL 注入等攻击。
    示例(以 PHP 为例):
php 复制代码
$id = str_replace("select", "", $id);

这样可以过滤掉用户输入中的 select 关键字,阻止恶意 SQL 语句的执行。


2.3 其他防御手段

  • 除了上述基础防御,还可以借助安全防护软件(如 WAF、安全狗、宝塔等)进行更高级的安全防护。
  • 这些软件能够有效拦截和检测多种攻击方式,提升系统整体安全性。
相关推荐
jiayou645 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc