linux – cURL始终使用NTLM返回401

前端之家收集整理的这篇文章主要介绍了linux – cURL始终使用NTLM返回401前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用 PHP与Microsoft Exchange进行通信.我的生产服务器上的一切正常,但我的开发机器上一直有401未经授权.我尝试从命令行使用curl,我得到相同的结果.

使用以下命令在我的机器上返回“401”:

curl https://mail.example.com/EWS/Exchange.asmx -w %{http_code} --ntlm -u username:password

同样的确切调用在我的生产机器上返回“302”,这是我所期望的.

我的开发机器使用curl 7.19.7,我的生产机器使用curl 7.18.0.

解决方法

这是一个老问题,但如果它最终可以帮助任何人,我想我会发布一个答案.

在某些最新版本的Ubuntu上有一个NTLM和curl的错误(我相信10.04及以上版本).

> Ubuntu:https://bugs.launchpad.net/ubuntu/+source/curl/+bug/675974
> CentOS:https://bugzilla.redhat.com/show_bug.cgi?id=799557

如果您在ubuntu上使用PHP的curl模块,并且您的libcurl版本受此错误的影响,这可以解释您的身份验证请求失败的原因.

如果将verbose标志添加到命令(-v),则应在响应部分中看到类似的内容

> gss_init_sec_context()失败::找不到凭据缓存文件’/ tmp / krb5cc_1000′

如果你看到这个,你就会受到bug的影响,你必须降级你的库或找到另一台机器.

我希望这会有所帮助:P

猜你在找的Linux相关文章