ER-Save-Editor全平台存档修改指南:从入门到高级应用
2026-04-13 09:59:38作者:裴锟轩Denise
核心功能速览
- 跨平台兼容:支持PC与PlayStation全系列存档解析与修改,实现不同平台间数据迁移
- 安全修改机制:内置签名验证绕过与数据校验系统,确保修改后存档可正常加载
- 批量管理工具:提供装备、属性、事件等多维度批量编辑功能,支持JSON配置导入
环境准备与基础配置
开发环境搭建
-
克隆项目仓库到本地
git clone https://gitcode.com/GitHub_Trending/er/ER-Save-Editor预期结果:项目文件将下载至本地ER-Save-Editor目录
-
安装Rust开发环境
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh预期结果:Rust编译器与Cargo包管理器将被安装到系统
-
构建项目二进制文件
cd ER-Save-Editor cargo build --release预期结果:在target/release目录下生成可执行文件
[!WARNING] 确保系统已安装gcc、make等编译工具,Linux系统可通过
apt install build-essential命令安装依赖
常用命令速查
| 命令用途 | 基础命令格式 |
|---|---|
| 显示帮助 | cargo run -- --help |
| 验证存档 | cargo run -- --validate <存档路径> |
| 基础修改 | cargo run -- --modify <修改类型> <存档路径> |
| 平台转换 | cargo run -- --convert <转换类型> <源文件> <目标文件> |
存档解析与结构分析
跨平台存档格式对比
| 特性 | PC平台 | PlayStation平台 |
|---|---|---|
| 文件格式 | .sl2 (BND4容器) | .bin (SFO+BIN组合) |
| 加密方式 | AES-128-CBC | RSA-2048 (PS4)/AES-256-GCM (PS5) |
| 数据偏移量(文件中特定信息的存储位置标记) | 0x200 | 0x100 (PS4)/0x400 (PS5) |
| 签名验证 | 可移除 | 必须重新签名 |
存档解析核心原理
存档解析模块通过内存映射技术将二进制文件映射为Rust结构体,关键代码位于src/read/read.rs:
pub struct SaveMetadata {
pub file_version: u32, // 存档文件版本
pub character_id: [u8; 16], // 角色唯一标识符
pub last_modified: u64, // 最后修改时间戳
pub data_crc: u32 // 数据校验和
}
解析过程采用零复制设计,直接在内存中操作二进制数据,避免额外内存开销。
⚠️ 风险提示:解析错误可能导致程序崩溃,建议先使用--validate参数验证存档完整性
全平台修改流程
PC平台修改步骤
-
创建存档备份
cp ./ER0000.sl2 ./ER0000_backup_$(date +%Y%m%d).sl2预期结果:生成带日期戳的备份文件
-
执行属性修改
cargo run --release --features pc -- --modify stats \ --vigor 60 --mind 40 --endurance 50 ./ER0000.sl2预期结果:角色属性被调整至指定值,存档头部签名自动移除
-
验证修改结果
cargo run -- --validate ./ER0000.sl2预期结果:控制台输出"Validation successful"确认修改有效
PlayStation平台修改步骤
-
导入PS存档至PC
cargo run -- --ps-import ./PS4_SAVE.bin ./imported_save.sl2预期结果:PS存档被转换为PC兼容格式
-
执行装备修改
cargo run -- --modify equipment --add 1001,10,1 --add 1015,5,1 ./imported_save.sl2预期结果:指定ID的武器被添加到角色装备栏
-
生成签名并导出
cargo run -- --ps-sign ./imported_save.sl2 ./PS4_MODIFIED.bin预期结果:生成带有有效签名的PS格式存档
⚠️ 风险提示:PlayStation平台存档修改后必须重新签名,否则主机将拒绝加载
高级功能应用
批量装备管理
通过JSON配置文件实现批量装备导入:
- 创建
equipment_config.json文件:
{
"equipment_set": {
"primary_weapon": {"id": 1001, "upgrade": 10, "affinity": 3},
"secondary_weapon": {"id": 1015, "upgrade": 5, "affinity": 1},
"armor_set": [100, 101, 102, 103],
"talismans": [5, 12, 23, 42]
}
}
- 执行导入命令:
cargo run -- --import-equip ./equipment_config.json ./save.sl2
修改复杂度评估矩阵
| 修改类型 | 复杂度 | 风险等级 | 推荐工具 |
|---|---|---|---|
| 属性调整 | ★☆☆☆☆ | 低 | 基础命令行 |
| 装备添加 | ★★☆☆☆ | 中 | JSON导入 |
| 事件修改 | ★★★★☆ | 高 | 专用编辑器 |
| 跨版本迁移 | ★★★★★ | 极高 | 迁移工具 |
适用场景判断:
- 新手用户:建议从属性调整开始尝试
- 进阶用户:可进行装备批量管理
- 专业用户:在备份基础上修改事件标志
自动化工作流配置
存档备份自动化脚本
创建backup_save.sh:
#!/bin/bash
SAVE_DIR="$HOME/Elden Ring/76561198068123456/remote"
BACKUP_DIR="$HOME/ER_Save_Backups"
# 创建备份目录
mkdir -p "$BACKUP_DIR"
# 备份所有存档文件
cp "$SAVE_DIR/"*.sl2 "$BACKUP_DIR/ER_$(date +%Y%m%d_%H%M%S)_"
echo "备份完成: $BACKUP_DIR"
添加执行权限并运行:
chmod +x backup_save.sh
./backup_save.sh
多步骤修改脚本
创建modify_save.sh:
#!/bin/bash
SAVE_FILE="$1"
# 步骤1: 验证存档
cargo run -- --validate "$SAVE_FILE" || exit 1
# 步骤2: 修改属性
cargo run --features pc -- --modify stats \
--vigor 60 --mind 40 --endurance 50 "$SAVE_FILE"
# 步骤3: 添加装备
cargo run --features pc -- --modify equipment \
--add 1001,10,1 --add 1015,5,1 "$SAVE_FILE"
# 步骤4: 再次验证
cargo run -- --validate "$SAVE_FILE" && echo "修改成功"
使用方法:./modify_save.sh ./ER0000.sl2
跨版本兼容性评估
版本迁移命令
# 版本迁移
cargo run -- --migrate <源版本> <目标版本> <源文件> <目标文件>
版本兼容性矩阵
| 源版本 → 目标版本 | 1.08 | 1.09 | 1.10 | 1.11 |
|---|---|---|---|---|
| 1.08 | ✅ | ✅ | ⚠️ | ❌ |
| 1.09 | ❌ | ✅ | ✅ | ⚠️ |
| 1.10 | ❌ | ❌ | ✅ | ✅ |
[!WARNING] 跨大版本迁移(如1.08→1.10)建议分阶段进行,先迁移至中间版本再升级到目标版本
问题排查决策树
-
存档无法加载
- 检查文件完整性:
cargo run -- --validate <存档路径> - 确认平台匹配:PC存档需用
--features pc编译 - 尝试修复:
cargo run -- --repair <存档路径>
- 检查文件完整性:
-
修改不生效
- 验证命令参数是否正确
- 检查存档版本是否兼容
- 确认是否针对正确平台编译
-
程序崩溃
- 检查Rust版本:
rustc --version(需1.56+) - 更新依赖:
cargo update - 以调试模式运行:
cargo run -- --debug <命令>
- 检查Rust版本:
常用命令参考卡片
| 功能 | 命令示例 |
|---|---|
| 查看存档信息 | cargo run -- --info ./save.sl2 |
| 修改卢恩数量 | cargo run -- --modify runes 5000000 ./save.sl2 |
| 解锁全地图 | cargo run -- --modify map all ./save.sl2 |
| 批量添加物品 | cargo run -- --import-items items.json ./save.sl2 |
| 存档版本转换 | cargo run -- --migrate 1.09 1.10 old.sl2 new.sl2 |
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00
热门内容推荐
最新内容推荐
智能票务抢票系统:突破手动抢票瓶颈的效率革命方案如何利用Path of Building PoE2高效规划流放之路2角色构建代码驱动的神经网络可视化:用PlotNeuralNet绘制专业架构图whisper.cpp CUDA加速实战指南:让语音识别效率提升6倍的技术解析Windows 11系统PicGo高效解决安装与更新全流程指南解决Jellyfin中文元数据难题:MetaShark插件3大场景配置指南5大技术突破:轻量级AI引擎的跨平台部署指南B站m4s格式无法播放?m4s-converter轻松搞定视频永久保存全攻略BTCPay Server 开源项目配置指南:跨平台部署与高效部署最佳实践RSSHub-Radar 使用问题全解析:从入门到进阶的解决方案
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
659
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
504
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
288
暂无简介
Dart
906
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
863
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108