123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- <?php
- /**
- * [Discuz!] (C)2001-2099 Comsenz Inc.
- * This is NOT a freeware, use is subject to license terms
- *
- * $Id: function_filesock.php 36279 2016-12-09 07:54:31Z nemohou $
- */
- if(!defined('IN_DISCUZ')) {
- exit('Access Denied');
- }
- function _dfsockopen($url, $limit = 0, $post = '', $cookie = '', $bysocket = FALSE, $ip = '', $timeout = 15, $block = TRUE, $encodetype = 'URLENCODE', $allowcurl = TRUE, $position = 0, $files = array()) {
- $return = '';
- $matches = parse_url($url);
- $scheme = $matches['scheme'];
- $host = $matches['host'];
- $path = $matches['path'] ? $matches['path'].($matches['query'] ? '?'.$matches['query'] : '') : '/';
- $port = !empty($matches['port']) ? $matches['port'] : ($scheme == 'http' ? '80' : '');
- $boundary = $encodetype == 'URLENCODE' ? '' : random(40);
- if($post) {
- if(!is_array($post)) {
- parse_str($post, $post);
- }
- _format_postkey($post, $postnew);
- $post = $postnew;
- }
- if(function_exists('curl_init') && function_exists('curl_exec') && $allowcurl) {
- $ch = curl_init();
- $httpheader = array();
- if($ip) {
- $httpheader[] = "Host: ".$host;
- }
- if($httpheader) {
- curl_setopt($ch, CURLOPT_HTTPHEADER, $httpheader);
- }
- curl_setopt($ch, CURLOPT_URL, $scheme.'://'.($ip ? $ip : $host).($port ? ':'.$port : '').$path);
- curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
- curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
- curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
- curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
- curl_setopt($ch, CURLOPT_HEADER, 1);
- if($post) {
- curl_setopt($ch, CURLOPT_POST, 1);
- if($encodetype == 'URLENCODE') {
- curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
- } else {
- foreach($post as $k => $v) {
- if(isset($files[$k])) {
- $post[$k] = '@'.$files[$k];
- }
- }
- foreach($files as $k => $file) {
- if(!isset($post[$k]) && file_exists($file)) {
- $post[$k] = '@'.$file;
- }
- }
- curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
- }
- }
- if($cookie) {
- curl_setopt($ch, CURLOPT_COOKIE, $cookie);
- }
- curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
- curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);
- $data = curl_exec($ch);
- $status = curl_getinfo($ch);
- $errno = curl_errno($ch);
- curl_close($ch);
- if($errno || $status['http_code'] != 200) {
- return;
- } else {
- $GLOBALS['filesockheader'] = substr($data, 0, $status['header_size']);
- $data = substr($data, $status['header_size']);
- return !$limit ? $data : substr($data, 0, $limit);
- }
- }
- if($post) {
- if($encodetype == 'URLENCODE') {
- $data = http_build_query($post);
- } else {
- $data = '';
- foreach($post as $k => $v) {
- $data .= "--$boundary\r\n";
- $data .= 'Content-Disposition: form-data; name="'.$k.'"'.(isset($files[$k]) ? '; filename="'.basename($files[$k]).'"; Content-Type: application/octet-stream' : '')."\r\n\r\n";
- $data .= $v."\r\n";
- }
- foreach($files as $k => $file) {
- if(!isset($post[$k]) && file_exists($file)) {
- if($fp = @fopen($file, 'r')) {
- $v = fread($fp, filesize($file));
- fclose($fp);
- $data .= "--$boundary\r\n";
- $data .= 'Content-Disposition: form-data; name="'.$k.'"; filename="'.basename($file).'"; Content-Type: application/octet-stream'."\r\n\r\n";
- $data .= $v."\r\n";
- }
- }
- }
- $data .= "--$boundary\r\n";
- }
- $out = "POST $path HTTP/1.0\r\n";
- $header = "Accept: */*\r\n";
- $header .= "Accept-Language: zh-cn\r\n";
- $header .= $encodetype == 'URLENCODE' ? "Content-Type: application/x-www-form-urlencoded\r\n" : "Content-Type: multipart/form-data; boundary=$boundary\r\n";
- $header .= 'Content-Length: '.strlen($data)."\r\n";
- $header .= "User-Agent: $_SERVER[HTTP_USER_AGENT]\r\n";
- $header .= "Host: $host:$port\r\n";
- $header .= "Connection: Close\r\n";
- $header .= "Cache-Control: no-cache\r\n";
- $header .= "Cookie: $cookie\r\n\r\n";
- $out .= $header;
- $out .= $data;
- } else {
- $out = "GET $path HTTP/1.0\r\n";
- $header = "Accept: */*\r\n";
- $header .= "Accept-Language: zh-cn\r\n";
- $header .= "User-Agent: $_SERVER[HTTP_USER_AGENT]\r\n";
- $header .= "Host: $host:$port\r\n";
- $header .= "Connection: Close\r\n";
- $header .= "Cookie: $cookie\r\n\r\n";
- $out .= $header;
- }
- $fpflag = 0;
- if(!$fp = @fsocketopen(($ip ? $ip : $host), $port, $errno, $errstr, $timeout)) {
- $context = array(
- 'http' => array(
- 'method' => $post ? 'POST' : 'GET',
- 'header' => $header,
- 'content' => $post,
- 'timeout' => $timeout,
- ),
- );
- $context = stream_context_create($context);
- $fp = @fopen($scheme.'://'.($ip ? $ip : $host).':'.$port.$path, 'b', false, $context);
- $fpflag = 1;
- }
- if(!$fp) {
- return '';
- } else {
- stream_set_blocking($fp, $block);
- stream_set_timeout($fp, $timeout);
- @fwrite($fp, $out);
- $status = stream_get_meta_data($fp);
- if(!$status['timed_out']) {
- while (!feof($fp) && !$fpflag) {
- $header = @fgets($fp);
- $headers .= $header;
- if($header && ($header == "\r\n" || $header == "\n")) {
- break;
- }
- }
- $GLOBALS['filesockheader'] = $headers;
- if($position) {
- for($i=0; $i<$position; $i++) {
- $char = fgetc($fp);
- if($char == "\n" && $oldchar != "\r") {
- $i++;
- }
- $oldchar = $char;
- }
- }
- if($limit) {
- $return = stream_get_contents($fp, $limit);
- } else {
- $return = stream_get_contents($fp);
- }
- }
- @fclose($fp);
- return $return;
- }
- }
- function _format_postkey($post, &$result, $key = '') {
- foreach($post as $k => $v) {
- $_k = $key ? $key.'['.$k.']' : $k;
- if(is_array($v)) {
- _format_postkey($v, $result, $_k);
- } else {
- $result[$_k] = $v;
- }
- }
- }
- ?>
|