Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
When distributing your WebView2 app, make sure that the WebView2 Runtime is present on the client machine. This requirement applies to both the Evergreen and Fixed Version distribution modes.
For introductory information, see Evergreen vs. fixed version of the WebView2 Runtime.
Servicing the WebView2 Runtime through Windows Server Update Services (WSUS)
See Windows Server Update Services (WSUS) in Enterprise management of WebView2 Runtimes.
Runtime or browser support during development or production
During development and testing, a WebView2 app can use either option as the backing web platform:
- The WebView2 Runtime. The Runtime generally provides the same web platform capabilities and update cadence as the Stable channel of the Microsoft Edge browser. Use the WebView2 Runtime in a production environment or to develop and test against the web platform that your users have today. 
- A preview (Insider) Microsoft Edge browser channel. These Microsoft Edge preview channels are Beta, Dev, and Canary. Use this approach to test your app for forward-compatibility, so that you know if a breaking change is coming that will require updating your app. See Test upcoming APIs and features. 
A production release of a WebView2 app can only use the WebView2 Runtime as the backing web platform, not Microsoft Edge.
Microsoft Edge Stable channel isn't supported for WebView2
WebView2 apps aren't permitted to use the Stable channel of Microsoft Edge as the backing web platform. This restriction prevents a production release of a WebView2 app from taking a dependency on the browser. A WebView2 app cannot take a dependency on the browser during production, for the following reasons:
- Microsoft Edge isn't guaranteed to be present on all user devices. Many devices in enterprises and in education are disconnected from Windows Update or aren't managed by Microsoft directly. Such devices might not have Microsoft Edge installed. Requiring the production version of WebView2 apps to use the WebView2 Runtime rather than Microsoft Edge avoids making Microsoft Edge a prerequisite for running a WebView2 app. 
- Browsers and apps have different use cases. If a WebView2 app required the presence of Microsoft Edge on the client, that would potentially have unintended side-effects on the WebView2 app. For example, an IT admin can prevent the browser from being updated from a specific version, to keep the browser compatible with an internal website. Requiring the production version of a WebView2 app to use the WebView2 Runtime rather than the browser allows the WebView2 app to stay evergreen even if browser updates are prevented by the clients' admin. 
- As opposed to the browser, the WebView2 Runtime is developed and tested for app scenarios, and in some cases the WebView2 Runtime might include bug fixes that aren't yet available in the browser. 
The Evergreen WebView2 Runtime will be included as part of the Windows 11 operating system. Various WebView2 apps have installed the Evergreen Runtime on devices with an operating system prior to Windows 11. However, some devices might not have the Runtime pre-installed, so it's a good practice to check whether the Runtime is present on the client.
Before your app creates a WebView2, the app should check whether the WebView2 Runtime is present (either by checking a registry key or by calling an API) and install the Runtime if it is missing. The app can do this check when installing or updating your app (recommended), or at app runtime. To check whether the Runtime is present, see Deploying the Evergreen WebView2 Runtime, below.
The Evergreen Runtime distribution mode
The Evergreen distribution mode ensures that your WebView2 app is taking advantage of the latest WebView2 features and security updates. For introductory information, see The Evergreen Runtime distribution mode in Evergreen vs. fixed version of the WebView2 Runtime.
The Evergreen distribution mode has the following characteristics:
- The WebView2 Runtime updates automatically without requiring any action from you. It receives the same Microsoft Edge updates that are described in Release notes for Microsoft Edge Stable Channel and Release notes for Microsoft Edge Security Updates. 
- All WebView2 apps that use the Evergreen distribution mode use a shared copy of the Evergreen WebView2 Runtime, which saves disk space. 
- On eligible systems, binaries for Microsoft Edge and the Evergreen WebView2 Runtime are hard-linked together when they are on the same version. This linking provides benefits for disk footprint, memory, and performance. 
When you use the Evergreen distribution mode of the WebView2 Runtime, your WebView2 app assumes that clients have the latest Runtime. Your app cannot require a particular version of the WebView2 Runtime for all apps on the client. By the time a new WebView2 SDK package is released, a compatible version of the WebView2 Runtime has already been distributed to clients. Therefore it's OK for your WebView2 app to use the APIs that are in the latest version of the WebView2 SDK.
Windows 11 devices and Windows 10 devices (details)
For introductory information, see Windows 11 devices and Windows 10 devices in Evergreen vs. fixed version of the WebView2 Runtime.
The vast majority of Windows 10 devices have the WebView2 Runtime installed already, as described in Delivering Microsoft Edge WebView2 Runtime to managed Windows 10 devices. A small number of Windows 10 devices don't have the WebView2 Runtime installed. We recommend that you handle this edge case, by using either of the following approaches:
- Programmatically deploy the Evergreen Runtime with your app. See Deploying the Evergreen WebView2 Runtime below. 
- Redirect your end users to the Microsoft site: Download Microsoft Edge WebView2, and have end users download the Evergreen WebView2 Runtime installer from the site and install the Runtime themselves. 
See also:
- Prerelease and Release SDKs for WebView2 - Use a Prerelease version of the SDK along with a preview channel of Microsoft Edge; or use a Release version of the SDK along with the Evergreen WebView2 Runtime.
Deploying the Evergreen WebView2 Runtime
Only one installation of the Evergreen WebView2 Runtime is needed for all Evergreen apps on the device. Several tools are available at Download the WebView2 Runtime to help you deploy the Evergreen Runtime.
- For online clients: WebView2 Runtime Bootstrapper is a tiny (approximately 2 MB) installer. The WebView2 Runtime Bootstrapper downloads and installs the Evergreen Runtime from Microsoft servers that matches the user's device architecture. - In the setup part of your WebView2 app, link to the bootstrapper. Use a link to programmatically download the bootstrapper; select the Get the Link button at the above download page. 
- Or, download the bootstrapper and package it with your WebView2 app. 
 
- For offline clients: WebView2 Runtime Standalone Installer is a full installer that installs the Evergreen WebView2 Runtime in offline environments. 
- If you're using App Installer to deploy MSIX applications, you can specify the WebView2 Runtime as a dependency, to have it be installed with the application. For details about how to do this, see win32dependencies:ExternalDependency (Windows 10, Windows 11) in the App package manifest docs. See also Install Windows 10 apps with App Installer. 
Installing the Runtime as per-machine or per-user
The latest bootstrapper and standalone installer support both per-machine and per-user installs of the WebView2 Runtime.
If you run the installer from an elevated process or command prompt, the Runtime is installed as per-machine. If you don't run the installer from an elevated process or command prompt, the Runtime will be installed as per-user. However, a per-user install is automatically replaced by a per-machine install, if a per-machine Microsoft Edge Updater is in place. A per-machine Microsoft Edge Updater is included as part of Microsoft Edge, except for the Canary preview channel of Microsoft Edge.
Use the following online deployment workflow or offline deployment workflow to ensure that the Runtime is already installed before your app launches. You can adjust your workflow depending on your scenario. Sample code is available in the Samples repo.
Detect if a WebView2 Runtime is already installed
To verify that a WebView2 Runtime is installed, use one of the following approaches:
- Approach 1: Inspect the - pv (REG_SZ)regkey for the WebView2 Runtime at both of the following registry locations. The- HKEY_LOCAL_MACHINEregkey is used for per-machine install. The- HKEY_CURRENT_USERregkey is used for per-user install.- For WebView2 applications, at least one of these regkeys must be present and defined with a version greater than 0.0.0.0. If neither regkey exists, or if only one of these regkeys exists but its value is - null, an empty string, or 0.0.0.0, this means that the WebView2 Runtime isn't installed on the client. Inspect these regkeys to detect whether the WebView2 Runtime is installed, and to get the version of the WebView2 Runtime. Find- pv (REG_SZ)at the following two locations.- The two registry locations to inspect on 64-bit Windows: - HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdate\Clients\{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5} HKEY_CURRENT_USER\Software\Microsoft\EdgeUpdate\Clients\{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5}- The two registry locations to inspect on 32-bit Windows: - HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\EdgeUpdate\Clients\{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5} HKEY_CURRENT_USER\Software\Microsoft\EdgeUpdate\Clients\{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5}
- Approach 2: Run GetAvailableCoreWebView2BrowserVersionString and evaluate whether the - versionInfois- nullptr.- nullptrindicates that the WebView2 Runtime isn't installed. This API returns version information for the WebView2 Runtime or for any installed preview channels of Microsoft Edge (Beta, Dev, or Canary).
Online-only deployment
If you have an online-only deployment scenario where users are assumed to have internet access, use the following workflow.
- During your app setup, run a test to make sure that the WebView2 Runtime is already installed. See Detect if a WebView2 Runtime is already installed, above. 
- If the Runtime isn't installed, in your app setup process, use the link (from the Get the Link button on the download page) to programmatically download the WebView2 Runtime Bootstrapper. 
- Invoke the WebView2 Runtime Bootstrapper by issuing the following command. - If you run the following command from an elevated process or command prompt, it triggers a per-machine install. If you don't run the command from an elevated process or command prompt, a per-user install will take place. However, a per-user install is automatically replaced by a per-machine install, if a per-machine Microsoft Edge Updater is in place. A per-machine Microsoft Edge Updater is provided as part of Microsoft Edge, except for the Canary preview channel of Microsoft Edge. For more information, see Installing the Runtime as per-machine or per-user. - MicrosoftEdgeWebview2Setup.exe /silent /install
The above workflow has several benefits:
- The Runtime is installed only when needed. 
- You aren't required to package a Runtime installer with your WebView2 app. 
- The WebView2 Runtime Bootstrapper automatically detects the device's architecture (platform) and then installs the matching WebView2 Runtime. 
- The Runtime is installed silently. 
Alternatively, instead of programmatically downloading the bootstrapper on-demand by getting a link, as shown above, you can package the Evergreen Bootstrapper for the WebView2 Runtime with your app.
Offline deployment
If you have an offline deployment scenario, where app deployment has to work entirely offline, use the following workflow.
- Download the Evergreen Standalone Installer from Download the WebView2 Runtime to your development machine. The Evergreen Standalone Installer installs the Evergreen WebView2 Runtime on the client. 
- Include the Evergreen Standalone Installer in your app installer or updater. 
- During your app setup, run a test to make sure that the WebView2 Runtime is already installed. See Detect if a WebView2 Runtime is already installed, above. 
- If the WebView2 Runtime isn't installed, run the Evergreen Standalone Installer. If you want to run a silent installation, you can run the following command. - If you run the following command from an elevated process or command prompt, it triggers a per-machine install. If you don't run the command from an elevated process or command prompt, a per-user install will take place. However, a per-user install is automatically replaced by a per-machine install, if a per-machine Microsoft Edge Updater is in place. A per-machine Microsoft Edge Updater is provided as part of Microsoft Edge, except for the Canary preview channel of Microsoft Edge. For more information, see Installing the Runtime as per-machine or per-user. - MicrosoftEdgeWebView2RuntimeInstaller{X64/X86/ARM64}.exe /silent /install
Handle Evergreen WebView2 Runtime updates
New versions of the Evergreen WebView2 Runtime are automatically downloaded to the client. The client uses the new version of the WebView2 Runtime when your WebView2 app is restarted. However, if your app runs continuously, your app will continue to use the previous version of the WebView2 Runtime. This has security implications, because the previous version of the WebView2 Runtime might have security vulnerabilities that are fixed in the new version. You should consider whether it is important for your app to adopt the latest version of the WebView2 Runtime as soon as possible, based on your app's threat model. For example, if your WebView2 app accesses third-party content, that content should be considered untrusted, so your app would need to use the latest version of the WebView2 Runtime.
To use the new version of the WebView2 Runtime, you need to either release all references to the previous WebView2 environment objects, or restart your app.  The next time your app creates a new WebView2 environment, the app will use the new version of the WebView2 Runtime.  To accomplish this, you can have an event handler for the NewBrowserVersionAvailable event, to have your app automatically notify the user to restart the app.  If your app handles restarting the app, consider saving the user state before the WebView2 app exits.
- CoreWebView2EnvironmentClass:
Test your app for forward-compatibility
In the Evergreen distribution mode, the WebView2 Runtime is automatically kept up to date on the client to provide the latest features and security fixes. If you use Evergreen distribution, to ensure that your WebView2 app stays compatible with the web, you should set up testing infrastructure.
For best practices about how to test your app for forward-compatibility, see Prerelease testing using preview channels and Self-host by deploying preview channels.
Feature-detect when using recent APIs
When using Evergreen mode in WebView2 apps, it's crucial to check for the presence of new APIs on the client's machine, by using methods like QueryInterface or try-catch, because the client machine might not have the latest WebView2 Runtime, containing the new APIs.  Updates to the WebView2 Runtime might not occur if an IT Admin disables updating, or if the client is offline.
For details, see Feature-detecting to test whether the installed Runtime supports recently added APIs in Prerelease and Release SDKs for WebView2.
There are separate update policies for Microsoft Edge and the WebView2 Runtime. Disabling updates for Microsoft Edge doesn't impact the availability of the latest WebView2 APIs, because the WebView2 Runtime can still update automatically (unless updating the WebView2 Runtime is disabled by an Admin).
The Fixed Version runtime distribution mode
For constrained environments that have strict compatibility requirements, consider using the Fixed Version distribution mode. (The Fixed Version distribution mode was previously called bring-your-own.) For introductory information, see The Fixed Version runtime distribution mode in Evergreen vs. fixed version of the WebView2 Runtime.
In the Fixed Version distribution mode, you control the timing of updates to the WebView2 Runtime for your app. You download a specific version of the WebView2 Runtime and then package it with your WebView2 app. The WebView2 Runtime on the client isn't automatically updated. Instead, you periodically update the WebView2 Runtime that's packaged and distributed together with your updated app. The Fixed Version approach doesn't use a registry key for the WebView2 Runtime.
The Fixed Version binaries are over 250 MB and will make your app package larger by that amount.
To use the Fixed Version distribution mode:
- Download the Fixed Version of the WebView2 Runtime from Download the WebView2 Runtime, as a package. - The most-patched version of the latest and second-latest major releases are available for download at this site. Keep an archived copy of any versions you need. 
- Decompress the WebView2 Runtime package using the command-line command - expand {path to the package} -F:* {path to the destination folder}or by using a decompression tool such as WinRAR. Avoid decompressing through File Explorer, because that approach might not generate the correct folder structure.
- Include all of the decompressed Fixed Version binaries in your app package, to be deployed on the target machine during your app's installation. 
- Indicate the path to the Fixed Version binaries when creating the WebView2 environment. - For Win32 C/C++, you can create the environment using the CreateCoreWebView2EnvironmentWithOptions function. Use the - browserExecutableFolderparameter to indicate the path to the folder that contains- msedgewebview2.exe.
- For .NET, you must specify the environment before the WebView2 - Sourceproperty takes effect. For .NET, you can use either of the following approaches to specify the environment:- Set the - CreationProperties(WPF/WinForms) property on the- WebView2element. Use the- BrowserExecutableFoldermember in the- CoreWebView2CreationProperties(WPF/WinForms) class to indicate the path to the Fixed Version binaries.
- Alternatively, use - EnsureCoreWebView2Async(WPF/WinForms) to specify the environment. Use the- browserExecutableFolderparameter in CoreWebView2Environment.CreateAsync to indicate the path to the Fixed Version binaries.
 
- For WinUI, make sure the app has access to the folder by specifying the installed location and setting the environment variable for runtime path. One way to do this is by adding the following C# code to your app: - StorageFolder localFolder = Windows.ApplicationModel.Package.Current.InstalledLocation; String fixedPath = Path.Combine(localFolder.Path, "FixedRuntime\\(version number)"); Debug.WriteLine($"Launch path [{localFolder.Path}]"); Debug.WriteLine($"FixedRuntime path [{fixedPath}]"); Environment.SetEnvironmentVariable("WEBVIEW2_BROWSER_EXECUTABLE_FOLDER", fixedPath);
 
- Package and ship the Fixed Version binaries with your app. Update the binaries as appropriate. - For WinUI, this might include opening the project file ( - .csproj) in a code editor, and then add the following code within the project tags:- <ItemGroup> <Content Include="FixedRuntime\(version number)\\**\*.*"> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> </Content> </ItemGroup>- Verify that the - bin\**designated architecture**\Releasefolder has a matching FixedRuntime\(version number) folder with the runtime files in it.
 
- On Windows 10 devices, starting with Fixed Version 120, developers of unpackaged Win32 applications using Fixed Version are required to run the following commands, for Fixed Version to continue to work. This is due to a security improvement in v120 to run the Renderer process inside the App Container. This change doesn't affect Windows 11 devices, the older runtime, or packaged apps. - Locate the path where you deploy the Fixed Version package on the user's device, such as the following location: - D:\myapp\Microsoft.WebView2.FixedVersionRuntime.87.0.664.8.x64
- Run the following commands on the user's device: - icacls {Fixed Version path} /grant *S-1-15-2-2:(OI)(CI)(RX) icacls {Fixed Version path} /grant *S-1-15-2-1:(OI)(CI)(RX)
- Confirm that permissions are granted for - ALL APPLICATION PACKAGESand- ALL RESTRICTED APPLICATION PACKAGESin the Security tab of the Fixed Version folder, as shown below: 
 
Known issues for Fixed Version
- Currently, Fixed Version cannot be run from a network location or UNC path.
Files to ship with the app
The WebView2Loader code needs to be shipped with the app.  This can be done by statically linking WebView2Loader.lib into the app binaries, or by including the WebView2Loader.dll that matches the app's architecture. Usually this is handled automatically for you by Visual Studio when using the .targets file in the WebView2 SDK, but there might be cases when you need to manually specify what files to publish with your app.  To statically link the WebView2 loader library, see Distribute a WebView2 app as a single executable file.
WebView2Loader.dll is a native and architecture-specific binary, so you need to include all flavors of this binary that you expect your app to run in.  For example:
- For x86, you would include the x86 version of - WebView2Loader.dll.
- For a managed app using AnyCPU, you would include the x86, x64, and arm64 versions of - WebView2Loader.dll. The correct version of- WebView2Loader.dllis loaded from the appropriate architecture-specific folder.
Example native app folder structure:
\<myApp>
    \WebView2Loader.dll
For .NET managed apps, you also need to include the WebView2 .NET assemblies for the core WebView2 functionality (Microsoft.Web.WebView2.Core.dll) and for the WPF/WinForms-specific functionality (Microsoft.Web.WebView2.Winforms.dll or Microsoft.Web.WebView2.WPF.dll).
Example managed app folder structure:
\<myApp>
    \Microsoft.Web.WebView2.Core.dll
    \Microsoft.Web.WebView2.Winforms.dll
    \Microsoft.Web.WebView2.WPF.dll
    \runtimes
        \win-arm64\native\WebView2Loader.dll (arm64)
        \win-x64\native\WebView2Loader.dll (x64)
        \win-x86\native\WebView2Loader.dll (x86)
See also
- Prerelease and Release SDKs for WebView2
- Feature-detecting to test whether the installed Runtime supports recently added APIs in Prerelease and Release SDKs for WebView2.
 
- Evergreen vs. fixed version of the WebView2 Runtime
- Windows Server Update Services (WSUS) in Enterprise management of WebView2 Runtimes.
- Test upcoming APIs and features
- Prerelease testing using preview channels
- Self-host by deploying preview channels
- Distribute a WebView2 app as a single executable file - statically linking the WebView2 loader library.
Enterprise docs:
- Microsoft Edge release schedule
- Release notes for Microsoft Edge Stable Channel
- Release notes for Microsoft Edge Security Updates
developer.microsoft.com:
- Download the WebView2 Runtime - Developers.
- Download Microsoft Edge WebView2 - End users.
Blogs:
- Delivering Microsoft Edge WebView2 Runtime to managed Windows 10 devices
- Delivering Microsoft Edge WebView2 Runtime to managed Windows 10 devices
Windows:
GitHub:
Windows Runtime API:
- win32dependencies:ExternalDependency (Windows 10, Windows 11) in the App package manifest docs.
API Reference:
- The - CreationPropertiesproperty on the- WebView2element: (WPF/WinForms)
- The - BrowserExecutableFoldermember in the- CoreWebView2CreationProperties(WPF/WinForms)
- CoreWebView2EnvironmentClass:- CoreWebView2Environment.CreateAsync including the browserExecutableFolderparameter.
- CoreWebView2Environment.NewBrowserVersionAvailable Event
 
- CoreWebView2Environment.CreateAsync including the