我正在尝试创建一个安装程序包,它不仅可以安装我们的应用程序,还可以将文件复制到远程应用程序服务器并在那里安装服务。我想我会在自定义操作中覆盖install方法,让它启动PowerShell脚本来复制文件。不幸的是,当代码调用powershell脚本时,我得到 CmdletProviderInvocationException :
系统检测到可能危及安全性的尝试。请确保您可以联系通过身份验证的服务器。
我能够复制我用来将powershell脚本调用到测试项目中的代码,并且它运行得很好,正如我所期望的那样,因为我已经通过Windows资源管理器登录到服务器,所以我的用户应该进行身份验证。我认为安装程序调用时脚本无法工作的原因必须是安装程序切换用户以获得安装应用程序的管理员权限,并且管理员用户未经过身份验证(尽管我可能错了)。
有谁知道我怎么能让它发挥作用?
以下是自定义操作代码:
Runspace runspace = RunspaceFactory.CreateRunspace();
runspace.Open();
Pipeline pipeline = runspace.CreatePipeline();
string scriptLoc = "c:\\sampleLocation";
pipeline.Commands.AddScript("&\"" + scriptLoc + "\\script.ps1\"");
Collection<PSObject> results = pipeline.Invoke();
runspace.Close();
这是脚本:
$RemotePath = "\\SERVER\C$\Shared\Service"
$Source = "C:\sampleLocation\Service"
Get-ChildItem $Source -Recurse | Copy-Item -Destination $RemotePath
答案 0 :(得分:2)
将文件复制到网络位置有两个主要要求:
MSI安装在本地系统帐户下运行。所以,如果你有权限也没关系。
由于从网络计算机授予SYSTEM帐户权限并不容易,最简单的方法是向Everyone授予完全权限。这需要在包含共享文件夹的计算机上完成。
答案 1 :(得分:0)
根据@Cosmin Pirvu和Microsoft文档:
LocalSystem帐户是服务控制管理器使用的预定义本地帐户。它在本地计算机上具有广泛的权限,并充当网络上的计算机。
如果您的共享文件夹位于域中的计算机上,则可以将客户端计算机的完全权限提供给Everyone。