php调用听书插件如何实现断点续播_php听书插件断点续播实现法【续播】

PHP无法直接实现断点续播,需前后端协同:前端JavaScript监听播放状态并上报进度,PHP接口负责存取user_id、book_id和current_time至Redis或MySQL。

php调用听书插件如何实现断点续播_php听书插件断点续播实现法【续播】

PHP 本身不直接控制音频播放,断点续播需前后端协同

PHP 是服务端语言,无法直接读取浏览器 的当前播放时间或监听暂停/中断事件。所谓“PHP 调用听书插件实现断点续播”,本质是 PHP 提供接口存取播放进度,由前端 JavaScript 主动上报和恢复。如果跳过前端、只写 PHP 逻辑,断点续播一定失败。

关键数据存储:用 PHP 接口保存和读取用户播放位置

用户每次暂停或离开页面前,前端应通过 AJAX 向 PHP 接口提交当前 currentTime(单位:秒),PHP 将其与 user_idbook_id 一起存入数据库(如 MySQL)或缓存(如 Redis)。下次加载同一本书时,前端再调用 PHP 接口拉取该记录。

  • 推荐使用 Redis 存储,键名建议为 play_progress:{user_id}:{book_id},过期时间设为 7 天
  • MySQL 表结构至少包含:user_id(INT)、book_id(INT)、current_time(FLOAT)、updated_at(DATETIME)
  • PHP 接口示例(接收 POST):
    if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['book_id'], $_POST['time'])) {
        $book_id = (int)$_POST['book_id'];
        $time = (float)$_POST['time'];
        $user_id = get_current_user_id(); // 你自己的登录态识别逻辑
        // 写入 Redis 或 DB
        $redis->setex("play_progress:{$user_id}:{$book_id}", 60 * 60 * 24 * 7, $time);
        echo json_encode(['ok' => true]);
    }

前端 JS 必须主动管理播放状态与时间同步

仅靠 PHP 存数据远远不够。前端要处理:beforeunload 捕获页面关闭、visibilitychange 监听标签页切换、pause/ended 事件触发保存,并在 loadedmetadata 后设置 currentTime

  • 不要依赖 timeupdate 频繁上报——太耗资源,应在暂停/切页/播放结束时才调用保存接口
  • 恢复播放前务必检查音频是否已加载元数据(audio.readyState >= 1),否则设置 currentTime 会无效
  • 若音频是流式(如 HLS),currentTime 可能不精确,需配合服务端做分段对齐(如按章节/时间戳锚点)

常见失效原因:跨设备、无登录态、缓存未清理

很多“续播失效”问题其实和 PHP 逻辑无关,而是业务链路断了:

酷表ChatExcel

酷表ChatExcel

北大团队开发的通过聊天来操作Excel表格的AI工具

下载

立即学习PHP免费学习笔记(深入)”;

  • 用户未登录,user_id 为空或用 session_id 临时标识 → 换浏览器即丢失进度
  • 前端请求 PHP 接口时没带 cookie 或 token,导致服务端无法识别用户
  • CDN 或代理缓存了 PHP 返回的进度接口响应(尤其是 GET 请求),造成旧时间被反复返回
  • 音频文件 URL 带有动态参数(如签名、时间戳),导致两次加载的 实际不是同一个资源,浏览器无法复用已缓冲数据

断点续播真正难的不是存时间,而是确保「谁、在哪个设备、播哪本书、播到哪一秒」这四个维度始终可追溯且一致。PHP 只管稳稳接住和吐出那个数字,别让它跑偏就行。

https://www.php.cn/faq/1991130.html

发表回复

Your email address will not be published. Required fields are marked *