这听起来很荒谬,但我有一个启动 PowerShell 文件的批处理文件(只需右键单击批处理文件并“以管理员身份运行”会更容易),这取决于 PowerShell 文件中的某些参数,可以运行做一些事情的不同批处理文件。
.bat -> .ps1 -> .bat
这是必要的,因为除了我之外还有其他人编写和管理这个其他批处理文件。我无法将它正在做的事情合并到我自己的脚本中。
照原样,运行我的批处理文件确实是以管理员身份运行我的 PowerShell 脚本。它会继续以管理员身份继续并运行嵌套的批处理文件吗?它有多深?你有没有“失去”管理员?
最佳答案
是的,它会继续进行,在大多数情况下,这取决于您的进程在做什么,但答案通常是否定的——它不会失去管理员权限。这里的关键区别在于您的脚本是否保留在本地。
如果是本地的,那么是的,管理员上下文将为从初始提升的进程派生的进程保留。
如果您的代币通过网络传播,则视情况而定。已提升的帐户是否也是远程计算机上的管理员?那么是的,它将继续以管理员身份运行。如果本地用户在远程机器上没有管理权限,则可能与远程主机交互但不执行管理任务(取决于本地管理员是否在远程机器上具有“用户”权限)。
如果您有本地主机 (A) 和远程主机(B 和 C),并且来自主机 A 的脚本(具有管理员权限)尝试在主机 B 上执行一系列命令。如果这些命令中的任何一个从主机发出B 到任何其他远程主机(例如主机 C),那么这将因其他原因而失败。出现此问题的原因是 Windows 如何执行 NTLM/Kerberos 身份验证并存储这些凭据以进行单点登录。
假设在主机 A 上成功进行初始本地身份验证,将在存储和维护的内存中创建一个安全 token ,这样任何需要身份验证的东西都可以重新使用该 token ,而无需重新提示用户输入凭据。深入了解这个过程超出了这个问题的范围,但只要了解主机 A 拥有该 token 并可以将其呈现给远程资源进行身份验证,远程主机就不会获得它的副本。意思是,主机 A 可以让主机 B 信任它(假设已授予权限),但主机 B 没有机制向任何其他主机(例如主机 C)提供相同的身份验证 token ——为了更详细的解释,这称为“双跳”问题。 https://blogs.technet.microsoft.com/askds/2008/06/13/understanding-kerberos-double-hop/
关于windows - 运行批处理文件,运行 PowerShell 文件,运行批处理文件...以管理员身份,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44290443/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我正在使用i18n从头开始构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在rubyonrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚