Flutter WebView 中是否可以允许混合内容

hog*_*gar 3 https http webview flutter

我遇到一个问题,网页使用 SSL 进行保护,但页面内的视频和音频内容却没有,源 URL 是 HTTP,这会阻止用户在 WebView 内播放这些类型的内容。消息如下:

"Mixed Content: The page at 'https://<page url>' was loaded over HTTPS, but requested an insecure video 'http://<video url>.mp4'. This request has been blocked; the content must be served over HTTPS.", source: https://<page url> (0)
Run Code Online (Sandbox Code Playgroud)

是否可以以某种方式允许或强制 WebView 加载混合内容并允许用户播放未使用 SSL 保护的内容?

谢谢

Lor*_*lli 5

webview_flutter插件没有更改 Android WebView 混合内容模式的选项。

相反,您可以使用我的flutter_inappwebview插件,它支持特定的 Android webview 选项。

在您的情况下,您可以设置 Android webview 选项mixedContentMode的值AndroidMixedContentMode.MIXED_CONTENT_ALWAYS_ALLOW

在此模式下,WebView 将允许安全源加载来自任何其他源的内容,即使该源不安全。

代码示例:

child: InAppWebView(
  initialUrlRequest: URLRequest(url: Uri.parse("https://yourwebsite.com")),
  initialOptions: InAppWebViewGroupOptions(
    android: AndroidInAppWebViewOptions(
      mixedContentMode: AndroidMixedContentMode.MIXED_CONTENT_ALWAYS_ALLOW
    )
  ),
)
Run Code Online (Sandbox Code Playgroud)