构建一个“简单的” php url 代理
我需要在我正在构建的 Web 应用程序中实现一个简单的 PHP 代理(它基于 Flash,并且目标服务提供商不允许编辑其 crossdomain.xml 文件)
任何 php 专家都可以提供有关以下 2 个选项的建议吗?另外,我认为(但不确定)我还需要包含一些标题信息。
感谢您的任何反馈!
选项1
$url = $_GET['path'];
readfile($path);
选项2
$content .= file_get_contents($_GET['path']);
if ($content !== false)
{
echo($content);
}
else
{
// there was an error
}
I need to implement a simple PHP proxy in a web application I am building (Its flash based and the destination service provider doesn't allow edits to their crossdomain.xml file)
Can any php gurus offer advice on the following 2 options? Also, I think, but am not sure, that I need to include some header info as well.
Thanks for any feedback!
option1
$url = $_GET['path'];
readfile($path);
option2
$content .= file_get_contents($_GET['path']);
if ($content !== false)
{
echo($content);
}
else
{
// there was an error
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
首先,永远不要包含仅基于用户输入的文件。想象一下,如果有人像这样调用您的脚本,会发生什么:
http://example. com/proxy.php?path=/etc/passwd
然后进入问题:你代理什么样的数据?如果有任何类型,那么您需要从内容中检测内容类型,并将其传递,以便接收端知道它正在获取什么。我建议使用类似 HTTP_Request2 或 Pear 类似的东西(参见: http://pear.php.net /package/HTTP_Request2)如果可能的话。如果您有权访问它,那么您可以执行以下操作:
请注意,此代码尚未经过测试,这只是为了给您一个起点。
First of all, never ever ever include a file based only on user input. Imagine what would happen if someone would call your script like this:
http://example.com/proxy.php?path=/etc/passwd
Then onto the issue: what kind of data are you proxying? If any kind at all, then you need to detect the content type from the content, and pass it on so the receiving end knows what it's getting. I would suggest using something like HTTP_Request2 or something similar from Pear (see: http://pear.php.net/package/HTTP_Request2) if at all possible. If you have access to it, then you could do something like this:
Note that this code hasn't been tested, this is just to give you a starting point.
这是使用curl的另一种解决方案
有人可以评论吗??
Here's another solution using curl
Can anyone comment??