Home > Backend Development > PHP Tutorial > 关于file_get_contents获取借口403

关于file_get_contents获取借口403

WBOY
Release: 2016-06-06 20:39:37
Original
1918 people have browsed it

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

<code>curl -L "api location"  -----> 正确返回数据(预期)
curl "api location"     -----> 返回空(预期)
curl -I "api location"  ------> 头提示302(预期)
</code>
Copy after login
Copy after login

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

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

php cli方式

<code>var_dump(file_get_contents('api loaction'))-->返回空(非预期)
</code>
Copy after login
Copy after login

最后参考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>
Copy after login
Copy after login

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>
Copy after login
Copy after login

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

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

php cli方式

<code>var_dump(file_get_contents('api loaction'))-->返回空(非预期)
</code>
Copy after login
Copy after login

最后参考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>
Copy after login
Copy after login

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>
Copy after login
Related labels:
php
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template