PeakSWC.RemoteBlazorWebView.WindowsForms 6.0.29

There is a newer version of this package available.
See the version list below for details.
dotnet add package PeakSWC.RemoteBlazorWebView.WindowsForms --version 6.0.29
                    
NuGet\Install-Package PeakSWC.RemoteBlazorWebView.WindowsForms -Version 6.0.29
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="PeakSWC.RemoteBlazorWebView.WindowsForms" Version="6.0.29" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="PeakSWC.RemoteBlazorWebView.WindowsForms" Version="6.0.29" />
                    
Directory.Packages.props
<PackageReference Include="PeakSWC.RemoteBlazorWebView.WindowsForms" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add PeakSWC.RemoteBlazorWebView.WindowsForms --version 6.0.29
                    
#r "nuget: PeakSWC.RemoteBlazorWebView.WindowsForms, 6.0.29"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#addin nuget:?package=PeakSWC.RemoteBlazorWebView.WindowsForms&version=6.0.29
                    
Install PeakSWC.RemoteBlazorWebView.WindowsForms as a Cake Addin
#tool nuget:?package=PeakSWC.RemoteBlazorWebView.WindowsForms&version=6.0.29
                    
Install PeakSWC.RemoteBlazorWebView.WindowsForms as a Cake Tool

RemoteBlazorWebViewTutorial

Microsoft has recently introduced two Blazor WebView Controls in .NET 6. One control (Microsoft.AspNetCore.Components.WebView.Wpf) targets Windows Presentation Foundation (WPF) apps and the other (Microsoft.AspNetCore.Components.WebView.WindowsForms) targets Windows Form (WinForms) apps. The Microsoft controls allow developers to create user interfaces for desktop apps using Blazor web technology. The desktop apps using Blazor have the full feature set and performance of .NET 6 and are not contrained like a Blazor WebAssembly app.

The Remote versions of the Blazor WebView Controls (PeakSWC.RemoteBlazorWebView.Wpf and PeakSWC.RemoteBlazorWebView.WindowsForms) act as a drop-in replacement for the Microsoft controls along with the ability to access the user interface over a secure connection to a public server using a web browser. This is accomplished by setting up a secure server (RemoteWebWindowService) in the cloud and pointing your browser to it. With a couple of minimal changes you will be able to either run your app locally or remotely control your application.

Use Cases

The primary use case is to be able to share a desktop application controlling hardware with an external service technician. Typically, the application is behind a corporate firewall and is not easily accessed by the technician. The Remote Blazor controls allow the desktop application to be started in "Remote" mode which generates a unique Url for the technician to access the user interface.

Another use case is to be able to monitor data that is behind a firewall or on a private network without the cost and complexity to store the data externally. For example, if a brewer wanted to monitor fermentation data such as PH, Gravity, and Pressure they could build an app showing real-time graphical data using Blazor components and, with only a couple of changes, be able to view the user interface with a web browser from outside of the firewall.

How it works

RemoteBlazorWebView.Wpf has two modes of operation. In the first default mode, it works just like the Microsoft BlazorWebView Controls (see BlazorDesktopWPF). In the second mode, a url is specified on the control's properties. In this mode, all GUI interactions are sent to a server which can be accessed with a browser. Hosting the server (RemotableWebViewService.exe) in the cloud allows you to remotely control an application which is behind a firewall or does not have a static IP address.

Demo Video

RemoteBlazorWebView

Download and Run Demo

  • Download the latest Release.zip under the Assets folder from https://github.com/budcribar/RemoteBlazorWebViewTutorial/releases

  • Extract the files

  • Run either the WinForms (RemoteBlazorWebViewTutorial.WinFormsApp.exe) or the Wpf Sample Program (RemoteBlazorWebViewTutorial.WpfApp.exe) which shows the Blazor UI running normally

  • Next start the server and run the sample application through the browser

    • Open a powershell window and execute RemoteWebViewService in the background
    .\RemoteWebViewService &
    
    • Run the sample program with the local server option
    .\RemoteBlazorWebViewTutorial.WpfApp.exe -u=https://localhost:5001
    
    • Click the link in the sample program
  • Finally, Run the sample program and use the secured cloud server

    .\RemoteBlazorWebViewTutorial.WpfApp.exe -u=https://server.remoteblazorwebview.org:443
    
    • Click the link in the sample program
    • Create a new user and sign in

Build and Run Demo

  • Install the RemoteWebViewService
dotnet tool update -g PeakSWC.RemoteWebViewService --version 6.*-* 
  • Start the server
RemoteWebViewService
  • Open the RemoteBlazorWebViewTutorial.sln with Visual Studio

  • Select the Local Profile from the dropdown next to the Run button and click on run

  • Make sure the RemoteBlazorWebViewTutorial.WppfApp is set as Startup Project

  • Next we will run the application remotely

  • Select the Remote Profile from the dropdown next to the Run button and click on run

  • A main window will come up with a URL. Click on it

  • At this point the sample blazor app will be running in a web browser served from RemoteWebViewService!

  • Finally, we will run the application from a cloud server (https://server.remoteblazorwebview.org/)

  • Select the Cloud Profile from the dropdown next to the Run button and click on run

  • A main window will come up with a URL. Click on it

  • At this point the sample blazor app will be running in a web browser served from https://server.remoteblazorwebview.org. Accessing the server will require that you set up a login. The server is setup for demo purposes only. Contact me at budcribar@msn.com if you would like help setting up a production server.

Security

Each time a client application starts it attaches to the server with a unique Guid. This Guid needs to be specified on the Url in order to access the application and provides the first layer of security. The application is locked once a browser attaches to the server at a given Guid and no other browser instance has access.

The demo version of the RemoteWebViewService does not include authentication but it can be built and configured with Azure AD B2C. When built with Azure AD B2C authentication, the server requires that users are authenticated in order to access the endpoints which serve up the demo application user interface. The server code is hosted in the RemoteBlazorWebView github repository and includes a Visual Studio project to build the server. This added layer of security should be sufficient for most use cases but the server can be further locked down with firewall rules if needed.

Product Compatible and additional computed target framework versions.
.NET net6.0-windows7.0 is compatible.  net7.0-windows was computed.  net8.0-windows was computed.  net9.0-windows was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
10.0.0-preview4 98 5/14/2025
10.0.0-preview3 50 4/12/2025
9.0.5 117 5/14/2025
9.0.4 82 4/12/2025
9.0.2 122 2/16/2025
9.0.1 109 1/18/2025
9.0.0 116 11/14/2024
9.0.0-rc2 69 10/26/2024
9.0.0-preview7 159 8/19/2024
9.0.0-preview6 49 7/29/2024
9.0.0-preview5 73 6/23/2024
8.0.11 100 11/14/2024
8.0.10 133 10/10/2024
8.0.8 156 8/20/2024
8.0.7 100 7/29/2024
8.0.6 128 6/19/2024
8.0.4 127 6/19/2024
8.0.3 141 4/20/2024
8.0.2 154 2/23/2024
8.0.1 137 2/16/2024
8.0.0 204 12/30/2023
8.0.0-rc2 99 10/14/2023
8.0.0-preview5 117 6/15/2023
8.0.0-preview4 117 5/24/2023
8.0.0-preview3 126 4/21/2023
8.0.0-preview2 129 3/29/2023
7.0.16 137 2/25/2024
7.0.14 139 12/29/2023
7.0.12 256 10/14/2023
7.0.9 174 8/15/2023
7.0.7 164 6/14/2023
7.0.5 196 4/20/2023
7.0.4 274 3/24/2023
7.0.3 237 3/17/2023
7.0.2 338 1/29/2023
7.0.0 389 11/13/2022
7.0.0-rc1 138 10/9/2022
7.0.0-pre6 156 7/14/2022
7.0.0-pre5 170 7/2/2022
7.0.0-pre4 165 5/11/2022
6.3.9 279 2/11/2023
6.3.8 318 2/1/2023
6.3.7 316 1/31/2023
6.3.6 398 11/13/2022
6.3.5 458 10/11/2022
6.3.4 482 7/13/2022
6.3.3 494 7/3/2022
6.3.2 459 6/15/2022
6.3.1 469 5/25/2022
6.3.0 180 5/21/2022
6.2.0 188 5/8/2022
6.1.2-pre 179 4/7/2022
6.1.1-pre 166 2/19/2022
6.1.0-pre 181 2/7/2022
6.0.38-pre 178 2/1/2022
6.0.37-pre 167 1/25/2022
6.0.36 227 1/4/2022
6.0.35 200 1/1/2022
6.0.34 190 12/30/2021
6.0.33 187 12/29/2021
6.0.32 213 12/12/2021
6.0.31 219 12/4/2021
6.0.30 761 12/3/2021
6.0.29 216 11/17/2021
6.0.28-rc2 194 10/14/2021
6.0.27-rc1 190 10/11/2021
6.0.26-rc1 187 10/7/2021
6.0.25-rc1 232 10/4/2021
6.0.24-rc1 256 10/1/2021
6.0.23-rc1 220 9/26/2021
6.0.22-rc1 207 9/15/2021
6.0.21-preview7 216 9/7/2021
6.0.20-preview7 213 8/26/2021
6.0.16-preview7 180 8/25/2021
6.0.15-preview7 207 8/13/2021
6.0.13-preview6 181 8/9/2021
6.0.12-preview6 260 8/1/2021
6.0.11-preview6 175 7/16/2021
6.0.10-preview5 302 7/10/2021
6.0.9-preview5 261 6/29/2021
6.0.8-preview5 262 6/22/2021
6.0.7-preview4 197 6/17/2021

Updated net6 packages