绝大多数情况下,PHP报“Parse error: syntax error, unexpected”是因{、(、[或引号未闭合,需用括号高亮匹配定位,或从末尾逐段注释排查;非语法错误如file_get_contents()失败、json_decode()返回null、preg_match()分隔符冲突等需分别验证配置、JSON有效性、HTTP响应内容及正则写法。
Parse error: syntax error, unexpected 怎么快速定位?绝大多数情况下,这不是短链接逻辑出错,而是 PHP 语法本身没写完——最常见的是 {、(、[ 或字符串引号没闭合。PHP 解析器在报错行附近往往已失焦,真正问题可能在前面几十行。
{ 上看是否标出对应 }
if、foreach、function 块),直到错误消失,再回溯最后被注释的那块),导致后续所有括号层级错位file_get_contents() 却提示 failed to open stream
这和括号无关,是运行时错误,但新手常误以为是语法问题。根本原因是 PHP 默认禁用远程 URL 封装协议(allow_url_fopen=Off),或目标短链服务返回了重定向而 file_get_contents() 不自动跟随。
php -i | grep allow_url_fopen输出应为
On;若为 Off,需改 php.ini 并重启 Web 服务cURL 手动处理重定向:$ch = curl_init($short_url); curl_setopt($ch, CURLOPT_HEADER, true); curl_setopt($ch, CURLOPT_NOBODY, true); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_exec($ch); $redirect_url = curl_getinfo($ch, CURLINFO_EFFECTIVE_URL); curl_close($ch);
User-Agent 或拒绝非浏览器请求,此时需补 curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0')
json_decode() 返回 null 导致后续调用报语法错误?这不是语法错误,但错误信息可能误导你去检查括号——比如你写了 $data = json_decode($res); echo $data->url;,而 $data 是 null,PHP 7+ 会直接报 Fatal error: Uncaught Error: Trying to get property 'url' of non-object,部分旧版环境可能混成解析错误提示。
json_decode() 结果:$data = json_decode($res, true);
if (json_last_error() !== JSON_ERROR_NONE) {
throw new Exception('JSON parse failed: ' . json_last_error_msg());
}var_dump(substr($res, 0, 100)) 先看前 100 字节真实内容json_decode($str, true) 返回数组,json_decode($str) 返回对象——混用 -> 和 ['key'] 会静默失败或报错preg_match() 报 Unknown modifier
这是典型的分隔符未转义导致的语法级报错。正则表达式写在双引号字符串里,又用了未转义的斜杠,PHP 会把它当 preg_match 的分隔符解析,从而破坏整个语句结构。
preg_match("/Location: (.+)/", $headers, $matches); // 如果 $headers 含 "/" 就崩
# 或 ~),并确保内部符号转义:preg_match('#Location:\s+(https?://\S+)#i', $headers, $matches);explode() 拆响应头:$lines = explode("\n", $headers);
foreach ($lines as $line) {
if (stripos($line, 'Location:') === 0) {
$url = trim(substr($line, 9));
break;
}
}