[P0] COS 预签名 URL q-sign-time 结束时间戳被截断,iOS 端文件下载全部 AccessDenied #69
Closed
opened 2026-06-03 22:56:25 +08:00 by wangdl
·
3 comments
Labels
Clear labels
area:activity
活动/统计
area:admin
管理后台
area:admin-api
area:ai
AI/RAG
area:ai-runtime
AI Runtime / AI 分析体系相关
area:analytics
area:api
API 接口
area:auth
认证与授权
area:cos
对象存储
area:database
数据库/Migration
area:import
文件导入/解析
area:knowledge
知识库/知识点
area:learning-info
area:learning-session
area:quiz
测验/自测
area:reading-event
area:reading-progress
area:review
复习系统
area:security
安全相关
audit:api-admin-info
audit:api-info
audit:planned
已完成宏观规划,尚未代码审查
audit:reviewed
blocked-by:api-info-aggregation
blocked-by:api-info-core
blocked-by:api-info-ops
blocked-by:api-info-schema
blocked-by:processor
blocked-by:schema
priority:p0
最高优先级,阻塞发布
priority:p1
高优先级,里程碑必需
priority:p2
中优先级,后续版本
repo:api
API 仓库 Issue
status:blocked
被阻塞
status:done
已完成
status:partial
status:todo
type:aggregation
type:bug
缺陷修复
type:design
设计
type:docs
文档
type:feature
新功能
type:migration
type:refactor
重构
type:test
work:admin-api
work:aggregation
work:api
work:artifact
题目/卡片产物
work:audit
work:circuit-breaker
熔断
work:contract
work:design
架构/协议设计工作
work:docs
work:export
work:extend-existing
work:internal-api
Runtime 内部接口
work:job
Job 调度相关
work:new-module
work:new-table
work:ops
work:query
work:quota
额度/限流
work:schema
Prisma Schema 设计
work:security
work:service
Service 层实现
work:snapshot
Snapshot 构建
work:test
No Label
Milestone
No items
No Milestone
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: wangdl/api-server#69
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
现象
iOS App 请求下载知识点对应的 .md 文件时,COS 返回 403 AccessDenied。
根因
后端生成腾讯云 COS 预签名 URL 时 q-sign-time 参数的结束时间戳被截断。
错误: q-sign-time=1779893650;1779(结束时间应为完整时间戳)
排查方向
关联网址
https://git.longde.cloud/wangdl/ios-projects
修复汇报 (2026-06-05)
根因
COS 预签名 URL 通过
cos-nodejs-sdk-v5在创建知识点时生成了 24 小时有效期签名,存入 DB 的content字段。签名过期后 COS 返回403 AccessDenied。修复方案
在
KnowledgeItemsService.findById(即GET /knowledge-items/:id)中新增enrichItem()方法:content是否是 COS URL(含.cos.和myqcloud.com)objectKeyStorageService.getDownloadUrl()生成新的 7 天有效签名 URLfindByKnowledgeBaseId不做刷新(避免 N 次 COS API 调用)修改文件
src/modules/knowledge-items/knowledge-items.service.ts— 新增enrichItem()src/modules/knowledge-items/knowledge-items.module.ts— 导入StorageModuleiOS 端配合
iOS
KnowledgeDetailViewModel.load()已通过KnowledgeItemService.shared.detail(id:)重新获取知识点,拿到新鲜 URL 后再下载。状态
✅ 代码已完成,待部署到服务器验证。
Bug 修复 (2026-06-06)
问题
enrichItem()中enriched.sourceType = enriched.sourceType || headInfo.contentType将 COS 返回的 MIME 类型(text/markdown、application/pdf)写入了sourceType字段,而 sourceType 应该是markdown、pdf等简洁值。修复
移除
sourceType的 MIME type 覆盖逻辑。sourceType 由detectSourceType()在创建时自动检测,不需要 enrichItem 再设置。fileSize 仍正常填充。状态
✅ 已修复。
优化 (2026-06-06)
问题
enrichItem()在 COS 调用失败时静默catch {}吞错,排查困难。修复
改用
catch (err)+Logger.warn()记录错误信息。状态
✅ 已修复。