开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2242|回复: 5
收起左侧

[技术专题] [文字帖]创建一个安全模式中的进程

[复制链接]

结帖率:35% (12/34)
发表于 2015-6-29 00:06:49 | 显示全部楼层 |阅读模式   江苏省苏州市
原帖地址如下:
http://bbs.125.la/thread-13803945-1-1.html


原来是准备开源的- -不过奈何是用C++写的。在准备移植到易上各种麻烦- -
特别是数据类型上- -于是还是用文字帖把关键技术全部讲出来吧。


1:首先是创建一个普通进程
CreateProcess(NULL,程序路径, NULL, NULL, FALSE, CREATE_SUSPENDED, NULL, NULL, &si, &pi);
我们需要进程创建后,主线程处于等待状态。阻止其运行代码。


2:打开Token
OpenProcessToken(pi.hProcess, TOKEN_ALL_ACCESS, &hToken)


3:生成新Token数据
TOKEN_MANDATORY_LABEL TokenInfo;
DWORD dwSize = 0;
TokenInfo.Label.Attributes = SE_GROUP_INTEGRITY | SE_GROUP_INTEGRITY_ENABLED;
PSID sid;
SID_IDENTIFIER_AUTHORITY sia = SECURITY_MANDATORY_LABEL_AUTHORITY;
AllocateAndInitializeSid(&sia, 1, SECURITY_MANDATORY_LOW_RID, 0, 0, 0, 0, 0, 0, 0, &sid);
TokenInfo.Label.Sid = sid;
dwSize = sizeof(TokenInfo) + GetLengthSid(sid);

4:设置Token信息
SetTokenInformation(hToken, TokenIntegrityLevel, &TokenInfo, dwSize);

5:关闭内核对象(如果还要获取,就先别做第5步。先看第6步)
ResumeThread(pi.hThread);
CloseHandle(hToken);
CloseHandle(pi.hProcess);
CloseHandle(pi.hThread);


6:获得Token信息
GetTokenInformation(hToken, TokenIntegrityLevel, NULL, 0, &dwNeedSize)【先得到需要多大的缓冲区】
PTOKEN_MANDATORY_LABEL pTokenInfo = (PTOKEN_MANDATORY_LABEL)LocalAlloc(0, dwNeedSize);
GetTokenInformation(hToken, TokenIntegrityLevel, pTokenInfo, dwNeedSize, &dwNeedSize)

7:获得进程级别:
DWORD nIntegrityLevel = *GetSidSubAuthority(pTokenInfo->Label.Sid, (*GetSidSubAuthorityCount(pTokenInfo->Label.Sid) - 1));
switch (nIntegrityLevel)
{
case SECURITY_MANDATORY_LOW_RID:
        strLevel = _T("安全模式");
        break;
case SECURITY_MANDATORY_MEDIUM_RID:
        strLevel = _T("普通用户");
        break;
case SECURITY_MANDATORY_HIGH_RID:
        strLevel = _T("管理员");
        break;
case SECURITY_MANDATORY_SYSTEM_RID:
        strLevel = _T("系统");
        break;
default:
        strLevel = _T("未知");
        break;
}


8:跳到第5步

评分

参与人数 1好评 +1 精币 +20 收起 理由
Cand + 1 + 20 奉上小小红包希望笑纳

查看全部评分


本帖被以下淘专辑推荐:

结帖率:97% (32/33)
发表于 2016-11-11 15:17:23 | 显示全部楼层   香港特别行政区*
辛苦了 感谢感谢
回复 支持 反对

使用道具 举报

发表于 2015-8-9 17:14:39 | 显示全部楼层   四川省成都市
  向大神学习,,,,,下来看看了d
回复 支持 反对

使用道具 举报

结帖率:53% (8/15)
发表于 2015-7-17 21:51:12 | 显示全部楼层   贵州省铜仁市
先学习了
回复 支持 反对

使用道具 举报

头像被屏蔽
结帖率:0% (0/1)
发表于 2015-6-29 04:31:10 | 显示全部楼层   广东省中山市
Will居然又活了
回复 支持 反对

使用道具 举报

结帖率:64% (30/47)
发表于 2015-6-29 00:11:40 | 显示全部楼层   山西省临汾市
不明觉厉      
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表