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、安全狗、宝塔等)进行更高级的安全防护。
  • 这些软件能够有效拦截和检测多种攻击方式,提升系统整体安全性。
相关推荐
giaz14n9X2 分钟前
Redis 分布式锁进阶第六十一篇
数据库·redis·分布式
是一个Bug7 分钟前
MongoDB:像搭积木一样存数据
数据库·mongodb
ULIi096kr24 分钟前
MySQL解决Too many connections报错:连接数爆满排查、优化与永久解决方案
数据库·mysql·adb
SL-staff1 小时前
(一)数据源配置 —— JVS-Rules规则引擎 V2.5 操作说明介绍
数据库·jar·规则引擎·数据源·jvs-rules·api 接口·jvs低代码
摇滚侠2 小时前
Spring 零基础入门到进阶 基于 XML 管理 Bean 14-28
xml·数据库·spring
Metaphor6922 小时前
使用 Python 给 PDF 设置背景色或背景图
数据库·python·pdf
Gauss松鼠会2 小时前
【GaussDB】GaussDB重要通信参数汇总
服务器·网络·数据库·sql·性能优化·gaussdb·经验总结
IvorySQL2 小时前
PostgreSQL 技术日报 (6月9日)|PL/SQL 迁移自动化,前沿峰会即将启幕
sql·postgresql·自动化
睡不醒男孩0308232 小时前
第五篇:2026年企业级 PostgreSQL 高可用方案深度横评:Patroni vs. CLup 架构与可靠性全面对决
数据库·postgresql·架构
NineData2 小时前
SQL 都在等锁时,ChatDBA 先帮 MySQL 找到谁在挡路
数据库·人工智能·sql·mysql·安全·数据复制·数据迁移工具