首页
/ Cromite浏览器中"关闭窗口时删除设备数据"功能导致的SIGSEGV崩溃分析

Cromite浏览器中"关闭窗口时删除设备数据"功能导致的SIGSEGV崩溃分析

2025-06-13 03:35:35作者:邓越浪Henry

问题背景

在Cromite浏览器135.0.7049.52版本中,当用户启用了"关闭所有窗口时删除网站保存在设备上的数据"功能后,浏览器在关闭时会出现SIGSEGV段错误崩溃。这个问题最早出现在133版本左右,且仅在Linux平台上出现。

崩溃现象

当用户在设置中启用"删除数据站点已保存到您的设备当您关闭所有窗口"选项,并浏览一些未被加入白名单的网站后关闭浏览器时,系统会产生核心转储文件。从堆栈跟踪可以看出,崩溃发生在网络模块处理信任令牌(Trust Token)相关操作时。

技术分析

从崩溃堆栈可以观察到以下关键点:

  1. 崩溃发生在network::PendingTrustTokenStore::ExecuteOrEnqueue方法中
  2. 调用链涉及网络上下文清理会话数据的过程
  3. 问题与Mojo IPC通信机制有关,特别是在处理跨进程消息时

深入分析表明,这个问题与浏览器关闭时清理站点数据的异步操作有关。当浏览器尝试清理未被列入白名单的站点数据时,信任令牌存储可能已经被销毁,导致后续操作访问了无效内存。

解决方案

该问题已在后续版本中得到修复。对于遇到此问题的用户,可以采取以下临时解决方案:

  1. 暂时禁用"关闭窗口时删除设备数据"功能
  2. 使用chrome://settings/clearBrowserData手动清理浏览器数据
  3. 考虑使用不同的浏览器配置文件来隔离需要保留登录状态的网站

构建配置建议

在自行构建Cromite浏览器时,建议注意以下构建参数:

  • symbol_level=0:保留足够的调试信息用于生成堆栈跟踪
  • is_official_build=true:在x86_64架构上自动启用CFI保护
  • 避免使用use_sysroot以减少构建复杂度

最佳实践

对于需要保留特定网站登录状态的用户,建议:

  1. 使用浏览器内置的白名单功能
  2. 考虑使用密码管理器替代长期保留cookie
  3. 定期手动清理浏览器数据而非依赖自动清理

总结

这个崩溃问题展示了浏览器数据清理机制与信任令牌系统之间的复杂交互。Cromite团队已经修复了这个问题,用户可以通过更新到最新版本获得修复。同时,这也提醒我们在处理浏览器数据清理时需要特别注意异步操作的时序问题。

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