為了服務器安全考慮很多主機商禁用了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);
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的功能,參考代碼:
- function b_fsockopen($host, $port, &$errno, &$errstr, $timeout) {
- $ip = gethostbyname($host);
- $s = socket_create(AF_INET, SOCK_STREAM, 0);
- if (socket_set_nonblock($s)) {
- $r = @socket_connect($s, $ip, $port);
- if ($r || socket_last_error() == EINPROGRESS) {
- $errno = EINPROGRESS;
- return $s;
- }
- }
- $errno = socket_last_error($s);
- $errstr = socket_strerror($errno);
- socket_close($s);
- return false;
- }
具體操作:
1.首先找到使用fsockopen函數的代碼段,將上面代碼加至其上端,搜索該代碼段中的字符串 fsockopen 替換為 b_fsockopen。
2.因為fsockopen函數返回文件指針所以可以被文件函數操作,但是這個b_fsockopen函數沒能返回文件指針,需要繼續修改代碼段:用socket_read替換掉fread,用socket_write替換掉fwrite,用socket_close替換掉fclose。
解決方案二:fsockopen大多數應用是的獲取遠程頁面數據,對于獲取遠程頁面這種應用,PHP還有其他函數可以完美替代,方法1:
- <?php
- $str = file("http://www.companysz.com");
- $count = count($str);
- for ($i=0;$i<$count;$i++){
- $file .= $str[$i];
- }
- echo $file;
- ?>
方法2:
- <?php
- $str = file_get_contents("http://www.companysz.com");
- echo $str;
- ?>
新聞熱點
疑難解答