天天看点

Adminrun 提升命令行下运行权限脚本

为什么提升权限?

因为很多小工具,如果调用了系统的硬件,都需要申请管理员权限。换句话说,必须由管理员下达这个命令才能正常执行,否则就会提示“以管理员身份运行”。

为了尽可能的保证用户们可以正常使用,而不是因为不知道如何正确运行而抱怨软件问题。

众所周知,在windows

vista版本之后的所有windows都加入了权限管理控制系统,这样在一定程度上防止了后台运行高级脚本的可能性。但是既然是利用图形化界面来完成的工作(鼠标右键->以管理员身份运行),就一定可以用脚本和命令行来实现。这也是毋庸置疑的。这就是写这个脚本的初衷。

但是这个脚本只是模拟了图形化界面的工作(鼠标右键->以管理员身份运行),所以还是有点小缺陷的。

当时写这个脚本之前,有一个更简单的想法,那就是在命令行里加载administrator来运行脚本,但是这个是有一定的局限性的。windows和linux还是有差别的。

在windows下,命令runas可以讲一些工具和脚本以其他管理员的身份来运行,但是有一个小前提,那就是,如果你想通过administrator管理员来运行文件,首先,你的管理员必须有一个密码。这样的话,就不能保证所有用户都能用runas来变相获取权限。

相反,在linux下,命令sudu就可谓十分方便,在这里也给大家普及一下sudu的知识。

功能说明:以其他身份来执行指令。

语 法:sudo [-bhhpv][-s

<shell>][-u <用户>][指令] 或 sudo [-klv]

补充说明:sudo可让用户以其他的身份来执行指定的指令,预设的身份为root。在/etc/sudoers中设置了可执行sudo指令的用户。若其未经授权的用户企图使用sudo,则会发出警告的邮件给管理员。用户使用sudo时,必须先输入密码,之后有5分钟的有效期限,超过期限则必须重新输入密码。 

参 数:

-b 在后台执行指令。 

-h 显示帮助。 

-h

将home环境变量设为新身份的home环境变量。 

-k 结束密码的有效期限,也就是下次再执行sudo时便需要输入密码。 

-l 列出目前用户可执行与无法执行的指令。 

-p 改变询问密码的提示符号。 

-s<shell>

执行指定的shell。 

-u<用户> 以指定的用户作为新的身份。若不加上此参数,则预设以root作为新的身份。 

-v 延长密码有效期限5分钟。 

-v 显示版本信息。

显然,sudu命令使用更方便一些。为了保证所有的用户都能直接获取到权限,我还是用模拟操作法,就是一开始说的,用脚本模拟图形化界面获取权限的操作,然后更新一下代码脚本就行了。使用的时候只需要在你原有的命令前加上adminrun即可。

语法

感谢neko13哥帮忙优化脚本,exefile的地址目前可以用当前目录的地址来代替,以前的那个需要用绝对路径,特别感谢。

下面是脚本代码

核心的代码是shellexecute(cmd, arg, null, “runas”,

1)。最后那个1的意思就是第一个管理员,也就是admin。