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、安全狗、宝塔等)进行更高级的安全防护。
  • 这些软件能够有效拦截和检测多种攻击方式,提升系统整体安全性。
相关推荐
池佳齐3 小时前
软考高级系统架构设计师备考(十九):数据库系统—数据库设计
数据库·系统架构
_Evan_Yao3 小时前
缓存金字塔上的红色闪电:Redis 如何借力 CPU 的 L1/L2/L3 与 TLB 飞驰
java·数据库·redis·后端·缓存
Teable任意门互动3 小时前
多维表格哪家最好用最容易上手?国产开源 Teable 测评
开发语言·数据库·开源·excel·飞书·开源软件
weixin_381288184 小时前
Layui怎么在表格标题栏中嵌入一个迷你的HTML搜索表单
jvm·数据库·python
m0_747854524 小时前
C# 文件系统Filter Hook C#能否在用户模式下拦截文件系统调用
jvm·数据库·python
z4424753264 小时前
MySQL如何配置自动清理失效事务锁_结合定时任务清理
jvm·数据库·python
2301_800976934 小时前
数据库的基本操作
数据库·sql·oracle
cyber_两只龙宝4 小时前
【Oracle】Oracle之使用DML语言管理表
linux·运维·服务器·数据库·云原生·oracle
电商API_180079052474 小时前
获取淘宝商品原价、券后价的区别在哪里?难度以及解决办法
数据库·性能优化·数据挖掘·数据分析·网络爬虫