为了服务器安全考虑很多主机商禁用了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.首先找到使用fsockopen函数的代码段,将上面代码加至其上端,搜索该代码段中的字符串 fsockopen 替换为 b_fsockopen。 2.因为fsockopen函数返回文件指针所以可以被文件函数操作,但是这个b_fsockopen函数没能返回文件指针,需要继续修改代码段:用socket_read替换掉fread,用socket_write替换掉fwrite,用socket_close替换掉fclose。 解决方案二:fsockopen大多数应用是的获取远程页面数据,对于获取远程页面这种应用,PHP还有其他函数可以完美替代,方法1:
方法2: (责任编辑:admin) |