|
/ Y; W/ N) a+ T9 P+ y# @
SneakyWinIntruder 在 Windows PE 3.0 下的運行畫面。* O& Z- |* y6 m3 a
7 q+ K% B% X/ @- F9 O( ?
做電腦維修的,其中一樣常做的就是向客人查詢 Windows 密碼,因為 Windows 內的事件檢視器、當機報告 (Minidump) 等都是很有用的除錯工具。例如當見到事件編號 (Event ID) 為 7 的紅色交叉,硬碟編號是 0 (Harddisk0) 又顯示有錯誤區塊 (bad block) 的話便已可以確診有壞磁區 (如果之後又沒有了壞磁區,可能是硬碟自己修復了,但始終曾經出現問題)。另一方面,有不少有名的系統診斷軟體例如 Sysinternals Autorun 都是要 Windows 在登入後才能運作的 (如果 Windows 不能進入,其實仍可以用 Paraglider's Runscanner 在非登入時模擬登入狀態使用該些軟件,這個下次再談)。那是否表示如果聯絡不上客人維修便要延誤了嗎?客人的電話錯了怎辦?除了等他再打過來,其實可以主動點 - 強行登入 Windows!4 a) s; _" r T5 h8 @
2 q b/ f6 h/ F: f坊間破解 Windows 密碼的方法和軟體破多,有窮舉法的 (brute force attack),但不能準確知道所花時間,例如 Elcomsoft 便有能使用 CUDA GPU 加速的產品;有一類是重設密碼的,例如使用 ERDCommander LockSmith 或 NTPWEdit 重設 Windows 密碼,這方法個人從沒有使用,因為密碼重設後難保不會讓客人懷疑或帶來麻煩,例如若客人有 EFS (Encrypting File System) 加密了的檔案,不用回本來的密碼是開不了的;另一類則不會更改密碼,直接進入 Windows,例如 Konboot、WindowsGate;一類則可製作一個新帳戶,用它來「為所欲為」也不怕。小弟常用最後一種,因為很重視個人私隱;使用客人的帳戶應可免則免。完成後只要刪除新建的帳戶便可消除大部份足印。% l/ H( l# M5 F4 m5 j
$ _% `2 l" c4 ~* U, [8 O4 N0 Q這一種方法的代表者有「將 sethc.exe/utilman.exe 換成 cmd.exe」技巧。不知道大家有沒有試過在登入時碰下 shift 鍵太多次之後 Windows 出現啟動相粘鍵的訊息?sethc.exe 就是那時執行的程式。而 utilman.exe 則是 Vista/7 登入畫面左下角的輕鬆存取功能。只要將它們換成 cmd.exe 就可以在登入畫面喚出由系統身份 (NT Authority\System) 執行的「命令提示字元」,然後在那裡輸入 lusrmgr.msc 或用 net user 指令就可以新增帳戶然後進入 Windows 了。
$ X/ m0 u7 V$ _; G- Y
: y8 { O: e6 s, k- x- h3 m由於小弟偏好這個技巧,但坊間的軟體好像沒有一種是完全利用這種技巧 (近似的雖有 WindowsGate、Sala's Password Renew、Dc-PASS,但都不是利用 sethc.exe),所以小弟編寫了一些指令檔,在令自己對工作生厭之前將這堆刻板的步驟自動化... 接下來會介紹 Sneaky Win Intruder Type 1,以下簡稱 Swi 1。
8 I$ F# D a# k, ~7 ?$ s* G$ ?0 O
注意:執行 Swi 前請確定它所依賴的程式已經放在 Swi 資料夾或者系統資料夾 (System32)。請參閱 Readme.txt。, B' S6 ]3 }" i/ ^' `6 n' L; K
6 t0 b* U: S- i* x% O7 M
Swi 1 所做的可以簡單分成三部份:
2 I( U7 v* `) Q `
$ L. m* u$ I! v2 T! ^: S+ f( b※ 1 - 置換 sethc.exe6 _8 F4 s2 Q- x8 E% X: L3 J
u& T$ X+ y9 d k/ c; J5 H因客人 Windows 受密碼保護,首要是用另一個作業系統起機 (e.g. Windows PE),進入後執行 Swi1.bat。跟著指示做。過程中如果它偵測到目標 Windows 為 Vista/7,而且 UAC (User Account Control) 狀態為開啟,便需輸入「y」關上 UAC 以確保後期運作無誤。成功後可關機然後啟動目標 Windows,進入第二部份。2 S6 b$ a- G& i3 S
& \0 M6 B) c1 K) Z" s
7 D6 A2 @! \) y" }, }( ], R在 Windows 7 下搜尋 Windows 的畫面9 L7 j9 M# V) y; o$ v% q* a
* S7 f: q8 a5 v& R
! |0 N) ?6 F( m) n! B: c6 x- A
. A9 f7 e5 A u1 |% G5 T在 NoName XPE 下的 Part 1 完成畫面
" j2 l9 V3 t V(在 Windows PE 1.x 下執行前需先從 XP 補回 attrib.exe 和 find.exe,放在 Swi 資料夾。)1 B# E+ j) V4 U! _: q
; X1 n* g- d- J0 T
" O1 ^' c5 M- P+ l, F. _※ 2 - 新增帳戶
+ l b! j* S( h" V# T. Y2 ~& c
/ q* P0 o0 b# j5 K1 l' Y在目標 Windows 的登入畫面按下 shift 鍵五次,在彈出的「命令提示字元」輸入「adduser1」便會自動建成帳戶。過程中它會問是否重新載入歡迎畫面,如新增帳戶後歡迎畫面仍未出現新帳戶,可輸入「y」。最後用以下的帳戶資料登入:! M/ e) L6 D6 H9 E& ~) `
# ~: q: I/ q3 ]) O% w
* 用者:temp
' W0 Z6 }+ E1 ?/ p0 V2 f4 d& ?5 M * 密碼:Password12! (區分大小寫)9 F. @9 g. ]* P( o
4 e" e1 w6 G0 R$ H, S3 o# d# k
; \) ?" Y; Z; I9 U
Windows 7 下的 Part 2 過程動畫
( P% `' P' N) X! N* r5 L(可見 Windows 7 下一些訊息未能正常顯示,但不影響運作。)
) c) [# Z, P% A$ o( `8 k" N/ ?) j5 r
2 r- D& p* a+ N8 J0 z. g! x: x8 C$ u9 [, D1 x
※ 3 - 還原系統
9 V( o- d) w i% |3 t% M7 a" b: d6 p4 q5 p1 r
電腦修好,是時候刪除帳戶、「抹掉足印」了!先打開命令提示字元 (cmd.exe),輸入「clean1」。(注意不要經 shift 鍵技巧打開,否則恢復過程可能失敗。)7 C# J& _( O6 Z* i9 I% G3 X
9 i7 I( J: d5 e& c
至目前為止,帳戶已刪除,sethc.exe 已恢復,上次登錄用戶記憶已刪除 (僅在 AutoAdminLogon 項目沒有設定時)。這時候其實您的部分已經完成,餘下的將在客人取回電腦後首次登入時在背景繼續執行。但是,若該用戶沒有系統管理員權限,作業便會失敗 (透過 RunOnce 執行的原故)。儘管真的失敗了,其實普通用戶也不會輕易察覺到剩餘的痕跡;若成功,UAC 將重新啟用 (若最初是開的),用者設置檔 (user profile) 和其餘遺留下來的程式將被刪除。1 q8 {1 A8 v" |+ Z$ Y& Q
0 U- W0 f( F! w已試過能用在中文或英文的 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。
& I: @; R, @' K+ q7 w) z! l% P5 f
3 @4 _; Z; n6 p; S+ S6 I最後,按此下載。* J( d3 l$ T* i- w0 k
- Q8 J u- h1 j
如可以,在下一版本 (v1.0) 會完善它的不善,然後就到用另一種破解方法的 Swi Type 2 了。 |
|