0

0

php调用听书插件如何绑定用户播放偏好_php绑定听书用户偏好技巧【偏好】

蓮花仙者

蓮花仙者

发布时间:2026-01-18 16:51:09

|

242人浏览过

|

来源于php中文网

原创

php无法直接绑定用户播放偏好,仅负责接收校验并存储前端传来的playback_rate等白名单字段为json,存入utf-8mb4兼容的text字段,并通过api返回标准json响应。

php调用听书插件如何绑定用户播放偏好_php绑定听书用户偏好技巧【偏好】

PHP 调用听书插件时,无法直接“绑定用户播放偏好”,因为偏好数据必须由前端或客户端采集(如播放速度、默认音源、章节记忆点、是否自动续播),PHP 仅负责接收、校验、持久化这些值——关键在于「谁传、怎么传、存哪、怎么读」。

如何通过 PHP 接收并存储用户播放偏好

听书插件(如基于 Web Audio 或第三方 SDK)通常在用户操作后通过 fetchXMLHttpRequest 向 PHP 接口提交偏好数据。PHP 端需提供一个接收接口(如 /api/save_preference.php),并完成基础校验与写入。

  • 必须校验 $_POST['user_id'] 或登录态(如从 $_SESSION['uid'] 获取),禁止信任前端传来的任意 user_id
  • 偏好字段应白名单过滤:只允许保存 playback_ratedefault_sourcelast_chapter_idauto_resume 等已知键名
  • 推荐用 json_encode() 存入数据库单字段(如 user_preferences TEXT),而非拆成多列——便于扩展新偏好项
  • 若用 MySQL,确保该字段支持 UTF-8mb4 编码,避免 emoji 或特殊音源名入库失败
if ($_SERVER['REQUEST_METHOD'] !== 'POST') {
    http_response_code(405);
    exit('Method not allowed');
}
$user_id = $_SESSION['uid'] ?? 0;
if (!$user_id) {
    http_response_code(401);
    exit('Unauthorized');
}

$allowed_keys = ['playback_rate', 'default_source', 'last_chapter_id', 'auto_resume'];
$preference = [];
foreach ($_POST as $k => $v) {
    if (in_array($k, $allowed_keys)) {
        $preference[$k] = is_scalar($v) ? trim((string)$v) : null;
    }
}

$json = json_encode($preference, JSON_UNESCAPED_UNICODE);
// 执行 INSERT ON DUPLICATE KEY UPDATE 或 REPLACE INTO
$stmt = $pdo->prepare("INSERT INTO user_settings (user_id, preferences, updated_at) VALUES (?, ?, NOW()) ON DUPLICATE KEY UPDATE preferences = VALUES(preferences), updated_at = NOW()");
$stmt->execute([$user_id, $json]);

PHP 如何在响应听书插件请求时返回对应偏好

插件初始化时会请求用户当前偏好(如 /api/get_preference.php),PHP 需读取并输出合法 JSON,且设置正确 Header。

Notion Sites
Notion Sites

Notion 推出的AI网站构建工具,允许用户将 Notion 页面直接发布为完整网站。

下载
  • 务必设置 Content-Type: application/json; charset=utf-8,否则前端 JSON.parse() 可能因 BOM 或编码错乱失败
  • 空偏好不能返回 null 或空字符串,应返回标准空对象 {}
  • 敏感字段(如设备指纹、token)绝不可从 user_preferences 字段中透出
  • 若偏好含时间戳类字段(如 last_played_at),PHP 应统一转为秒级 Unix 时间戳,避免前端解析差异
header('Content-Type: application/json; charset=utf-8');
$user_id = $_SESSION['uid'] ?? 0;
if (!$user_id) {
    echo json_encode([], JSON_UNESCAPED_UNICODE);
    exit;
}

$stmt = $pdo->prepare("SELECT preferences FROM user_settings WHERE user_id = ?");
$stmt->execute([$user_id]);
$row = $stmt->fetch(PDO::FETCH_ASSOC);

echo json_encode($row['preferences'] ?? [], JSON_UNESCAPED_UNICODE);

常见踩坑:前端传参格式与 PHP 解析不一致

听书插件常使用 FormDataapplication/json 提交,但 PHP 默认只解析 application/x-www-form-urlencodedmultipart/form-data$_POST。若前端用 fetch('/save', {method:'POST', body:JSON.stringify(...)}),PHP 不会自动填充 $_POST

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

  • 前端发 JSON 时,PHP 需手动读取 php://inputjson_decode(file_get_contents('php://input'), true)
  • 若插件同时支持多种提交方式(如表单 + JSON),建议统一入口:先判断 $_SERVER['CONTENT_TYPE'] 是否含 application/json,再分支解析
  • playback_rate 值为 "1.25" 字符串时,PHP 存库前应 (float) 强转,避免后续比较出错(如 "1.25" > "1.5" 字符串比较结果为 true)
  • MySQL 中若用 JSON 类型字段(5.7+),注意 PHP json_encode() 输出的 JSON 必须严格合法,否则 JSON_VALID() 校验失败

真正难的不是存和取,而是「偏好」在多端(Web / App / 小程序)间的一致性同步。PHP 层没有状态,它只忠实地按约定读写;一旦前端漏传、缓存未更新、或用户登出后偏好未清理,整个链路就会断裂。别迷信“绑定”这个词——你绑定的只是数据库里一行记录,而用户的实际体验,取决于每一处读写是否都严守这个契约。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

493

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

666

2023.08.14

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 846人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号