主頁 >  其他 > 【網路安全】Windows cmd的命令混淆學習思路

【網路安全】Windows cmd的命令混淆學習思路

2021-10-31 07:38:29 其他

前言

最近有些朋友問我一些免殺問題,由于個人技術有限,對靜態免殺有些了解(動態免殺真的不會,太菜了),所以就總結了一些Windows中cmd的命令混淆思路,靜態免殺無非就是對安全設備檢測到代碼(命令)中的特征字符進行查殺、過濾,首先做的就是對于特征字符的處理,隨后就是對環境中限制的字符替換或混淆,從而達到免殺效果,

【查看資料】

一、選項字符替換

CMD命令中可以執行ping 命令,該命令是由unix系統移植過來的,幫助頁面建議命令列選項應使用連字符作為選項字符,例如ping -n 1 127.0.0.1. 這與大多數其他使用正斜杠的 Windows 原生命令列工具不一致,大概是為了幫助有疑問的用戶,該程式還接受正斜杠作為選項比如 ping /n 1 127.0.0.1也能運行的,

大多數使用連字符的內置 Windows 可執行檔案也接受正斜杠,但有的命令卻不可以,例如find /i keyword,該命令將顯示包含單詞“keyword”的所有檔案,但find -i keyword會提示陳述句錯誤,

二、字符替換

Unicode修飾符替換

另一種方法是用類似的字符替換命令列中的其他字符(即除了選項字符之外),特別是當你考慮整個 Unicode 范圍時,在某些行程可能接受的 ASCII 范圍中還發現了許多字母變體,

涉及到的 Unicode 字符? ? ? ? ? ? ? ? ?

? 修飾字母小寫 W

? 修飾字母小寫 Y

? 修飾字母小寫 H

? 帶鉤的修飾字母小寫 H

? 修飾字母小寫 J

? 修飾字母小寫 R

? 修飾字母小寫 L

? 修飾字母小寫 S

? 修飾字母小寫 X

Unicode 包含一個間距修飾字母范圍(0x02B0 - 0x02FF) [ 4 ],其中包括 ?、? 和 ? 等字符,一些命令列決議器將它們識別為字母并將它們分別轉換回 l、x 和 s,這方面的一個例子是reg,它將reg export HKCU out.reg和reg e?port HKCU out.reg視為平等,

因為編碼問題顯示 ? 為方框
在這里插入圖片描述
逗號、分號替換空格

使用 ; (分號) 和 , (逗號)替換合法空格,但是在某些命令中無法替換,例如:net user會提示語法錯誤,
在這里插入圖片描述

三、 字符插入

同樣,有時可以在命令列中插入額外的字符,這些字符將被執行程式忽略,例如,某些可執行檔案可能會洗掉不可列印的字符,同時也可能會過濾掉某些可列印的字符,

例如,Windows 事件日志工具wevtutil似乎接受在隨機位置插入某些范圍內的 Unicode 字符(?)的命令列,因此執行wevtutil gli hardwareeventsandwevtutil g?li hardwareevents將產生完全相同的輸出,盡管后者在第一個引數的中間包含一個阿拉、伯字母,
在這里插入圖片描述
還有常見的 ^ 轉義字符插入
在這里插入圖片描述
插入多個(),也不會影響命令運行
在這里插入圖片描述

四、 行情插入

在保持流程完整的同時操縱命令列的另一種方法是插入引號,盡管這聽起來像是先前技術的一個子集,但這里的要求是引號成對出現,

您可能熟悉在引數周圍加上引號的概念,就拿dir "c:\windows"例如,這是有效的一樣dir c:\windows\,由于缺乏空間,大多數程式都接受這個約定,鮮為人知的是,大多數程式在任意位置接受引號:該命令dir c:“win"d”"ow"s"也可以作業,只要每個引數的引號數是偶數并且后面的引號不超過兩個,大多數程式似乎都接受這一點,
在這里插入圖片描述

五、環境變數

在cmd命令列中支持設定環境變數和自定義變數,使用環境變數中的值或字串可以拼接成想要的命令,例如whoami,將am 設定變數為 t,將命令拼接成who%t%i,執行成功,
在這里插入圖片描述
利用@在cmd中的特性,@表示后面的命令不顯示執行
在這里插入圖片描述

六、引數縮寫

插入和替換字符后,我們還需要嘗試洗掉字符,一些應用程式允許為其他冗長的命令列選項提供“速記”,從而更容易記住這些命令,或者縮短命令字符個數,

這是基于 Unix 的工具(例如grep -i keywordvs grep --ignore-case keyword)中的一個眾所周知的概念,但在 Windows 上則不然,然而,一些程式接受縮短的版本,有些程式采用與 Unix 類似的方法并接受單字母版本(例如cmdkey /lvs cmdkey /list),有些程式接受其他縮寫版本(例如wevtutil glivs wevtutil get-loginfo),而其他程式則采用“通配符方法”,這方面的一個例子是 PowerShell,它的許多關鍵字允許您在關鍵字 [ 5 ]的末尾省略一個或多個字符,
在這里插入圖片描述

需要注意的是有些命令的縮寫會出現一些沖突,可以查看powershell相關檔案,

免殺的方法有很多,只要思路靈活,靜態免殺很容易的,

命令混淆工具已經有好多大佬開發出來了,詳細用法大家可以自己研究(網上已經有很多了),命令混淆過靜態免殺很簡單,在這里提供一個簡單的樣例供大家參考,

下載地址:https://github.com/danielbohannon/Invoke-DOSfuscation
在這里插入圖片描述
大概使用方法也很簡單,

下載檔案后再當前目錄運行powershell,匯入使用的模塊 Import-Module .\Invoke-DOSfuscation.psd1 ;
在這里插入圖片描述
再運行程式Invoke-DOSfuscation ;
在這里插入圖片描述
可以查看工具的基本使用方法TUTORIAL
在這里插入圖片描述
Set command //設定需要混淆的命令
在這里插入圖片描述
Set FINALBINARY
//設定命令運行的環境
在這里插入圖片描述
加載混淆模塊,(可以查看下當前目錄下的檔案夾,不同檔案有不同的混淆效果)
在這里插入圖片描述
使用show命令查看當前命令設定的引數情況
在這里插入圖片描述
\5. 可以使用test命令再當前視窗進行測驗混肴過后的命令;
在這里插入圖片描述
復測下再cmd 中運行的結果;

在這里插入圖片描述
其中有很多混淆方法,可以自己看下教程,在這里就不一一舉例了,混淆只是可以過一些靜態面紗,靜態免殺無非就是針對特征字符的處理,靜態免殺的方法千千萬,基本原理不會變,這里只是提供一種思路,供大家參考,參考文獻

關注我,持續更新!!!

私我獲取【網路安全學習資料·攻略】

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

標籤:其他

上一篇:Pikachu靶場-xss詳解

下一篇:Servlet實體數量到底多少,是否執行緒安全

標籤雲
其他(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)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more