fix: allow new session binding after /clear command

- 移除 isOldSession 检查,信任客户端的 session ID 作为新会话标识
- 将 sessionBindingTtlDays 默认值从 30 天改为 1 天,避免 Redis 内存累积
- 添加新会话绑定的监控日志(包含 sessionId、messages 数量、accountId 等)
- 完美支持 Claude Code /clear 等合法的新会话场景
- 同步更新前端界面的默认值配置

问题背景:
用户在 Claude Code 中执行 /clear 后,会生成新的 session ID,
但旧的逻辑会检查请求内容判定为"旧会话",导致返回"本地session已污染"错误。

修复方案:
采用方案2(放宽新会话检测)+ TTL 优化,信任客户端的 session ID,
不再检查请求内容是否"看起来像旧会话",由 1 天的 TTL 自动清理过期绑定。

影响范围:
- src/routes/api.js (流式和非流式两处)
- src/services/claudeRelayConfigService.js
- web/admin-spa/src/views/SettingsView.vue
This commit is contained in:
enzyme2013
2026-01-22 17:31:11 +08:00
parent 9ebef1b116
commit 16e2bcfedb
3 changed files with 17 additions and 29 deletions

View File

@@ -370,19 +370,13 @@ async function handleMessagesRequest(req, res) {
accountId &&
accountType === 'claude-official'
) {
// 🚫 检测旧会话(污染的会话
if (isOldSession(req.body)) {
const cfg = await claudeRelayConfigService.getConfig()
logger.warn(
`🚫 Old session rejected: sessionId=${originalSessionIdForBinding}, messages.length=${req.body?.messages?.length}, tools.length=${req.body?.tools?.length || 0}, isOldSession=true`
)
return res.status(400).json({
error: {
type: 'session_binding_error',
message: cfg.sessionBindingErrorMessage || '你的本地session已污染请清理后使用。'
}
})
}
// 🆕 允许新 session ID 创建绑定(支持 Claude Code /clear 等场景
// 信任客户端的 session ID 作为新会话的标识,不再检查请求内容
logger.info(
`🔗 Creating new session binding: sessionId=${originalSessionIdForBinding}, ` +
`messages.length=${req.body?.messages?.length}, tools.length=${req.body?.tools?.length || 0}, ` +
`accountId=${accountId}, accountType=${accountType}`
)
// 创建绑定
try {
@@ -928,19 +922,13 @@ async function handleMessagesRequest(req, res) {
accountId &&
accountType === 'claude-official'
) {
// 🚫 检测旧会话(污染的会话
if (isOldSession(req.body)) {
const cfg = await claudeRelayConfigService.getConfig()
logger.warn(
`🚫 Old session rejected (non-stream): sessionId=${originalSessionIdForBindingNonStream}, messages.length=${req.body?.messages?.length}, tools.length=${req.body?.tools?.length || 0}, isOldSession=true`
)
return res.status(400).json({
error: {
type: 'session_binding_error',
message: cfg.sessionBindingErrorMessage || '你的本地session已污染请清理后使用。'
}
})
}
// 🆕 允许新 session ID 创建绑定(支持 Claude Code /clear 等场景
// 信任客户端的 session ID 作为新会话的标识,不再检查请求内容
logger.info(
`🔗 Creating new session binding (non-stream): sessionId=${originalSessionIdForBindingNonStream}, ` +
`messages.length=${req.body?.messages?.length}, tools.length=${req.body?.tools?.length || 0}, ` +
`accountId=${accountId}, accountType=${accountType}`
)
// 创建绑定
try {