五分钟让 DreamHost 打开 allow_url_fopen 配置选项的最简单方法
DreamHost 默认不打开文件系统和流配置选项 allow_url_fopen ,而是建议使用一个替代的函数模块 cURL。下面以一个例子说明用 cURL 远程读取的方法:%s5nv C ~pQ0U第一,allow_url_fopen = On 的情况下:
<?php9~k5L}Q'x,mC;?
$str = file_get_contents("http://www.hosteguide.com/");8j5S)d8O N:I_Io
if ($str !== false) {
// do something with the content
echo $str;
}0D+p(KcD_
?>g2L_8aJ4n
第二,allow_url_fopen = Off 的情况下:0g8^+LqT4]H$r e"o
<?phpD$m,^D(V
$ch = curl_init("http://www.hosteguide.com/");Ix5u!I QK
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);Hi+kgr.V W
$str = curl_exec($ch);E7Uo%pA!{du
if ($str !== false) {
// do something with the content&D2A.P.G(x
echo $str; W;WlJK4hwA
}8sud?)J-| @_V
curl_close($ch);
?> dF0}"Nl/\
但是很多现成的 PHP 采集器是使用依赖于 allow_url_fopen 选项的函数,当初遇到这个问题时,我搜索了一下,大概有2个解决办法,但是都不方便。一个是编译自己的 PHP,该方法是一切从头开始,怎么定义 PHP 都随你,可是费时费力费空间,当初,我还真的尝试了一下,像 Zend Optimizer 等等,也要自己安装,如果,只是为了使用这一个函数,根本没必要这么折腾;另一个方法是上传什么 php-update.sh 脚本文件,也是比较麻烦的。
后来发现,其实只要定制 php.ini 文件,并让系统知道本网站使用定制的 php.ini 即可,先来说说标准的方法,这需要对 lunix 有一点了解,之后再给出一个更容易的方法,标准的方法如下:
1)用 ssh 方式登录到你的网站,找到以你的网站名命名的目录,例如 hosteguide.com,在它下面用 mkdir 命令创建一个子目录 cgi-bin;
2)把默认的 php.cgi 和 php.ini 文件放到 cgi-bin 目录下,可以从 DreamHost 的系统目录中拷贝,以我的网站为例:i*v:jt!^(@%w
cp /dh/cgi-system/php5.cgi hosteguide.com/cgi-bin/php.cgi
cp /etc/php5/cgi/php.ini hosteguide.com/cgi-bin/php.inioQl)P;Ni
现在的网站是 php5 的,我也是建议使用这个版本。如果,你使用的是 php4,则要从 /dh/cgi-system/php.cgi 和 /etc/php/cgi/php.ini 分别获取 DreamHost 的默认 php.cig 和 php.ini 文件;$XF5Ci1^ ]
3)编辑 php.ini 文件,把 allow_url_fopen = Off 改为 allow_url_fopen = On 并保存; ?*XC8\V l$qg
4)在域名同名的目录下创建(如果已经存在就修改).htaccess 文件,例如 hosteguide.com/.htaccess 文件,在文件中添加
AddHandler php-cgi .php VI uG n9zy
Action php-cgi /cgi-bin/php.cgi
5)修改文件的访问权限,例如:;nBW!HiBL
chmod 644 hosteguide.com/.htaccessw;H;^.}p?.n
chmod 755 hosteguide.com/cgi-bin
chmod 750 hosteguide.com/cgi-bin/php.cgi
chmod 644 hosteguide.com/cgi-bin/php.inip?T R\ElU
现在就可以正常使用依赖于 allow_url_fopen 选项的函数,或者 PHP 的采集器。
页:
[1]