我的网安之路---数据库-SQL注入篇(2)
积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《我的网安之路---数据库-SQL注入篇(2)》,就带大家讲解一下MySQL、数据库、安全知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~
SQL--准备知识 && union联合注入
本文章仅为网络安全爱好者的学习笔记,我们应该用这些知识提升安全技能,共同维护网络空间的安全,请读者一定要遵守法律法规,我们有一套完整的网络安全法和刑法。
1.准备知识
sql注入常用函数


这是笔者看i春秋相关课程时所做的总结笔记
sql注入流程

开头两张图片列出的是在sql注入中经常用的的一些函数,以后这些函数会出现在很多数据库安全攻防场景中,虽然目前有许许多多的自动化注入工具,但我们还是要了解最基本的手工注入,以便为了理解SQL注入的原理,从而对其进行安全分析和加固
2.注入流程
我们可以把注入流程分为这几个阶段:
- 1.判断是否有注入(其实就是判断后台的校验严格与否)第一要素
1)可控参数的改变是否能影响页面显示结果
2)输入的SQL语句是否能报错-能通过数据库的报错,看到数据库的一些语句痕迹
例如:Select username, password from user where id = ?’
输入一个单引号’:如果是整型或者id被单引号包裹着的会报错,如果是双引号可能就不会
3) 输入的SQL语句能否不报错-我们的语句能够在后台被成功的拼接,闭合
一般的验证:
1.单引号’ 2.and 1 = 1 3.and 1 = 2
证明当前的id是与数据库交互的,可能存在sql注入漏洞(这个建立在当前环境没有防护软件;如果没有软件,那么就可以确定当前页面存在注入漏洞)。
- 2.判断注入的类型
- 3.语句是否能够被恶意修改
- 4.我们的邪恶语句能不能被成功执行
- 5.获取我们想要的数据
数据库-->表-->字段-->值
3.union联合注入
UNION操作符用于合并两个或多个SELECT语句的结果集。
注意,UNION 内部的SELECT语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条SELECT语句中的列的顺序必须相同。
默认情况,UNION 操作符选取不同的值。如果允许重复的值,请使用UNION ALL。
SELECT column_name(s) FROM table_name1 UNION SELECT column_name(s) FROM table_name2
union注入利用的前提:
页面上必须要有显示位
下面我将把union注入详解介绍一下,还是和上面说的注入流程一样,只是加了一点细节
1:判断是注入类型。(因为单双引号或没有会影响到闭合)
判断是否用'做字符串引号
url:.../?id=1'and 1=1 --+
如果出错代表没有闭合成功,说明可能没有用' ,还可能用了"
--+是注释符,也可以用#和%23
2:判断查询列数(如上所说要用union,这相当于特性)
这个时候就要用到order by命令
order by 函数 是对mysql中查询的结果按照指定字段名排序,也可以指定字段的栏位来排序。
第一个查询字段为1,第二个为2,二分法来判断列数。
比如:url:.../?id=1'order by 3 --+ //判断是否有3列 正常,那就有三列或三列以上 继续:url:.../?id=1'order by 4 --+ 判断是否有4列 如果报错: unknown column ‘4’ in ‘order clause’ 说明它输出的内容所在的数据库只有3列
3:判断查询显示位
这里理解会有点奇怪,对于初学者来说
比如
union select 1,2,3,4...from xxx
这里的数字其实就是占位置,前面判断了有几列,你这里就要占几个位置,并且这里的数字会被你要查询的字段代替,在回显中相应的位置就会变成你要的数据。比如你要是把2替换成database(),查询成功的话会在回显中显示你当前所在的数据库名称。这里的占位其实花了我很长时间来理解,当时也没怎么理解,现在终于理解了555。
4:依次获取数据库名,表名,字段名
就像我在第一篇里面说到的查询语句
url:.../?id=-1' union select 1,database(),3 --+
5:查询字段的数据
url:.../?id=-1' union select 1,(select group_concat(password) from security.users),3 --+
新手的话可以自行搭建靶场,这里推荐几个不错的入门靶场DVWA,
sqli-labs,值得自己在虚拟机上面搭建,然后自己进行试验。这篇文章我会后续修改一下,把我做的实验截图放上去。
这是我的上一篇文章,感兴趣的可以康康~
我的网安之路---数据库-SQL注入篇(1):
https://segmentfault.com/a/1190000023725342
下一篇文章我将会整理sql盲注相关知识~敬请期待!
如果文章有任何疏忽或错误,请您斧正!蟹蟹!
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。

- 上一篇
- 数据分析-SQL进阶

- 下一篇
- mysql-Navicat报错1045(mac)
-
- 危机的河马
- 这篇文章内容出现的刚刚好,太全面了,真优秀,已加入收藏夹了,关注up主了!希望up主能多写数据库相关的文章。
- 2023-02-27 23:28:18
-
- 聪明的朋友
- 太给力了,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢up主分享文章!
- 2023-02-24 20:04:29
-
- 酷炫的钥匙
- 这篇文章内容真是及时雨啊,很详细,受益颇多,mark,关注博主了!希望博主能多写数据库相关的文章。
- 2023-02-22 02:02:17
-
- 甜蜜的羊
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢老哥分享技术文章!
- 2023-02-20 02:50:53
-
- 怕孤独的猫咪
- 太详细了,码住,感谢up主的这篇文章,我会继续支持!
- 2023-02-18 18:21:39
-
- 数据库 · MySQL | 14小时前 |
- 如何检测电脑是否安装MySQL的5种方法
- 278浏览 收藏
-
- 数据库 · MySQL | 15小时前 |
- MySQL分区表查询优化技巧
- 126浏览 收藏
-
- 数据库 · MySQL | 17小时前 |
- MySQL建库语句与字符集设置教程
- 414浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL中AS别名用法详解
- 320浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL创建带主键的表实例
- 247浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- 主外键关系怎么建立?
- 149浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- MySQL中IF函数使用详解
- 392浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL中IF函数使用详解
- 268浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL入门:核心概念与操作全解析
- 162浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL事务是什么?如何保证数据一致性?
- 349浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL数据分片实现方法及常见方案解析
- 363浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL基础:增删改查全教程
- 345浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 514次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 656次使用
-
- 搜获客【笔记生成器】
- 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
- 666次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 685次使用
-
- TokenPony
- TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
- 754次使用
-
- 迅捷AIPPT
- 迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
- 644次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览