Heim > Backend-Entwicklung > PHP-Tutorial > 关于file_get_contents获取借口403

关于file_get_contents获取借口403

WBOY
Freigeben: 2016-06-06 20:39:37
Original
1886 Leute haben es durchsucht

RT.
有一个接口,本身是302过的

<code>curl -L "api location"  -----> 正确返回数据(预期)
curl "api location"     -----> 返回空(预期)
curl -I "api location"  ------> 头提示302(预期)
</code>
Nach dem Login kopieren
Nach dem Login kopieren

如此上面的结论看出,接口是按照预期的想法输出的

由于项目架构的调整,所以才有上面302的产生,但是

php cli方式

<code>var_dump(file_get_contents('api loaction'))-->返回空(非预期)
</code>
Nach dem Login kopieren
Nach dem Login kopieren

最后参考stackoverflow:

stackoverflow 1

stackoverflow 2

<code>ini_set('user_agent','Mozilla/4.0 (compatible; MSIE 6.0)'); 
var_dump(file_get_contents('api loaction'))-->返回预期数据(预期)
</code>
Nach dem Login kopieren
Nach dem Login kopieren

stackoverflow上的解释:

This is not a problem with your script, but with the resource you are requesting. The web server is returning the "forbidden" status code.

It could be that it blocks PHP scripts to prevent scraping, or your IP if you have made too many requests.

You should probably talk to the administrator of the remote server.

最后问题来了:

既然server端做了处理,那么curl和file_get_contents 是怎么的差异导致结果不一样?

回复内容:

RT.
有一个接口,本身是302过的

<code>curl -L "api location"  -----> 正确返回数据(预期)
curl "api location"     -----> 返回空(预期)
curl -I "api location"  ------> 头提示302(预期)
</code>
Nach dem Login kopieren
Nach dem Login kopieren

如此上面的结论看出,接口是按照预期的想法输出的

由于项目架构的调整,所以才有上面302的产生,但是

php cli方式

<code>var_dump(file_get_contents('api loaction'))-->返回空(非预期)
</code>
Nach dem Login kopieren
Nach dem Login kopieren

最后参考stackoverflow:

stackoverflow 1

stackoverflow 2

<code>ini_set('user_agent','Mozilla/4.0 (compatible; MSIE 6.0)'); 
var_dump(file_get_contents('api loaction'))-->返回预期数据(预期)
</code>
Nach dem Login kopieren
Nach dem Login kopieren

stackoverflow上的解释:

This is not a problem with your script, but with the resource you are requesting. The web server is returning the "forbidden" status code.

It could be that it blocks PHP scripts to prevent scraping, or your IP if you have made too many requests.

You should probably talk to the administrator of the remote server.

最后问题来了:

既然server端做了处理,那么curl和file_get_contents 是怎么的差异导致结果不一样?

这里是不是没说清楚?OP这里 file_get_contents 的时候也是返回403吗?

如果仅仅是按照下面改UA来说,似乎只是这里影响了。

curlfile_get_contents 的差异,如果不看源代码的比较方法,应该是使用 tcpdump 等命令去抓一下发出去的请求内容,再做比较。

<code># tcpdump -i eth0 -A -n -v port ...
</code>
Nach dem Login kopieren
Verwandte Etiketten:
php
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage