我爱电脑技术论坛's Archiver

bbs23 发表于 2008-6-23 18:58

五分钟让 DreamHost 打开 allow_url_fopen 配置选项的最简单方法

DreamHost 默认不打开文件系统和流配置选项 allow_url_fopen ,而是建议使用一个替代的函数模块 cURL。下面以一个例子说明用 cURL 远程读取的方法:%s5nv C ~pQ0U
  第一,allow_url_fopen = On 的情况下:
$Z9c`*h ]@| <?php9~k5L} Q'x,mC;?
$str = file_get_contents("http://www.hosteguide.com/");8j5S)d8O N:I_Io
if ($str !== false) {
S]A8EZF l8w"i-D   // do something with the content
lY1KqT3m~   echo $str;
,uoH_~ }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!IQK
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
j-H6to~A0^x curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);Hi+kgr.V W
$str = curl_exec($ch);E7Uo%pA!{du
if ($str !== false) {
YV0{#~7Jq&a   // do something with the content&D2A.P.G(x
  echo $str; W;WlJK4hwA
}8sud?)J-| @_V
curl_close($ch);
OCl7d$h!oT ?> dF0}"Nl/\
  但是很多现成的 PHP 采集器是使用依赖于 allow_url_fopen 选项的函数,当初遇到这个问题时,我搜索了一下,大概有2个解决办法,但是都不方便。一个是编译自己的 PHP,该方法是一切从头开始,怎么定义 PHP 都随你,可是费时费力费空间,当初,我还真的尝试了一下,像 Zend Optimizer 等等,也要自己安装,如果,只是为了使用这一个函数,根本没必要这么折腾;另一个方法是上传什么 php-update.sh 脚本文件,也是比较麻烦的。
!L9WZ"aD$P5TSg   后来发现,其实只要定制 php.ini 文件,并让系统知道本网站使用定制的 php.ini 即可,先来说说标准的方法,这需要对 lunix 有一点了解,之后再给出一个更容易的方法,标准的方法如下:
)~x N7d-]5@&DS   1)用 ssh 方式登录到你的网站,找到以你的网站名命名的目录,例如 hosteguide.com,在它下面用 mkdir 命令创建一个子目录 cgi-bin;
I1W`%y)T0vI'B!M   2)把默认的 php.cgi 和 php.ini 文件放到 cgi-bin 目录下,可以从 DreamHost 的系统目录中拷贝,以我的网站为例:i*v:jt!^(@%w
    cp /dh/cgi-system/php5.cgi  hosteguide.com/cgi-bin/php.cgi
I ]m!T&Uzx{;X3b     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 文件;$X F5Ci1^]
  3)编辑 php.ini 文件,把 allow_url_fopen = Off 改为 allow_url_fopen = On 并保存; ?*XC8\V l$qg
  4)在域名同名的目录下创建(如果已经存在就修改).htaccess 文件,例如 hosteguide.com/.htaccess 文件,在文件中添加
Eb%rZf;ne     AddHandler  php-cgi  .php V I uG n9z y
    Action  php-cgi  /cgi-bin/php.cgi
rv([&L(?H8z   5)修改文件的访问权限,例如:;nB W!HiBL
chmod 644 hosteguide.com/.htaccessw;H;^.}p?.n
chmod 755 hosteguide.com/cgi-bin
&]KCG B0q chmod 750 hosteguide.com/cgi-bin/php.cgi
7nf&?"SD3`:X$C!qV chmod 644 hosteguide.com/cgi-bin/php.inip?T R\ElU
  现在就可以正常使用依赖于 allow_url_fopen 选项的函数,或者 PHP 的采集器。

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.