关于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官网的解释

相关推荐
鼓掌MVP4 小时前
Java框架的发展历程体现了软件工程思想的持续进化
java·spring·架构
编程爱好者熊浪5 小时前
两次连接池泄露的BUG
java·数据库
lllsure5 小时前
【Spring Cloud】Spring Cloud Config
java·spring·spring cloud
拽着尾巴的鱼儿5 小时前
fixed-bug:JPA 关联关系的对象序列化循环引用问题
spring·bug·jpa
鬼火儿5 小时前
SpringBoot】Spring Boot 项目的打包配置
java·后端
NON-JUDGMENTAL5 小时前
Tomcat 新手避坑指南:环境配置 + 启动问题 + 乱码解决全流程
java·tomcat
cr7xin6 小时前
缓存三大问题及解决方案
redis·后端·缓存
chxii6 小时前
Maven 详解(上)
java·maven
李少兄6 小时前
IntelliJ IDEA 远程调试(Remote Debugging)教程
java·ide·intellij-idea
爱怪笑的小杰杰6 小时前
浏览器端缓存地图请求:使用 IndexedDB + ajax-hook 提升地图加载速度
ajax·okhttp·缓存