部署 Qt WebEngine 应用程序

The way to package and deploy applications varies between operating systems. For Windows and macOS, windeployqt and macdeployqt automate the steps to generate a stand-alone application package.

When manually deploying applications that depend on Qt WebEngine, all the files that are required to run the application have to be included: libraries, QML imports, plugins, and translations.

更多信息,见 部署 Qt 应用程序 .

目标平台

Qt WebEngine does try to support all 支持平台 of Qt. However, due to different requirements of Chromium this is not always possible. Known limitations are:

  • Qt WebEngine currently supports only Windows, Linux, and macOS.
  • On Windows, Qt WebEngine only supports Windows Vista or newer as target platform. Due to use of newer API in Chromium, Windows XP is not supported. WinRT is not supported, either.

手动部署应用程序

When manually deploying applications that depend on Qt WebEngine, the following files might have to be deployed:

  • QML 导入
  • Qt WebEngine process
  • 资源
  • 翻译
  • 音频和视频编解码器

部署库

The following libraries must be deployed with applications that depend on Qt WebEngine:

部署 QML 导入

If Qt Quick integration is used in the application, the QtWebEngine import directory needs to be deployed.

部署 Qt WebEngine Processes

Qt WebEngine takes advantage of the multi-process model that the Chromium project offers. The multi-process model requires that the Qt WebEngine Process executable be deployed alongside your application.

The WebEngine process is executed for each QWebEngineView or WebEngineView instance. For example, a browser application with two tabs open should have two separate instances of the process running. This is a common approach used by most modern web engines to provide a stable browsing experience.

At runtime, Qt WebEngine looks for the QtWebEngineProcess executable in the directory that QLibraryInfo::location( QLibraryInfo::LibraryExecutablesPath ) returns. For Qt installations, this is QTDIR/libexec (Linux) or QTDIR\bin (Windows). The path can be changed by defining a qt.conf file, for example. Alternatively, an executable path can be set as a value of the QTWEBENGINEPROCESS_PATH environment variable. On macOS, Qt WebEngine looks for the executable in .app/Helpers/QtWebEngineProcess .

部署资源

Qt WebEngine 要求下列资源文件:

  • qtwebengine_resources.pak contains the resources needed by Chromium.
  • qtwebengine_devtools_resources.pak contains tools for remote debugging.
  • qtwebengine_resources_100p.pak contains images suitable for low resolution displays.
  • qtwebengine_resources_200p.pak contains images suitable for high DPI displays.
  • icudtl.dat provides support for International Components for Unicode (ICU). It is the Chromium version of ICU, which is not needed if Qt WebEngine was configured to use the system ICU.

从以下位置搜索资源:

Alternatively, a resources directory path can be set as a value of the QTWEBENGINE_RESOURCES_PATH 环境变量。

翻译

区域设置数据 (譬如 en-US.pak ) 从以下位置搜索:

  • 在 macOS: .app/Content/Resources
  • 在 Linux 和 Windows: qtwebengine_locales directory in the directory specified by QLibraryInfo::location( QLibraryInfo::TranslationsPath )

Alternatively, a locales directory path can be set as a value of the QTWEBENGINE_LOCALES_PATH 环境变量。

Qt 资源文件中的 JavaScript 文件

WebEngine application is built using the Qt Quick Compiler, and the application ships JavaScript files inside .qrc resources, and these files are supposed to be loaded from inside HTML pages, make sure to specify the resource files in a QTQUICK_COMPILER_SKIPPED_RESOURCES qmake variable inside your project. This prevents the Qt Quick Compiler from trying to generate C++ code for the corresponding JavaScript code, as well as removing the original JavaScript code from the Qt resources file, which would lead to broken HTML pages. For example:

QTQUICK_COMPILER_SKIPPED_RESOURCES += resources/my_resource.qrc
					

macOS Specific Deployment Steps

To deploy a Qt WebEngine application that accesses the microphone or camera on macOS, you will need to provide texts for the messages that will be shown to the user to explain why the application asks for permission to access to the camera or microphone. To do this, add the texts to the application's Info.plist file using the keys described below.

For the camera usage message, provide a text using the following key:

<key>NSCameraUsageDescription</key>
<string>Your message text for camera usage.</string>
					

For the microphone usage message, provide a text using the following key:

<key>NSMicrophoneUsageDescription</key>
<string>Your message text for microphone usage.</string>
					

To notarize an application that accesses the camera or the microphone, you will need to add the corresponding keys to your application's entitlements file used for deployment and notarization.

To enable access to the camera, add:

<key>com.apple.security.device.camera</key>
<true/>
					

To enable access to the microphone, add:

<key>com.apple.security.device.microphone</key>
<true/>
					

/sa Apple's microphone entitlement documentation .

另请参阅 l{https://developer.apple.com/documentation/bundleresources/information_property_list/nscamerausagedescription}, Apple's property list file documentation, l{https://developer.apple.com/documentation/bundleresources/information_property_list/nsmicrophoneusagedescription}, Apple's property list file documentation, l{https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_security_device_camera}, and Apple's camera entitlement documentation.