20 KiB
20 KiB
🛡️ 发布中防误刷新(15:46,合并)
内容
- 发布按钮文案统一为:
正在发布...请勿刷新或关闭网页 - 发布中启用浏览器
beforeunload拦截,刷新/关闭页面会触发原生二次确认 - 适用于发布管理页全部平台(抖音 / 微信视频号 / B站 / 小红书)
- 后续优化已登记:发布任务状态恢复机制(任务化 + 状态持久化 + 前端轮询恢复)
涉及文件
frontend/src/features/publish/model/usePublishController.tsfrontend/src/features/publish/ui/PublishPage.tsx
🖼️ 发布成功截图稳定性优化(15:26,合并)
内容
- 成功判定后先等待页面加载,再额外等待
3s后截图,避免抓到半加载页面 - 针对“截图里页面内容只占 1/3”问题,成功截图从
full_page=True调整为视口截图full_page=False - 视频号成功截图前额外恢复
zoom=1.0,避免流程缩放影响最终截图比例 - 抖音成功截图同步应用相同策略,统一前端展示观感
涉及文件
backend/app/services/uploader/weixin_uploader.pybackend/app/services/uploader/douyin_uploader.py
🧪 视频号录屏 Debug 开关(15:12,已回收)
内容
- 为视频号上传器新增 Playwright 录屏能力,开关受
WEIXIN_DEBUG_ARTIFACTS && WEIXIN_RECORD_VIDEO控制 - 新增视频号录屏配置项:
WEIXIN_RECORD_VIDEOWEIXIN_KEEP_SUCCESS_VIDEOWEIXIN_RECORD_VIDEO_WIDTHWEIXIN_RECORD_VIDEO_HEIGHT
- 上传流程在
finally中统一保存录屏,失败必保留;成功录屏默认按开关清理 - 排障阶段临时开启过视频号 debug/录屏;当前已回收为默认关闭(
run_backend.sh设为false)
涉及文件
backend/app/services/uploader/weixin_uploader.pybackend/app/core/config.pyrun_backend.shDocs/DEPLOY_MANUAL.md
🔁 后端启动脚本统一为 run_backend.sh (15:00)
内容
- 删除旧脚本
run_backend_xvfb.sh - 将
run_backend.sh统一为 xvfb + headful 启动逻辑(不再保留非 xvfb 版本) - 默认端口从
8010统一为8006 - 启动脚本默认关闭微信/抖音 debug 产物
- 更新部署手册中的启动与 pm2 示例,统一使用
run_backend.sh
涉及文件
run_backend.shrun_backend_xvfb.sh(deleted)Docs/DEPLOY_MANUAL.md
🧾 视频号卡顿与文案未写入修复 (14:52)
内容
- 复盘日志确认视频号
post_create请求已成功,但结果判定仅靠页面文案,导致长时间“等待发布结果” - 发布判定优化:
post_create成功且页面进入post/list时立即判定成功 - 发布超时改为失败返回(不再
success=true假成功) - “标题+标签写在视频描述”进一步加强:先按
视频描述标签定位输入框,再做 placeholder 与 contenteditable 兜底 - 视频号发布结果等待超时从
180s收敛到90s
涉及文件
backend/app/services/uploader/weixin_uploader.py
🚦 视频号发布卡顿根因与快速判定 (14:45)
内容
- 定位到卡顿根因是实际请求已提交(
post_create成功)但结果判定仍在轮询文本提示,导致长时间等待 - 新增发布成功网络信号:监听
post/post_create成功响应后标记已提交 - 若已提交且页面已回到内容列表(
/post/list),立即判定发布成功,不再等满超时 - 新增发布接口失败信号:
post_create返回错误时立即失败返回
涉及文件
backend/app/services/uploader/weixin_uploader.py
📸 视频号发布成功截图接入前端 (13:34)
内容
- 为微信视频号新增“发布成功截图”能力:发布成功后直接对当前成功页截图
- 截图存储沿用私有隔离目录:
private_outputs/publish_screenshots/{user_id} - 返回前端的
screenshot_url使用鉴权接口:/api/publish/screenshot/{filename} - 视频号上传器新增
user_id透传,确保截图按用户隔离
涉及文件
backend/app/services/uploader/weixin_uploader.pybackend/app/services/publish_service.py
✍️ 视频号描述填充修正 + 关闭调试产物 (13:26)
内容
- 按最新规则调整视频号文案填充:标题和标签统一写入“视频描述”输入区
- 标签统一规范为
#标签形式并去重 - 若未找到“视频描述”输入区,直接返回失败,避免“发布成功但标题/标签为空”
- 关闭视频号 debug 产物:新增
WEIXIN_DEBUG_ARTIFACTS=false,禁用调试日志与截图输出 run_backend.sh增加WEIXIN_DEBUG_ARTIFACTS=false,启动脚本层面强制关闭
涉及文件
backend/app/services/uploader/weixin_uploader.pybackend/app/core/config.pyrun_backend.sh
🚫 强制关闭抖音调试产物 (13:15)
内容
- 进一步收紧为“默认不生成任何抖音 debug 截屏/日志/录屏”
- 录屏开关改为依赖
DOUYIN_DEBUG_ARTIFACTS && DOUYIN_RECORD_VIDEO,避免单独误开 run_backend.sh增加环境变量强制关闭:DOUYIN_DEBUG_ARTIFACTS=falseDOUYIN_RECORD_VIDEO=false
- 仅保留给用户看的发布成功截图(私有目录 + 鉴权访问)
涉及文件
backend/app/services/uploader/douyin_uploader.pybackend/app/core/config.pyrun_backend.sh
🧹 关闭调试截屏/录屏并清理历史文件 (13:08)
内容
- 抖音调试产物默认关闭:
DOUYIN_DEBUG_ARTIFACTS=falseDOUYIN_RECORD_VIDEO=false
- 保留功能信号监听(上传提交/封面生成/发布接口状态)用于流程判断,不依赖调试文件
- 已删除现有抖音调试文件(
debug_screenshots下的douyin_*截图、日志与失败录屏) - 继续保留并展示“给用户看的发布成功截图”(用户隔离 + 鉴权访问)
涉及文件
backend/app/core/config.pybackend/app/services/uploader/douyin_uploader.pybackend/app/debug_screenshots/douyin_*(deleted)backend/app/debug_screenshots/videos/douyin_*(deleted)
🔒 成功截图用户隔离 (12:58)
内容
- 发布成功截图改为用户隔离存储,不再写入公开静态目录
- 存储目录迁移到私有路径:
private_outputs/publish_screenshots/{user_id} - 新增鉴权访问接口:
GET /api/publish/screenshot/{filename}(必须登录,仅可访问本人截图) - 返回给前端的
screenshot_url改为鉴权接口地址,避免跨用户直接猜路径访问
涉及文件
backend/app/services/uploader/douyin_uploader.pybackend/app/services/publish_service.pybackend/app/modules/publish/router.pybackend/app/core/config.py
🎯 封面触发提速与审核中截图强化 (12:49)
内容
- 修复“上传完成后长时间不进入封面”:当出现
重新上传+预览且已收到视频提交信号时,立即进入封面步骤 - 目标是减少“处理中”文案残留导致的额外等待
- 成功截图逻辑强化为优先“真实点击审核中标签”,新增文本点击兜底,不再只用可见即通过
- 若审核中列表未马上出现标题,自动刷新并再次进入审核中重查后再截图
涉及文件
backend/app/services/uploader/douyin_uploader.py
🔐 登录态识别增强(避免误报上传失败) (12:41)
内容
- 针对“未触发文件选择弹窗”误报,新增登录页识别:
- URL 关键字:
passport/login/check_qrconnect/sso - 页面文本:
扫码登录/验证码登录/立即登录/抖音APP扫码登录等 - 登录控件:手机号/验证码输入框、登录按钮
- URL 关键字:
- 上传阶段重试后若识别为登录页,直接返回
Cookie 已失效,请重新登录 - 避免把“实际掉登录”误判成“上传入口失效”
涉及文件
backend/app/services/uploader/douyin_uploader.py
⏱️ 发布阶段超时与网络不佳快速失败 (12:30)
内容
- 针对“网络不佳后长时间卡住”增加发布阶段快速失败
- 上传完成后到发布结果设置总超时
60s(POST_UPLOAD_STAGE_TIMEOUT),超过直接失败 - 识别发布接口
create_v2的 HTTP 错误(如 403)并立即返回失败,不再等待 180 秒 - 发布结果判定新增网络类失败文案匹配(
网络不佳/网络异常/请稍后重试) - 阻塞弹窗关闭策略新增
暂不设置,避免“设置横封面获更多流量”弹窗阻塞点击发布
涉及文件
backend/app/services/uploader/douyin_uploader.py
🧯 封面已完成但误判失败修复 (12:22)
内容
- 针对报错“封面为必填但未设置成功”新增页面态兜底,避免封面已完成却未点击发布
- 新增
_is_cover_configured_on_page():通过横封面/竖封面+ 封面预览图判断页面已配置封面 - 当出现
horizontal_switch_missed或no_cover_button时,若页面已配置封面则允许继续发布 - 封面必填主流程增加
configured_fallback_continue兜底,降低误杀
涉及文件
backend/app/services/uploader/douyin_uploader.py
🧾 成功截图切到审核中视图 (11:26)
内容
- 按需求将“发布成功截图”改为内容管理
审核中/待审核视图,不再截“全部作品” - 发布成功后先进入内容管理并点击
审核中(或待审核)再截图 - 截图前额外尝试等待当前标题出现在审核中列表,便于确认是最新发布作品
- 发布超时兜底验证也改为优先在审核中列表查找标题
涉及文件
backend/app/services/uploader/douyin_uploader.py
✅ 封面步骤按指定顺序强约束 (11:18)
内容
- 按确认流程收紧旧发布页封面链路:
- 作品描述填完 → 点击
选择封面→ 点击设置横封面→ 点击完成→ 等待封面效果检测通过 → 才允许发布
- 作品描述填完 → 点击
- 新增
require_horizontal约束:封面必填场景必须切换到横封面,否则直接失败重试 - 新增封面效果检测通过等待:优先
cover/gen新请求信号,其次页面“检测通过”文案 - 避免因漏点
设置横封面导致后续卡住或误发布
涉及文件
backend/app/services/uploader/douyin_uploader.py
🧩 横封面点击漏判修复 (11:10)
内容
- 根据复现反馈修复“未点击设置横封面导致封面流程卡住”问题
- 新增
_switch_to_horizontal_cover(),扩展横封面入口选择器(设置横封面/横封面/横版封面) - 进入封面弹窗后先关闭阻塞弹窗再点击横封面,点击失败会重试一次
- 若页面存在横封面入口但始终未切换成功,直接返回失败并重试,避免长时间假等待
- 新增日志:
[douyin][cover] switched_horizontal ...、horizontal_switch_missed
涉及文件
backend/app/services/uploader/douyin_uploader.py
⚡ 横封面后直接完成优化 (11:03)
内容
- 根据实测反馈,在点击
设置横封面后新增一次“立即点击完成”快速路径 - 若平台已自动选中横封面,将直接确认并退出弹窗,不再执行后续封面扫描
- 新增日志:
[douyin][cover] fast_confirm_after_switch ...
涉及文件
backend/app/services/uploader/douyin_uploader.py
⚙️ 封面步骤提速优化 (10:58)
内容
- 复盘日志确认旧发布页封面步骤存在明显耗时(示例:
required_by_text到cover selected约 35 秒) - 新增封面“快速确认”路径:若平台已默认选中封面,直接确认并跳过多余扫描
- 收紧封面成功条件:仅“确认按钮点击成功”才算封面设置成功,避免误判
- 缩短不必要等待并新增封面耗时日志:
[douyin][cover] fast_confirm/selected=... confirmed=... elapsed=...
涉及文件
backend/app/services/uploader/douyin_uploader.py
🧾 发布成功截图前台展示 (10:48)
内容
- 按需求删除
run_backend_xvfb_live.sh,不再提供实时直播脚本 - 抖音发布成功时自动保存成功截图到
outputs/publish_screenshots - 发布接口返回
screenshot_url,前端发布结果卡片直接展示截图并支持点击查看大图 - 发布结果不再 10 秒自动清空,方便用户确认“是否真正发布成功”
涉及文件
backend/app/services/uploader/douyin_uploader.pyfrontend/src/features/publish/model/usePublishController.tsfrontend/src/features/publish/ui/PublishPage.tsxrun_backend_xvfb_live.sh(deleted)
🧬 抖音界面差异根因与环境对齐 (10:20)
内容
- 定位到 Playwright 与手动 Win11 Chrome 的环境指纹不一致(Linux 平台 + 自动化上下文),可能触发不同灰度界面
- 抖音上传器新增独立浏览器配置项,不再复用
WEIXIN_*配置 - 新增
DOUYIN_*配置:HEADLESS_MODE/USER_AGENT/LOCALE/TIMEZONE_ID/CHROME_PATH/BROWSER_CHANNEL/FORCE_SWIFTSHADER - 上传器启动改为
_build_launch_options(),可直接切换到系统 Chrome + headful(推荐配合 xvfb)
涉及文件
backend/app/services/uploader/douyin_uploader.pybackend/app/core/config.py
🪄 新旧发布页封面逻辑分流 (10:28)
内容
- 依据页面结构自动分流:
- 新版发布页(封面非必填):默认跳过封面设置
- 旧版发布页(出现
设置封面+必填):强制先设置封面
- 新增
_is_cover_required()判断,避免在新页面做多余封面操作 - 若判定为非必填但点击发布失败,会回退尝试设置封面后再重试发布
涉及文件
backend/app/services/uploader/douyin_uploader.py
📺 虚拟屏实时观看方案 (10:36)
内容
- 新增
run_backend_xvfb_live.sh,在 Xvfb 下同时启动后端与实时画面转码 - 通过 ffmpeg 抓取虚拟屏并输出 HLS:
/outputs/live/live.m3u8 - 适用于“边跑自动发布边实时观看”,不依赖 VNC
- 默认仍保留失败录屏,HLS 用于过程实时观察
涉及文件
run_backend_xvfb_live.sh
🎥 抖音后台录屏能力 (09:55)
内容
- 新增抖音自动发布过程录屏能力,便于定位“卡住在哪一步”
- 录屏文件保存目录:
backend/app/debug_screenshots/videos - 默认开启录屏,默认只保留失败录屏(成功录屏自动清理)
- 每次执行会在网络日志追加录屏保存记录(
[douyin][record]) - 增加发布阶段关键标记日志:
publish_wait ready、publish_click try/clicked - 新增配置项:
DOUYIN_RECORD_VIDEO、DOUYIN_KEEP_SUCCESS_VIDEO、DOUYIN_RECORD_VIDEO_WIDTH、DOUYIN_RECORD_VIDEO_HEIGHT
涉及文件
backend/app/services/uploader/douyin_uploader.pybackend/app/core/config.py
🚀 发布按钮等待逻辑修正 (10:00)
内容
- 根据线上反馈,发布页不再做冗长前置等待,改为“尽快尝试点击发布”
- 新增发布按钮定位策略(role + text 多选择器),避免
exact role匹配失败导致假等待 - 将发布按钮等待上限从上传超时(300s)独立为
PUBLISH_BUTTON_TIMEOUT=60s - 点击发布阶段统一走
_click_publish_button,并持续记录publish_wait/publish_click日志
涉及文件
backend/app/services/uploader/douyin_uploader.py
🧪 上传完成特征判定增强 (10:07)
内容
- 基于实测页面特征补齐“上传中/上传完成”判定:
- 上传中:
上传过程中请不要刷新、取消上传、已上传/当前速度/剩余时间 - 上传完成:
重新上传+预览视频/预览封面/标题
- 上传中:
- 仅在确认上传完成后才允许执行发布点击,避免“未传完提前发布”
- 新增上传等待日志:
[douyin][upload_wait] ...,可直观看到卡在上传中还是等完成信号
涉及文件
backend/app/services/uploader/douyin_uploader.py
⏸️ 上传完成后延时发布 (10:10)
内容
- 根据实测反馈,增加“上传完成后固定等待 2 秒”再点发布
- 避免刚出现完成信号就立即点击,给前端状态收敛留缓冲
- 新增日志标记:
[douyin][upload_ready] wait_before_publish=2s
涉及文件
backend/app/services/uploader/douyin_uploader.py
🖼️ 恢复封面设置流程 (10:14)
内容
- 按实测需求恢复“上传完成后先设置封面,再发布”流程
- 封面设置改为最多尝试 2 次,成功写入
[douyin][cover] selected - 若封面未设置成功则直接终止发布并保存截图
cover_not_selected - 避免出现“未设封面就点击发布”的情况
涉及文件
backend/app/services/uploader/douyin_uploader.py
🛠️ 抖音发布流程修复 (09:20)
内容
- 按最新页面流程改为先进入首页并点击
高清发布,再进入上传页 - 新增未发布草稿处理:检测到
你还有上次未发布的视频时自动点击放弃 - 上传策略改为优先点击
上传视频并走 file chooser,失败后再回退多 input 选择器 - 只有检测到
基础信息/作品描述/发布设置/重新上传等发布态信号才继续,避免误判“已上传” - 修复无扩展名视频临时文件策略:优先 hardlink,失败时 copy,移除 symlink 回退
- 适配当前智能封面流程:跳过手动封面操作
- 话题填写改为在简介/描述区域使用
#标签形式追加
涉及文件
backend/app/services/uploader/douyin_uploader.py
⚡ 抖音等待链路再收敛 (09:52)
内容
- 根据“选完视频即进入发布页”流程,移除独立的上传完成轮询阶段
- 改为在点击发布前统一等待“发布按钮可点击”,避免重复等待导致总时长偏长
- 新增
publish_wait调试日志,按秒记录按钮可点击等待时长 - 超时文案改为明确提示“发布按钮长时间不可点击”
- 上传入口改为严格 file chooser 流程:只走“点击上传视频 → 选择文件 → 进入发布页”链路
- 移除直接 input 回退上传,避免绕开上传入口导致状态机异常
涉及文件
backend/app/services/uploader/douyin_uploader.py
🧭 抖音卡慢环节定位与修复 (09:45)
内容
- 通过
douyin_network.log定位到卡慢发生在“上传完成判定”阶段,而非真正提交发布接口 - 新增上传完成网络信号:
CommitUploadInner成功与封面生成成功信号写入日志 - 收紧“上传完成”判定,移除
publish_button_enabled这种过早放行条件 - 仅在检测到
重新上传/重新选择或上传提交信号后才进入下一步,降低误判导致的长等待
涉及文件
backend/app/services/uploader/douyin_uploader.py
✅ 抖音发布结果判定修正 (09:38)
内容
- 修复“发布检测超时仍返回 success=true”的问题,超时场景改为
success=false - 优化超时返回文案,明确为“发布状态未知,需要后台确认”
- 下线过于宽松的管理页兜底判定(仅出现
审核中不再当作发布成功) - 超时时即使管理页出现同名标题也不直接判定成功,避免旧作品同名导致误报
涉及文件
backend/app/services/uploader/douyin_uploader.py
⏱️ 抖音上传完成判定优化 (09:34)
内容
- 根据最新日志确认文件上传已开始并有分片上传请求成功,但流程长时间停留在“等待上传完成”
- 扩展“上传完成”判定条件,不再只依赖单一
long-card + 重新上传选择器 - 新增上传完成信号:
重新上传/重新选择可见、发布按钮可用、发布设置或预览视频可见 - 上传等待日志增加耗时秒数,便于判断是否真实卡住
涉及文件
backend/app/services/uploader/douyin_uploader.py