如何修复PHP发送FCM推送通知时出现的HTTP ERROR 500问题
解决FCM推送在线服务器HTTP 500错误(本地正常运行)
兄弟,我之前也踩过一模一样的坑——本地Appserv跑FCM推送顺得不行,一部署到线上服务器就直接500报错,头都挠秃了!结合你的代码片段和场景,给你梳理几个最可能的原因和解决办法:
1. 先检查代码语法错误
你贴的代码里写了curl_seto...,这大概率是curl_setopt的笔误!线上服务器一般开启了严格的错误检测,这种低级语法错误直接就触发500了。补全正确的curl配置代码试试:
function send_notification ($tokens, $message) { $url = 'https://fcm.googleapis.com/fcm/send'; $fields = array( 'registration_ids' => $tokens, 'data' => $message ); $headers = array( 'Authorization: key=你的FCM服务器密钥', // 注意这里不要加多余空格 'Content-Type: application/json' ); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); // 临时关闭SSL验证(长期建议配置CA证书) curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($fields)); $result = curl_exec($ch); if ($result === FALSE) { die('Curl请求失败: ' . curl_error($ch)); } curl_close($ch); return $result; }
另外注意Authorization头的格式:key=和密钥之间不要加空格,之前我就是因为多了个空格踩了坑!
2. 排查线上服务器环境问题
- Curl扩展未启用:很多虚拟主机默认没开curl扩展,你可以上传一个
phpinfo.php(内容<?php phpinfo(); ?>),访问后搜索“curl”确认模块是否存在。如果没有,联系主机商开启,或者自己在php.ini里添加extension=curl(独立服务器适用)。 - SSL证书验证失败:本地环境可能默认忽略了SSL验证,但线上服务器会严格校验。如果不想配置CA证书,可以临时加
CURLOPT_SSL_VERIFYPEER, false(上面代码已经加了),长期建议下载官方CA证书配置。 - 网络权限限制:部分主机商会限制出站请求,确认服务器是否允许访问
fcm.googleapis.com的443端口。可以用telnet fcm.googleapis.com 443测试连通性(独立服务器),或者联系主机商确认。 - 临时目录权限不足:curl需要写入临时文件,如果PHP执行用户没有权限操作服务器临时目录,也会触发500。可以检查服务器临时目录(比如
/tmp)的权限,或者在代码里指定CURLOPT_CAINFO指向证书文件。
3. 查看服务器错误日志定位根源
HTTP 500是通用错误,最直接的办法是看服务器的错误日志:
- Apache服务器:日志一般在
/var/log/apache2/error.log - Nginx服务器:日志一般在
/var/log/nginx/error.log - 虚拟主机:后台通常有“错误日志”入口,进去能看到具体的错误信息(比如语法错误、扩展缺失、权限问题),比瞎猜高效多了!
内容的提问来源于stack exchange,提问作者Akkarin Huaihongthong




