首页
/ Snap Hutao项目祈愿记录网页缓存刷新功能失效问题分析

Snap Hutao项目祈愿记录网页缓存刷新功能失效问题分析

2025-06-13 02:00:19作者:何将鹤

问题背景

在Snap Hutao项目1.11.7.0版本中,用户反馈从网页缓存刷新祈愿记录时出现"未找到可用URL"的错误提示。有趣的是,当用户手动从网页缓存中查找URL并使用"手动输入URL"功能时,却能够正常获取祈愿记录。这表明问题并非出在核心功能上,而是与自动URL提取流程有关。

问题定位

经过代码审查,开发者在GachaLogQueryWebCacheProvider.cs文件中发现了问题根源。该文件第65行代码存在逻辑错误:

using (TempFileStream fileStream = TempFileStream.CopyFrom(path, FileMode.Open, FileAccess.Read))

这段代码原本应该从缓存文件中读取数据来查找URL,但实际上却错误地从游戏主程序路径(YuanShen.exe)读取数据。正确的做法应该是从变量cacheFile中获取缓存文件路径。

技术分析

这个问题属于典型的"变量误用"错误类型。在实现网页缓存刷新功能时,开发者需要:

  1. 定位游戏缓存文件位置
  2. 读取缓存文件内容
  3. 从内容中提取祈愿记录URL

原始代码中错误地将游戏主程序路径(path)而非缓存文件路径(cacheFile)传递给文件读取方法,导致系统无法在游戏主程序中找到祈愿记录URL,从而抛出"未找到可用URL"的错误。

解决方案

修复方案简单直接:将path替换为正确的cacheFile变量。这个修改确保了系统能够从正确的文件位置读取数据并提取URL。

using (TempFileStream fileStream = TempFileStream.CopyFrom(cacheFile, FileMode.Open, FileAccess.Read))

经验总结

这个案例提醒开发者:

  1. 变量命名应当清晰明确,避免使用过于通用的名称如path
  2. 在处理多个文件路径时,应当仔细检查每个路径变量的用途
  3. 单元测试应当覆盖各种数据源情况,包括网页缓存刷新场景

该问题已在1.11.8版本中得到修复,用户现在可以正常使用网页缓存刷新功能获取祈愿记录。

登录后查看全文
热门项目推荐
相关项目推荐