我想部署ClickOnce部署的项目。但是,当我这样做时,它是在最终用户机器的对话框中询问:
可以使用新版本的XXXX。你想现在下载吗?
但我的最终用户没有有鼠标或键盘。所以我的意图是:它必须自动获取更新,但它不能在客户端询问该对话框。如何使用ClickOnce部署实现此目的?
答案 0 :(得分:10)
看起来您可以通过更改构建中的某些属性来实现此目的。
http://blog.jnericks.com/configuring-msbuild-to-auto-update-clickonce
- MinimumRequiredVersion - 告诉ClickOnce它何时更新它 它应该更新到这个版本的应用程序(但是这不会 强制ClickOnce执行更新)。如你所见,我们设定了这个 与ApplicationVersion设置的版本号相同 MinimumRequiredVersion始终是最新版本。
- UpdateMode = Foreground - 告诉ClickOnce更新应用程序 在它打开之前。
- UpdateRequired = True - 告诉ClickOnce自动执行 更新
醇>
没有MSBuild场景:
然后发布应用程序并进行测试。在本地测试应用程序中,这对我来说很好。
编辑:看起来有些人已经获得了要更新的最低要求版本,可能想要查看他们的solutions。
编辑2:图像显示版权控制的重要性:
另外,请注意我已选中“每次发布时自动增加修订”。每次进入项目的属性时,该版本都是最新的。您通常只需在“应用程序更新”窗口中更改版本的“修订版”部分,以匹配“发布”选项卡中的“修订版”。
答案 1 :(得分:4)
当然可以!只要它是网络部署的应用程序,您就可以使用此代码轻松检查更新。见下文:
Private Sub InstallUpdates()
Dim info As UpdateCheckInfo = Nothing
If (ApplicationDeployment.IsNetworkDeployed) Then
Dim AD As ApplicationDeployment = ApplicationDeployment.CurrentDeployment
Try
info = AD.CheckForDetailedUpdate()
Catch dde As DeploymentDownloadException
(You may want to log here)
Return
Catch ioe As InvalidOperationException
(You may want to log here)
Return
End Try
If (info.UpdateAvailable) Then
Try
AD.Update()
Application.Restart()
Catch dde As DeploymentDownloadException
(You may want to log here)
Return
End Try
End If
End If
End Sub
您可以输入此代码段并在启动时调用它。它适用于控制台应用程序Windows Forms应用程序,但仅限于网络部署!你看到我关于日志记录的所有评论都是我最初使用带提示的消息框的地方,但这是不需要任何输入的版本!
答案 2 :(得分:3)
除了Gromer's answer之外,只需在项目中安装AutoUpdateProjectsMinimumRequiredClickOnceVersion nuget package即可。一旦您的项目设置为检查更新并使用最低要求版本,这将确保所需的最低版本始终与您当前的版本匹配(即用户将始终被迫更新到最新版本)。
答案 3 :(得分:1)
任何基于.exe文件的ClickOnce应用程序都可以由自定义安装程序以静默方式安装和更新。自定义安装程序可以在安装期间实现自定义用户体验,包括用于安全和维护操作的自定义对话框要执行安装操作,自定义安装程序将使用 InPlaceHostingManager 类。
要实施此解决方案,请参阅此link
答案 4 :(得分:1)
我知道这是一个古老的Q.但是,无论如何我会回答。 (希望它会帮助某人):
首先,您需要检查:选择应用程序何时应检查更新>> 申请开始后。
其次,将此方法添加到您的代码中:
private Boolean isVersionOK()
{
UpdateCheckInfo info = null;
if (ApplicationDeployment.IsNetworkDeployed)
{
ApplicationDeployment ad = ApplicationDeployment.CurrentDeployment;
try
{
info = ad.CheckForDetailedUpdate();
}
catch (DeploymentDownloadException)
{
// No network connection
return false;
}
catch (InvalidDeploymentException)
{
return false;
}
catch (InvalidOperationException)
{
return false;
}
if (info.UpdateAvailable)
{
try
{
ad.Update();
Application.Restart();
Environment.Exit(0);
}
catch (DeploymentDownloadException)
{
// No network connection
}
return false;
}
return true;
}
else
{
return false;
}
}
最后,您只需在应用开始时调用 isVersionOK(),并根据需要在每个循环中调用以检查更新。如果您使用的是最新版本,它将返回 TRUE ,否则会返回 FALSE ,并且预计应用会在没有用户互动的情况下自动重新启动到较新版本
答案 5 :(得分:0)
在艾哈迈德回答的后续内容中,下面是VB.NET中的代码,略有增强。它可能不是最佳实践,但它具有可读性和描述性。
''' <summary>
''' Checks if the update is available for network based deployment and download it.
''' </summary>
''' <param name="autoDownloadUpdate">If the update is available, should it be downloaded automatically.<para>Default value is <code>True</code></para></param>
''' <returns>It will return <code>True</code> only if the latest version is already installed.
''' <para>If autoDownloadUpdate is set to <code>True</code>, the update is auto downloaded (and app restarts and nothing is returned) else it returns <code>False</code>.</para>
''' </returns>
Shared Private Function CheckAndDownloadUpdate(ByVal Optional autoDownloadUpdate As Boolean = True) As Boolean
If ApplicationDeployment.IsNetworkDeployed = False Then Return False
Dim appDeployment As ApplicationDeployment = ApplicationDeployment.CurrentDeployment
Dim info As UpdateCheckInfo = Nothing
Try
info = appDeployment.CheckForDetailedUpdate
Catch ex As Exception
' Exceptions if you want to handle individually
'DeploymentDownloadException ' No network connection
'InvalidDeploymentException
'InvalidOperationException
Return False
End Try
' If no update is available, it means latest version is installated
If info.UpdateAvailable = False Then Return True
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' If we are here, it means an update is available on the network
' if autoDownload is False, simply return False
If autoDownloadUpdate = False Then Return False
Try
appDeployment.Update()
Application.Restart()
Environment.Exit(0)
Catch ex As DeploymentDownloadException
' No network connection
Return False
End Try
End Function
然后在您的启动代码中,您可以像这样调用
CheckAndDownloadUpdate()
任何反馈以进一步提高答案......