PHP无法调用知乎知海图AI接口,因其未开放API、无SDK文档,且请求需动态签名、严格鉴权;推荐改用通义千问、DeepSeek或本地Ollama等可集成方案。

Cookie、X-Zse-96、X-Zse-93 等加密 header,向 https://www.zhihu.com/api/v4/ai/knowledge_graph(或类似路径)发起的受控请求——这些签名逻辑未公开,且会动态更新。
为什么 PHP cURL 模拟会失败
即使你抓包拿到一次请求,用 PHP 的 cURL 复现,大概率返回:401 Unauthorized 或 {"error":"invalid_token"},原因包括:
-
X-Zse-96是基于时间戳、设备指纹、请求体等生成的动态签名,PHP 无对应逆向实现 - 知乎后端校验 Referer、User-Agent、Cookie 中的
z_c0和_xsrf,且z_c0有效期短、绑定 IP 和 UA - 高频请求触发人机验证(如滑块),PHP 无法自动过验
- 接口路径、参数名(如
queryvsquestion)在不同版本中频繁变更
有没有绕过方式?不推荐,且风险极高
网上流传的「PHP 调知海图 AI」代码,基本属于以下三类:
- 伪造 header 的无效请求(返回错误或空响应)
- 依赖已失效的旧版 token(几天内即被封禁)
- 调用非知乎的同名模型(实为其他公司私有部署的 LLM,与知海图无关)
试图用 file_get_contents()、curl_setopt() 硬刷,不仅得不到答案,还可能导致你的知乎账号被限流或封禁。
如果你真需要知识推理能力,可替代的务实方案
换用有明确 PHP 支持、开放 API 的模型服务:
立即学习“PHP免费学习笔记(深入)”;
- 通义千问:阿里云 DashScope 提供
dashscope.TextGeneration.call(),PHP SDK 官方维护,支持model="qwen-max" - DeepSeek:提供标准 OpenAI 兼容接口,可用
curl -X POST "https://api.deepseek.com/v1/chat/completions"直接对接 - 本地小模型:用
ollama启动phi3或qwen2:0.5b,PHP 通过http://localhost:11434/api/chat调用,零费用、低延迟
例如用 Ollama + PHP 最简调用:
'qwen2:0.5b',
'messages' => [['role' => 'user', 'content' => 'PHP怎么连接MySQL?']]
]);
$ch = curl_init('http://localhost:11434/api/chat');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Content-Type: application/json']);
$response = curl_exec($ch);
curl_close($ch);
echo json_decode($response)->message->content;
?>
知乎知海图 AI 当前不具备 PHP 可集成性。所谓「传文本得答案」只是终端用户界面表现,背后没有开放通道。别在签名逆向或 cookie 复用上浪费时间——那不是开发,是撞墙。











