架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1906|回复: 1

[资料] 【WebView2】(五)虚拟主机之加载本地 HTML 资源

[复制链接]
发表于 2022-10-10 16:41:42 | 显示全部楼层 |阅读模式
需求:假如客户机器无法访问外部 Web 网站(例如:基于 WebView2 做一个音乐播放器软件,在没有网络的情况下,也能正常使用播放本地歌曲),WebView2 就无法访问外网资源无法显示,从而使软件无法正常工作,如何将 HTML、CSS、JS 资源嵌入到安装包里面,使 WinFrom 程序加载客户本地文件资源呢?将 HTML、CSS、JS 代码打包进安装包还有一个优势是不会受到用户网速的影响,因为 WebView2 是直接读取客户本地的文件。

回顾:

【WebView2】(一)初识 Microsoft Edge WebView2 技术
https://www.itsvse.com/thread-10361-1-1.html

【WebView2】(二)WinForm 引入 WebView2 显示 Web 内容
https://www.itsvse.com/thread-10362-1-1.html

【WebView2】(三)Web 与 WinForm 应用程序双向通信
https://www.itsvse.com/thread-10364-1-1.html

【WebView2】(四)Web 与 WinForm 相互调用函数方法
https://www.itsvse.com/thread-10365-1-1.html

Angular 编译打包

前端使用 angular 框架开发,通过如下命令打包:



打包生成了 HTML、CSS、JS 文件,如下图:


QQ截图20221010162721.jpg

WinFrom 虚拟主机和文件夹映射

使 WebView2 能够正常加载本地 Web 资源,需要使用 SetVirtualHostNameToFolderMapping 设置域名和文件夹的映射关系,然后通过 WebView2 访问设置的域名,参考:https://learn.microsoft.com/zh-cn/dotnet/api/microsoft.web.webview2.core.corewebview2.setvirtualhostnametofoldermapping?view=webview2-dotnet-1.0.1343.22

主机名规则:RFC 6761保留了几个保证不会被真实站点使用的特殊用途域名(例如.example、.test和.invalid)。请注意,使用.local作为顶级域名是可行的,但在导航过程中可能会导致延迟。如果可以的话,应该避免使用.local。

c# 代码如下:


其中 SetVirtualHostNameToFolderMapping 第二个文件夹参数应该使安装包释放 Web 资源到本地磁盘文件夹的地址,我这里只是测试,所以写死了。

运行 WinFrom 程序,可以成功加载和渲染本地的 Web 资源,如下图:

QQ截图20221010163855.jpg

(完)




上一篇:【转】CURL 命令使用代理、以及代理种类介绍
下一篇:【实战】Xshell 7 查看本机电脑保存的会话密码
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2023-3-31 09:21:20 | 显示全部楼层
感谢大佬分享,正在学习
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-6-2 03:22

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表