我正在尝试创建一个安装程序包,它不仅可以安装我们的应用程序,还可以将文件复制到远程应用程序服务器并在那里安装服务.我想我会在自定义操作中覆盖install方法,让它启动Power
Shell脚本来复制文件.不幸的是,当代码调用powershell脚本时,我得到了这个CmdletProviderInvocationException:
The system detected a possible attempt to compromise security. Please ensure that you can contact the server that authenticated you.
我能够复制我用来将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
最佳答案 将文件复制到网络位置有两个主要要求:
>您的自定义操作应运行without impersonation
>网络位置应具有Everyone的完全权限
MSI安装在本地系统帐户下运行.所以,如果你有权限也没关系.
由于从网络计算机向SYSTEM帐户授予权限并不容易,因此最简单的方法是为Everyone提供完全权限.这需要在包含共享文件夹的计算机上完成.