用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

空间不支持fsockopen函数解决办法

时间:2015-01-23  来源:西部数据  作者:西部数据

为了服务器安全考虑很多主机商禁用了php的fsockopen函数,昨天进博客,使用cos-html-cache生成静态文件,尼玛提示:Warning: fsockopen() has been disabled for security reasons in D:...cos-html-cachecos-html-cache.php on line 35

换了其他版本的cos-html-cache,还是不行。后来找到下面的方法。 = =、(结果不行,因为函数都被禁用了。)大家试下,很少有我这样的情况的,用其他替代函数。

一、如何禁用fsockopen()下面是两种常用的禁用fsockopen的方法。

1、修改php.ini,将disable_functions=后加入fsockopen   

2、修改php.ini,将allow_url_fopen = On 改为 allow_url_fopen = Off  

二、如何解决fsockopen函数被禁用

1、如果服务器没有同时禁用pfsockopen,那么直接将fsockopen函数替换为pfsockopen,具体操作:搜索程序中的字符串fsockopen 替换为pfsockopen示例如下:

修改前:$fp = fsockopen($host, 80, $errno, $errstr, 30);

修改后:$fp = pfsockopen($host, 80, $errno, $errstr, 30);

2、如果服务器同时禁用了pfsockopen,那么用其他函数代替,如stream_socket_client()。注意:stream_socket_client()和fsockopen()的参数不同。

具体操作:搜索程序中的字符串  fsockopen(   替换为  stream_socket_client(   ,然后,将原fsockopen函数中的端口参数“80”删掉,并加到$host。示例如下

修改前:$fp = fsockopen($host, 80, $errno, $errstr, 30);

修改后:$fp = stream_socket_client($host."80", $errno, $errstr, 30);

3、如果PHP版本低于5.0,fsockopen被禁用,又没有stream_socket_client()怎么办呢?自己写一个函数实现fsockopen的功能,参考代码:

  1. function b_fsockopen($host$port, &$errno, &$errstr$timeout) { 
  2.  $ip = gethostbyname($host); 
  3.  $s = socket_create(AF_INET, SOCK_STREAM, 0); 
  4.  if (socket_set_nonblock($s)) { 
  5.   $r = @socket_connect($s$ip$port); 
  6.   if ($r || socket_last_error() == EINPROGRESS) { 
  7.    $errno = EINPROGRESS; 
  8.    return $s
  9.   } 
  10.  } 
  11.  $errno = socket_last_error($s); 
  12.  $errstr = socket_strerror($errno); 
  13.  socket_close($s); 
  14.  return false; 

具体操作:

1.首先找到使用fsockopen函数的代码段,将上面代码加至其上端,搜索该代码段中的字符串  fsockopen 替换为 b_fsockopen。

2.因为fsockopen函数返回文件指针所以可以被文件函数操作,但是这个b_fsockopen函数没能返回文件指针,需要继续修改代码段:用socket_read替换掉fread,用socket_write替换掉fwrite,用socket_close替换掉fclose。

解决方案二:fsockopen大多数应用是的获取远程页面数据,对于获取远程页面这种应用,PHP还有其他函数可以完美替代,方法1:

  1. <?php 
  2. $str = file("http://www.phpfensi.com"); 
  3. $count = count($str); 
  4. for ($i=0;$i<$count;$i++){ 
  5.      $file .= $str[$i]; 
  6.      } 
  7. echo $file
  8. ?> 

方法2:

  1. <?php 
  2. $str = file_get_contents("http://www.phpfensi.com"); 
  3. echo $str
  4. ?> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门