PHP无法直接监听浏览器视频播放事件,因它仅运行于服务端且请求结束后即释放资源;必须由前端JavaScript捕获play等事件,再通过AJAX将数据发送至PHP接口处理。
PHP 本身不能直接监听或控制浏览器端的视频播放行为(比如“用户点播放了”“播到第30秒了”),它只是服务端脚本语言,不运行在用户浏览器里。所谓“视频播放提醒”,实际必须由前端 JavaScript 触发事件,再通过 AJAX 或表单提交把信息传给 PHP 处理。
PHP 在请求结束时就释放资源,无法持续感知客户端状态。video 元素的 play、timeupdate、ended 等事件只在浏览器 DOM 中触发,PHP 完全收不到,除非你主动发请求过去。
$_POST['is_playing'] 就以为能拿到播放状态 —— 实际永远为空 → 用户点击播放 → JS 捕获 play 事件 → 调用 fetch() 或 XMLHttpRequest 发请求到 PHP 接口timeupdate 里高频发请求(比如每100ms一次),容易打爆后端;改用节流(throttle)或只上报关键节点(如开始、暂停、完成)只需要一个接收 POST 请求的 PHP 文件,校验来源、记录日志或更新数据库即可。重点不是功能多,而是能稳定接收前端发来的数据。
$_SERVER['REQUEST_METHOD'] === 'POST',防止 GET 误触HTTP_REFERER 或加简单 token(如前端带 data-token="abc123",PHP 核对),避免被恶意刷接口$_POST 默认解析 —— 前端常发 JSON,得用 json_decode(file_get_contents('php://input'), true)
user_id(如有登录)、video_id、event_type(如 "play" / "pause" / "complete")、timestamp
'Method not allowed']);
exit;
}
$data = json_decode(file_get_contents('php://input'), true);
if (!$data || !isset($data['event_type']) || !isset($data['video_id'])) {
http_response_code(400);
echo json_encode(['error' => 'Missing required fields']);
exit;
}
// 示例:写入 SQLite(换成 MySQL 或 PDO 更稳妥)
$db = new PDO('sqlite:/path/to/log.db');
$stmt = $db->prepare('INSERT INTO video_events (video_id, event_type, timestamp) VALUES (?, ?, ?)');
$stmt->execute([$data['video_id'], $data['event_type'], date('Y-m-d H:i:s')]);
echo json_encode(['status' => 'ok']);
?>
核心是绑定 video 元素事件,并用 fe 发送轻量请求。别用 jQuery.ajax —— 现代项目基本不需要,原生 
fetch 更可控。
play 事件比监听 click 更准确:用户可能用空格键、快捷键、自动播放等触发autoplay)受浏览器策略限制,多数情况需用户手势后才生效,所以 play 事件仍是最可靠入口data-notified="true" 标记,发过就跳过(适合只关心“首次播放”)new Image().src = '/log.php?e=play&v=123'(GET 方式更容错,但有长度和缓存风险)真正难的不是 PHP 写几行接收逻辑,而是前后端约定清楚字段含义、错误重试机制、防刷策略,以及如何在不拖慢视频体验的前提下完成上报 —— 这些细节没处理好,日志就会大量丢失或污染。