我正在嘗試使用 PHP SoapClient 來執(zhí)行對第三方應(yīng)用程序的請求。當(dāng)我創(chuàng)建 SoapClient 對象時,我收到有關(guān) WSDL 數(shù)據(jù)過早結(jié)束的錯誤。在嘗試診斷錯誤時,我發(fā)現(xiàn) WSDL URI 的 file_get_contents() 沒有返回整個 XML。事實上,它經(jīng)常返回不同數(shù)量的 WSDL。這是我的測試程序:$xml = file_get_contents('https://webservices3.autotask.net/atservices/1.6/atws.wsdl');echo $xml . "\n";echo strlen($xml). "\n";我每次得到大約 57k 字節(jié)(195628 是正確的值),有時更多而且很少我得到整個 XML。我認為這是一個 PHP 問題,因為為該 URI 每次調(diào)用 curl 或 wget 100 次的 shell 循環(huán)將在 100% 的時間內(nèi)返回整個文件。我使用的是 PHP 5.4.16,我知道它很舊(2013 年),但是這個過程工作了大約一個月,然后就完全停止了。我試過更改超時、HTTP 協(xié)議版本、PHP 內(nèi)存設(shè)置,但我不明白為什么 file_get_contents 會這樣。任何建議表示贊賞。卷曲測試:for a in $( seq 1 100 ); do curl -o wsdl.$a https://webservices3.autotask.net/atservices/1.6/atws.wsdl; done測試:for a in $( seq 1 100 ); do wget -O wsdl.$a https://webservices3.autotask.net/atservices/1.6/atws.wsdl; done更新 1:將 maxlen 設(shè)置為一些愚蠢的大數(shù)不會影響行為:$xml = file_get_contents('https://webservices3.autotask.net/atservices/1.6/atws.wsdl', false, null, 0, 999999);echo $xml . "\n";echo strlen($xml). "\n";更新 2:$ curl -s -D /dev/stderr -- https://webservices3.autotask.net/atservices/1.6/atws.wsdl > /dev/nullHTTP/1.1 200 OKContent-Type: text/xmlLast-Modified: Wed, 29 Apr 2020 14:38:25 GMTAccept-Ranges: bytesETag: "39163cd7331ed61:0"Server: Microsoft-IIS/8.5X-Powered-By: ASP.NETContent-Security-Policy: default-src 'self' https: *;script-src 'self' 'unsafe-inline' 'unsafe-eval' https: *;style-src 'self' 'unsafe-inline';img-src 'self' https://walkme.psa.datto.com/Images/ data: https://www.datto.com/img/Date: Fri, 08 May 2020 15:22:28 GMTContent-Length: 195628
2 回答

胡說叔叔
TA貢獻1804條經(jīng)驗 獲得超8個贊
webservices3.autotask.net 的響應(yīng)標頭錯誤
HTTP/1.1 200 OK
Content-Type: text/xml
Accept-Ranges: bytes
Server: Microsoft-IIS/8.5
X-Powered-By: ASP.NET
Cteonnt-Length: 195628
Cache-Control: private
Content-Encoding: gzip
Transfer-Encoding: chunked
注意:Cteonnt-Length: 195628應(yīng)該是Content-Length: 195628
那為什么file_get_contents不能正確處理請求。
所以,修復(fù)響應(yīng)或設(shè)置maxlen
- 2 回答
- 0 關(guān)注
- 278 瀏覽
添加回答
舉報
0/150
提交
取消