关于UnityWebgl缓存机制

最近在做UnityWebgl热更的时候,我的热更程序集更新,而我所有运行过项目的设备都没有更新成功。而没运行过的设备则运行的是最新的程序集。那么说明必然是和缓存有关系了。

特意查了一下问题,发现Edge浏览器会把一些比较小的图片、脚本等资源进行缓存,以便下次再次运行的时候能够更加快速流畅。我这里使用的是HybirdCLR做代码热更,发现这个热更程序集会被浏览器缓存,所以热更后浏览器依然读的是缓存的旧程序集。

查了很多资料,有些人说需要JS原生开发去处理缓存,做好版本控制。我这里发现了另外一种方式,在Unity内也可以直接做到。

1、下面是我的测试案例:

代码:

cs 复制代码
      string testpersistentDataPathPath = Application.persistentDataPath + "1.txt";
        Debug.Log(Application.persistentDataPath);

        Debug.Log("persistent是否存在:" + File.Exists(testpersistentDataPathPath));

        if (File.Exists(testpersistentDataPathPath))
        {
            Debug.Log($"存在Persistent,他的内容是{File.ReadAllText(testpersistentDataPathPath)}");
        }
        else
        {
            Debug.Log($"写入 {testpersistentDataPathPath}");
            File.WriteAllText(testpersistentDataPathPath, "哈哈哈");
        }

1、查找webgl的持久化路径(Application.persistentDataPath) ,它是存在的,打印出来的是**/idbfs/7e2ca8b4761dc653a9fdda6daab68d82。**

2、使用IO 去写入一个txt文件(内容为哈哈哈),也写入成功了。

3、第二次进入,直接就可以读了,那么说明确实是缓存成功了。

似乎被缓存到了Cookie中,我删除记录后就需要重新写入了。

那么既然我已经可以直接用File读到缓存的文件了,那么说明我也可以去判断程序集是否更新,通过MD5也行、版本控制都可以。

2、以下来自ChatGPT4.0的解释

在Unity WebGL中,Application.persistentDataPath实际上是一个虚拟文件系统(Virtual File System, VFS),它在运行时通过浏览器的IndexedDB存储数据。这种方式让你感觉像是在写入文件系统,但实际上是利用浏览器的存储机制来持久化数据。因此,你可以成功写入文件,但这些文件是存在于浏览器的IndexedDB中,而不是本地文件系统中。

3、temporaryCachePath,我顺便测了下这个路径,这个路径用得比较少。实测在webgl中无法写入

4、以下来自Unity官网的解释

相关推荐
雨中飘荡的记忆1 小时前
ElasticJob分布式调度从入门到实战
java·后端
考虑考虑10 小时前
JDK25模块导入声明
java·后端·java ee
_小马快跑_11 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero14 小时前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记14 小时前
Spring Boot条件注解详解
java·spring boot
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林5511 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
NE_STOP2 天前
springMVC-HTTP消息转换器与文件上传、下载、异常处理
spring
华仔啊2 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing2 天前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员