开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 2217|回复: 14
收起左侧

[求助] 系统_取DOS执行结果 () 如何提权

[复制链接]

结帖率:92% (49/53)
发表于 2023-1-22 00:19:03 | 显示全部楼层 |阅读模式   江西省上饶市
同样的指令,

终端(管理员)来手动运行可以成功.

系统_取DOS执行结果 ()  失败了.


  
子程序名返回值类型公开备 注
系统_取DOS执行结果T字节集 该命令会阻塞,一直到CMD中的内容执行完毕后才会返回
参数名类 型参考可空数组备 注
命令行文本字节集
即时回显子程序指针DOS即时回显信息回调函数!回调DOS函数(回显信息) 返回逻辑值;真、停止,假、继续
UNICODE逻辑型
变量名类 型静态数组备 注
hRead整数型 
hWrite整数型 
saSECURITY_ATTRIBUTES 
dwSize整数型 
szCmdline字节集 
siSTARTUPINFO 
piPROCESS_INFORMATION 
dwBytesInStdOut整数型 
isRes逻辑型 
dwExitCode整数型 
szTemp字节集 
szBuf字节集 
sa.nLength = 12  ' sizeof(SECURITY_ATTRIBUTES)
sa.lpSecurityDescriptor = #NULL
sa.bInheritHandle = 真
isRes = CreatePipe (hRead, hWrite, sa, 0)
如果真 (isRes = )
返回 ({  })
si.cb = 68  ' sizeof(STARTUPINFO)
si.dwFlags = 位或 ( #STARTF_USESTDHANDLES, #STARTF_USESHOWWINDOW )
si.wShowWindow = #SW_HIDE
si.hStdInput = hRead
si.hStdOutput = hWrite
si.hStdError = hWrite
dwSize = 取字节集长度 (命令行文本)
szCmdline = 编码_Ansi到Unicode (选择 (取操作系统类别 () ≤ 2, “command.com /c ”, “cmd.exe /c ”), ) + 命令行文本
szCmdline = szCmdline + 取空白字节集 ( #MAX_PATH × 2 - dwSize)  ' 填充
isRes = CreateProcessW ( #NULL, 取指针_字节集型 (szCmdline), 取数据_通用型 (sa), #NULL, 真, 0, #NULL, #NULL, si, pi)
CloseHandle (hWrite)
如果真 (isRes = )
CloseHandle (hRead)
返回 ({  })
CloseHandle (pi.hThread)
WaitForInputIdle (pi.hProcess, 1000)  ' 毫秒
判断循环首 (dwBytesInStdOut ≠ -1)
PeekNamedPipe (hRead, #NULL, 0, #NULL, dwBytesInStdOut, #NULL )
如果 (dwBytesInStdOut > 0)
szTemp = 取空白字节集 (dwBytesInStdOut)
ReadFile (hRead, szTemp, dwBytesInStdOut, dwBytesInStdOut, #NULL )
szBuf = szBuf + szTemp
如果真 (是否为空 (即时回显))
如果 (UNICODE)
szTemp = A2W_CP (szTemp, #CP_gb2312 )
szTemp = szTemp + { 0 }
isRes = 程序_执行整数子程序 (即时回显, 取指针_字节集型 (szTemp), , ) ≠ 0
如果真 (isRes)
跳出循环 ()


GetExitCodeProcess (pi.hProcess, dwExitCode)
如果真 (dwExitCode ≠ #STILL_ACTIVE )
跳出循环 ()

Sleep (1)
判断循环尾 ()
CloseHandle (pi.hProcess)
CloseHandle (hRead)
如果真 (szBuf = {  })
返回 ({  })
如果 (UNICODE)
返回 (A2W_CP (szBuf, #CP_gb2312 ))
szBuf = szBuf + { 0 }
返回 (szBuf)



主程序是管理员运行的,试过在上述程序里添加 进程_提升权限到debug(pi.dwProcessId)
(提升cmd.exe的权限)

仍然没有成功.


补充内容 (2023-1-22 00:20):
对内核方面的知识实在知之甚少..

补充内容 (2023-1-22 00:20):
对内核方面的知识实在知之甚少..

补充内容 (2023-1-22 10:20):
已经用匿名管道自行解决,楼下的操作试过了无用

补充内容 (2023-1-22 10:20):
已经用匿名管道自行解决,楼下的操作试过了无用
结帖率:83% (39/47)

签到天数: 23 天

发表于 2023-1-22 09:10:33 | 显示全部楼层   福建省宁德市
只要你易语言进程自身是管理员权限就可以了
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)
发表于 2023-1-22 09:37:40 | 显示全部楼层   江苏省南京市
软件编译出来以后右键以管理员身份运行。
回复 支持 反对

使用道具 举报

发表于 2023-1-22 15:37:46 | 显示全部楼层   陕西省西安市
是你编码的问题吧,试试这样
  
cmd = “systeminfo”
调试输出 (编码_Unicode到Ansi (系统_取DOS执行结果T (编码_Ansi到Unicode (cmd), , )))


i支持库列表   支持库注释   
spec特殊功能支持库

回复 支持 反对

使用道具 举报

结帖率:92% (49/53)

签到天数: 19 天

 楼主| 发表于 2023-1-22 19:01:03 | 显示全部楼层   江西省上饶市
Visitors 发表于 2023-1-22 15:37
是你编码的问题吧,试试这样
[e=0].版本 2
.支持库 spec

执行命令没问题的,说明不是编码问题

但是命令的执行结果是失败,说明是权限的问题..
回复 支持 反对

使用道具 举报

发表于 2023-1-22 21:30:05 | 显示全部楼层   陕西省西安市
空竹 发表于 2023-1-22 19:01
执行命令没问题的,说明不是编码问题

但是命令的执行结果是失败,说明是权限的问题.. ...

那你把进程以管理员权限运行不就好了
回复 支持 反对

使用道具 举报

结帖率:100% (25/25)

签到天数: 23 天

发表于 2023-1-22 22:13:14 | 显示全部楼层   贵州省遵义市
如果是源码调试的话,先把源码关闭 然后 右键管理员运行再去调试不就有权限了
回复 支持 反对

使用道具 举报

结帖率:100% (4/4)
发表于 2023-4-1 11:00:58 | 显示全部楼层   江西省南昌市

只要你易语言进程自身是管理员权限就可以了
回复 支持 反对

使用道具 举报

结帖率:92% (49/53)

签到天数: 19 天

 楼主| 发表于 2023-4-1 11:38:01 | 显示全部楼层   吉林省长春市
3507595911 发表于 2023-4-1 11:00
只要你易语言进程自身是管理员权限就可以了

测试无效
回复 支持 反对

使用道具 举报

发表于 2023-5-19 10:19:11 | 显示全部楼层   湖南省衡阳市
期待更好的作品,貌似还不够十五字
回复 支持 反对

使用道具 举报

  高级模式
B Color Image Link Quote Code Smilies |上传

本版积分规则 致发广告者

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

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

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