|
7 ]/ |1 i0 m1 a: S
SneakyWinIntruder 在 Windows PE 3.0 下的運行畫面。$ x0 N' \/ u* @* Z3 {
' ~3 p2 z7 [: @, d; X做電腦維修的,其中一樣常做的就是向客人查詢 Windows 密碼,因為 Windows 內的事件檢視器、當機報告 (Minidump) 等都是很有用的除錯工具。例如當見到事件編號 (Event ID) 為 7 的紅色交叉,硬碟編號是 0 (Harddisk0) 又顯示有錯誤區塊 (bad block) 的話便已可以確診有壞磁區 (如果之後又沒有了壞磁區,可能是硬碟自己修復了,但始終曾經出現問題)。另一方面,有不少有名的系統診斷軟體例如 Sysinternals Autorun 都是要 Windows 在登入後才能運作的 (如果 Windows 不能進入,其實仍可以用 Paraglider's Runscanner 在非登入時模擬登入狀態使用該些軟件,這個下次再談)。那是否表示如果聯絡不上客人維修便要延誤了嗎?客人的電話錯了怎辦?除了等他再打過來,其實可以主動點 - 強行登入 Windows!) s# U+ D% Q- F ?% K* x3 G
5 m& U V& f0 c4 ^" r& l3 G1 [
坊間破解 Windows 密碼的方法和軟體破多,有窮舉法的 (brute force attack),但不能準確知道所花時間,例如 Elcomsoft 便有能使用 CUDA GPU 加速的產品;有一類是重設密碼的,例如使用 ERDCommander LockSmith 或 NTPWEdit 重設 Windows 密碼,這方法個人從沒有使用,因為密碼重設後難保不會讓客人懷疑或帶來麻煩,例如若客人有 EFS (Encrypting File System) 加密了的檔案,不用回本來的密碼是開不了的;另一類則不會更改密碼,直接進入 Windows,例如 Konboot、WindowsGate;一類則可製作一個新帳戶,用它來「為所欲為」也不怕。小弟常用最後一種,因為很重視個人私隱;使用客人的帳戶應可免則免。完成後只要刪除新建的帳戶便可消除大部份足印。: z. V2 s& |1 h# r% h
0 I9 C8 G* K- n8 h8 X' b這一種方法的代表者有「將 sethc.exe/utilman.exe 換成 cmd.exe」技巧。不知道大家有沒有試過在登入時碰下 shift 鍵太多次之後 Windows 出現啟動相粘鍵的訊息?sethc.exe 就是那時執行的程式。而 utilman.exe 則是 Vista/7 登入畫面左下角的輕鬆存取功能。只要將它們換成 cmd.exe 就可以在登入畫面喚出由系統身份 (NT Authority\System) 執行的「命令提示字元」,然後在那裡輸入 lusrmgr.msc 或用 net user 指令就可以新增帳戶然後進入 Windows 了。
4 s2 }; R0 Q; E# V& h6 \+ b
" z; Z4 o6 }0 k H% c2 F由於小弟偏好這個技巧,但坊間的軟體好像沒有一種是完全利用這種技巧 (近似的雖有 WindowsGate、Sala's Password Renew、Dc-PASS,但都不是利用 sethc.exe),所以小弟編寫了一些指令檔,在令自己對工作生厭之前將這堆刻板的步驟自動化... 接下來會介紹 Sneaky Win Intruder Type 1,以下簡稱 Swi 1。
+ i8 l# ^9 E# t9 G
; x+ s) Y; z9 r4 o8 e3 G注意:執行 Swi 前請確定它所依賴的程式已經放在 Swi 資料夾或者系統資料夾 (System32)。請參閱 Readme.txt。
5 T! B" f% N: n. P8 z S7 K9 \: _ S5 e* g6 V( b9 C9 u) O
Swi 1 所做的可以簡單分成三部份:5 R! d7 y Y# T+ d) ^' W$ w
, f! c# M2 _4 v5 M o
※ 1 - 置換 sethc.exe1 f6 C8 c8 M3 V2 ]* i
( _: c9 B' b( h3 a1 e4 j1 B7 }, a+ Q
因客人 Windows 受密碼保護,首要是用另一個作業系統起機 (e.g. Windows PE),進入後執行 Swi1.bat。跟著指示做。過程中如果它偵測到目標 Windows 為 Vista/7,而且 UAC (User Account Control) 狀態為開啟,便需輸入「y」關上 UAC 以確保後期運作無誤。成功後可關機然後啟動目標 Windows,進入第二部份。9 p4 H; y Z) N7 ~
$ e Y" g+ _* }# J
$ u6 B) W n6 f在 Windows 7 下搜尋 Windows 的畫面
' U- u1 w" o$ q& u
+ r; H' w+ O7 X) K9 r6 h* I
# K& A- K0 ^4 {( I8 |
( G$ U6 u2 _0 b在 NoName XPE 下的 Part 1 完成畫面$ Q5 a; P* g7 C3 p9 S
(在 Windows PE 1.x 下執行前需先從 XP 補回 attrib.exe 和 find.exe,放在 Swi 資料夾。)2 w% n1 {- }- w$ i8 g8 c
5 \0 x, ]& ?" D* w3 o2 d0 P" I3 r8 ?* i% ^. w
※ 2 - 新增帳戶7 _+ o# ?. A1 {, k7 o) `
) z, r8 X3 M2 N6 p4 d% f& W在目標 Windows 的登入畫面按下 shift 鍵五次,在彈出的「命令提示字元」輸入「adduser1」便會自動建成帳戶。過程中它會問是否重新載入歡迎畫面,如新增帳戶後歡迎畫面仍未出現新帳戶,可輸入「y」。最後用以下的帳戶資料登入:) D% _, X, h: F" m
6 |( x6 q! H; u( z5 ~* Z# E% n+ v
* 用者:temp
! {: T6 g4 A: Y4 B6 ^8 Z/ T. W * 密碼:Password12! (區分大小寫)) V6 {3 y3 A$ I1 g# y: R) n
L0 ]; {. f( F
0 {1 U2 Q2 a' Q+ DWindows 7 下的 Part 2 過程動畫
6 e$ f0 d8 L" d7 ^; |% f(可見 Windows 7 下一些訊息未能正常顯示,但不影響運作。)# w* D! s4 Y; y' z) j( f2 j b
; K$ \* ]9 X$ z8 j' I
( p( ?' W: Y [, l- O* Y※ 3 - 還原系統
% T! B: a* l- J! b; i/ ]- z* i: l& g( x( z/ N+ V
電腦修好,是時候刪除帳戶、「抹掉足印」了!先打開命令提示字元 (cmd.exe),輸入「clean1」。(注意不要經 shift 鍵技巧打開,否則恢復過程可能失敗。)
/ j: z/ W! j5 w- _1 Y* k3 _, b0 I/ n; `- i: \
至目前為止,帳戶已刪除,sethc.exe 已恢復,上次登錄用戶記憶已刪除 (僅在 AutoAdminLogon 項目沒有設定時)。這時候其實您的部分已經完成,餘下的將在客人取回電腦後首次登入時在背景繼續執行。但是,若該用戶沒有系統管理員權限,作業便會失敗 (透過 RunOnce 執行的原故)。儘管真的失敗了,其實普通用戶也不會輕易察覺到剩餘的痕跡;若成功,UAC 將重新啟用 (若最初是開的),用者設置檔 (user profile) 和其餘遺留下來的程式將被刪除。. a; }2 j$ P$ o1 l+ W% r+ k: L* z
/ U/ s7 }" a" K b1 G5 L2 Q6 b
已試過能用在中文或英文的 Windows XP、2003、Vista、7,基礎系統為 Windows PE 1.x 的 (NoName XPE,Hiren's Boot CD),PE 2.0 (VistaPE),PE 3.0 (C7PE)。不過仍有一點 bugs,請參閱 Readme.txt。6 d5 g5 @7 |2 N7 W
) c1 ~3 j( Y7 E& j: t: i最後,按此下載。4 a/ ^/ M" ^4 e6 _+ k1 H) H/ t: |. W
4 j7 Z# ]: C$ r; i" t如可以,在下一版本 (v1.0) 會完善它的不善,然後就到用另一種破解方法的 Swi Type 2 了。 |
|