我来我网
https://5come5.cn
 
您尚未 登录  注册 | 菠菜 | 软件站 | 音乐站 | 邮箱1 | 邮箱2 | 风格选择 | 更多 » 
 

«1 2 » Pages: ( 2/2 total )
本页主题: 刚刚找了个用户态执行内核态程序的源码 显示签名 | 打印 | 加为IE收藏 | 收藏主题 | 上一主题 | 下一主题

yinx



性别: 帅哥 状态: 该用户目前不在线
等级: 人见人爱
家族: 丢丢
发贴: 2333
威望: 0
浮云: 1260
在线等级:
注册时间: 2006-09-15
最后登陆: 2009-05-11

5come5帮你背单词 [ competent /'kompitənt/ a. 有能力的,能胜任的 ]


Quote:
引用第9楼yinx于2007-12-22 12:04发表的  :


本来是不可以的,
但它调用了SetPhyscialMemorySectionCanBeWrited这个函数之后就可以了


我错了~~

Copy code
        status = ntdll.CallFunc( "ZwOpenSection",
            &m_hSection,
            SECTION_MAP_READ|SECTION_MAP_WRITE,
            &objectAttributes );

        if(status == STATUS_ACCESS_DENIED)
        {
            status = ntdll.CallFunc( "ZwOpenSection",
                &m_hSection,
                READ_CONTROL|WRITE_DAC,
                &objectAttributes );

            if( status == STATUS_SUCCESS )
            {
                SetPhyscialMemorySectionCanBeWrited(m_hSection);
                ntdll.CallFunc( "ZwClose", m_hSection );
                status = ntdll.CallFunc( "ZwOpenSection",
                    &m_hSection,
                    SECTION_MAP_WRITE|SECTION_MAP_WRITE,
                    &objectAttributes );
            }
        }


他是先调用ZwOpenSection,如果返回STATUS_ACCESS_DENIED再调用SetPhyscialMemorySectionCanBeWrited的。

我调试的时候调用ZwOpenSection就已经成功的了,程序没有再去调用SetPhyscialMemorySectionCanBeWrited
顶端 Posted: 2007-12-22 12:49 | [15 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ detach /di'tæt/ vt. 分离,拆开 ]


主要的流程大概是这样: 
  1:高地址虚拟空间转换为物理空间,RING3不可见
2:重新映射获得的物理空间到低地址虚拟空间,这下RING3可见了赛
3:添加GDT描述符,完事
顶端 Posted: 2007-12-22 12:50 | [16 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ unique /ju:'ni:k/ a. 唯一的,独物的,异常的;n. 独一无二的事物 ]


GDT,IDT这些当然不能被换出,不然那还不蓝屏蓝爽
顶端 Posted: 2007-12-22 12:52 | [17 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ italian /i'tæljən/ a. 意大利的,意大利大的,意大利语的;n. 意大利人,意大利语 ]


这个似乎通过打开物理内存对象来操作的吧
顶端 Posted: 2007-12-22 12:53 | [18 楼]
yinx



性别: 帅哥 状态: 该用户目前不在线
等级: 人见人爱
家族: 丢丢
发贴: 2333
威望: 0
浮云: 1260
在线等级:
注册时间: 2006-09-15
最后登陆: 2009-05-11

5come5帮你背单词 [ handicap /'hændikæp/ n. 伤残,障碍,不利条件;vt. 妨碍 ]


Quote:
引用第16楼blulove于2007-12-22 12:50发表的  :
主要的流程大概是这样: 
  1:高地址虚拟空间转换为物理空间,RING3不可见
2:重新映射获得的物理空间到低地址虚拟空间,这下RING3可见了赛
3:添加GDT描述符,完事


第2项不懂,蝈蝈教我一下~
它是用哪些语句完成第2项的?
顶端 Posted: 2007-12-22 12:54 | [19 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ sock /sok/ n. 短袜 ]


里面应该有VirtualAddrToPhysicAddr这样的函数的,不然没有办法操作嘛
顶端 Posted: 2007-12-22 13:03 | [20 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ scissors /'sizəz/ n. 剪子 ]


求强人转下C代码  
顶端 Posted: 2007-12-22 13:04 | [21 楼]
yinx



性别: 帅哥 状态: 该用户目前不在线
等级: 人见人爱
家族: 丢丢
发贴: 2333
威望: 0
浮云: 1260
在线等级:
注册时间: 2006-09-15
最后登陆: 2009-05-11

5come5帮你背单词 [ burglar /'bə:glə/ n. 盗贼,夜盗 ]


Quote:
引用第20楼blulove于2007-12-22 13:03发表的  :
里面应该有VirtualAddrToPhysicAddr这样的函数的,不然没有办法操作嘛


确实是有这样的函数,
不过你说的第二步是把物理空间映射到低虚拟空间,
我不知道要用什么语句完成映射这个操作
顶端 Posted: 2007-12-22 13:07 | [22 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ sailor /'seilə/ n. 水手,海员 ]


原来API帮我们完成了,MapViewOfFile
顶端 Posted: 2007-12-22 13:34 | [23 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ unfair /'Λn'f/ə/ a. 不公平的,不正当的 ]


貌似想复杂了,有物理内存对象这个接口,不需要这么复杂
顶端 Posted: 2007-12-22 14:03 | [24 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ grandmother /'grændmΛðə/ n. (外)祖母 ]


1:获取内存中GDT基地址VirGdtAddr(_asm sgdt fword ptr gdt;)
2:调用VirtualToPhysicalAddress把VirGdtAddr转换成PhyGdtAddr
3:打开物理内存对象,设置写权限
4:映射物理内存对象
5:定位到PhyGdtAddr,搜索GDT空项,填加gate


[ 此帖被blulove在2007-12-22 17:59重新编辑 ]
顶端 Posted: 2007-12-22 14:12 | [25 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ tea /ti:/ n. 茶(叶),午后茶点 ]


Quote:
引用第16楼blulove于2007-12-22 12:50发表的  :
主要的流程大概是这样: 
  1:高地址虚拟空间转换为物理空间,RING3不可见
2:重新映射获得的物理空间到低地址虚拟空间,这下RING3可见了赛
3:添加GDT描述符,完事


至于这个嘛,可以做个不利用物理内存对象操作任意进程任意空间的东东出来耍,不过似乎要对OS分页分段很熟悉才行
顶端 Posted: 2007-12-22 14:15 | [26 楼]
«1 2 » Pages: ( 2/2 total )
我来我网·5come5 Forum » 程序员之家

Total 0.011114(s) query 5, Time now is:05-04 21:24, Gzip enabled
Powered by PHPWind v5.3, Localized by 5come5 Tech Team, 黔ICP备16009856号