亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > PHP > 正文

PHP反向代理類代碼

2024-05-04 23:24:52
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了PHP反向代理類代碼,需要的朋友可以參考下
 
 

改自PHP Reverse Proxy PRP,修改了原版中的一些錯誤,支持了文件上傳以及上傳文件類型識別,支持指定IP,自適應SAE環境。

使用方法

<?php$proxy=new PhpReverseProxy();$proxy->port="8080";$proxy->host="www.49028c.com";//$proxy->ip="1.1.1.1";$proxy->forward_path="";$proxy->connect();$proxy->output();?>

源代碼

<?php//Source Code: http://www.xiumu.org/technology/php-reverse-proxy-class.shtmlclass PhpReverseProxy{ public $publicBaseURL; public $outsideHeaders; public $XRequestedWith; public $sendPost; public $port,$host,$ip,$content,$forward_path,$content_type,$user_agent,  $XFF,$request_method,$IMS,$cacheTime,$cookie,$authorization; private $http_code,$lastModified,$version,$resultHeader; const chunkSize = 10000; function __construct(){  $this->version="PHP Reverse Proxy (PRP) 1.0";  $this->port="8080";  $this->host="127.0.0.1";  $this->ip="";  $this->content="";  $this->forward_path="";  $this->path="";  $this->content_type="";  $this->user_agent="";  $this->http_code="";  $this->XFF="";  $this->request_method="GET";  $this->IMS=false;  $this->cacheTime=72000;  $this->lastModified=gmdate("D, d M Y H:i:s",time()-72000)." GMT";  $this->cookie="";  $this->XRequestedWith = "";  $this->authorization = ""; } function translateURL($serverName) {  $this->path=$this->forward_path.$_SERVER['REQUEST_URI'];  if(IS_SAE)   return $this->translateServer($serverName).$this->path;  if($_SERVER['QUERY_STRING']=="")   return $this->translateServer($serverName).$this->path;  else  return $this->translateServer($serverName).$this->path."?".$_SERVER['QUERY_STRING']; } function translateServer($serverName) {  $s = empty($_SERVER["HTTPS"]) ? ''   : ($_SERVER["HTTPS"] == "on") ? "s"   : "";  $protocol = $this->left(strtolower($_SERVER["SERVER_PROTOCOL"]), "/").$s;  if($this->port=="")    return $protocol."://".$serverName;  else   return $protocol."://".$serverName.":".$this->port; } function left($s1, $s2) {  return substr($s1, 0, strpos($s1, $s2)); } function preConnect(){  $this->user_agent=$_SERVER['HTTP_USER_AGENT'];  $this->request_method=$_SERVER['REQUEST_METHOD'];  $tempCookie="";  foreach ($_COOKIE as $i => $value) {   $tempCookie=$tempCookie." $i=$_COOKIE[$i];";  }  $this->cookie=$tempCookie;  if(empty($_SERVER['HTTP_X_FORWARDED_FOR'])){   $this->XFF=$_SERVER['REMOTE_ADDR'];  } else {   $this->XFF=$_SERVER['HTTP_X_FORWARDED_FOR'].", ".$_SERVER['REMOTE_ADDR'];  }  } function connect(){  if(empty($_SERVER['HTTP_IF_MODIFIED_SINCE'])){   $this->preConnect();   $ch=curl_init();   if($this->request_method=="POST"){    curl_setopt($ch, CURLOPT_POST,1);     $postData = array();    $filePost = false;    $uploadPath = 'uploads/';    if (IS_SAE)      $uploadPath = SAE_TMP_PATH;     if(count($_FILES)>0){      if(!is_writable($uploadPath)){        die('You cannot upload to the specified directory, please CHMOD it to 777.');      }      foreach($_FILES as $key => $fileArray){         copy($fileArray["tmp_name"], $uploadPath . $fileArray["name"]);        $proxyLocation = "@" . $uploadPath . $fileArray["name"] . ";type=" . $fileArray["type"];        $postData = array($key => $proxyLocation);        $filePost = true;      }    }     foreach($_POST as $key => $value){      if(!is_array($value)){     $postData[$key] = $value;      }      else{     $postData[$key] = serialize($value);      }    }     if(!$filePost){      //$postData = http_build_query($postData);      $postString = "";      $firstLoop = true;      foreach($postData as $key => $value){      $parameterItem = urlencode($key)."=".urlencode($value);      if($firstLoop){     $postString .= $parameterItem;      }      else{     $postString .= "&".$parameterItem;      }      $firstLoop = false;       }      $postData = $postString;    }     //echo print_r($postData);     //curl_setopt($ch, CURLOPT_VERBOSE, 0);    //curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);    //curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible;)");    $this->sendPost = $postData;    //var_dump(file_exists(str_replace('@','',$postData['imgfile'])));exit;    curl_setopt($ch, CURLOPT_POSTFIELDS,$postData);    //curl_setopt($ch, CURLOPT_POSTFIELDS,file_get_contents($proxyLocation));    //curl_setopt($ch, CURLOPT_POSTFIELDS,file_get_contents("php://input"));   }    //gets rid of mulitple ? in URL   $translateURL = $this->translateURL(($this->ip)?$this->ip:$this->host);   if(substr_count($translateURL, "?")>1){     $firstPos = strpos($translateURL, "?", 0);     $secondPos = strpos($translateURL, "?", $firstPos + 1);     $translateURL = substr($translateURL, 0, $secondPos);   }    curl_setopt($ch,CURLOPT_URL,$translateURL);    $proxyHeaders = array(     "X-Forwarded-For: ".$this->XFF,     "User-Agent: ".$this->user_agent,     "Host: ".$this->host   );    if(strlen($this->XRequestedWith)>1){     $proxyHeaders[] = "X-Requested-With: ".$this->XRequestedWith;     //echo print_r($proxyHeaders);   }    curl_setopt($ch,CURLOPT_HTTPHEADER, $proxyHeaders);    if($this->cookie!=""){    curl_setopt($ch,CURLOPT_COOKIE,$this->cookie);   }   curl_setopt($ch,CURLOPT_FOLLOWLOCATION,false);    curl_setopt($ch,CURLOPT_AUTOREFERER,true);    curl_setopt($ch,CURLOPT_HEADER,true);   curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);    $output=curl_exec($ch);   $info = curl_getinfo( $ch );   curl_close($ch);   $this->postConnect($info,$output);  }else {   $this->lastModified=$_SERVER['HTTP_IF_MODIFIED_SINCE'];   $this->IMS=true;  } } function postConnect($info,$output){  $this->content_type=$info["content_type"];  $this->http_code=$info['http_code'];  //var_dump($info);exit;  if(!empty($info['last_modified'])){   $this->lastModified=$info['last_modified'];  }  $this->resultHeader=substr($output,0,$info['header_size']);  $content = substr($output,$info['header_size']);   if($this->http_code=='200'){   $this->content=$content;  }elseif( ($this->http_code=='302' || $this->http_code=='301') && isset($info['redirect_url'])){   $redirect_url = str_replace($this->host,$_SERVER['HTTP_HOST'],$info['redirect_url']);   if (IS_SAE)     $redirect_url = str_replace('http://fetchurl.sae.sina.com.cn/','',$info['redirect_url']);   header("Location: $redirect_url");   exit;  }elseif($this->http_code=='404'){   header("HTTP/1.1 404 Not Found");   exit("HTTP/1.1 404 Not Found");  }elseif($this->http_code=='500'){   header('HTTP/1.1 500 Internal Server Error');   exit("HTTP/1.1 500 Internal Server Error");  }else{   exit("HTTP/1.1 ".$this->http_code." Internal Server Error");  } }  function output(){  $currentTimeString=gmdate("D, d M Y H:i:s",time());  $expiredTime=gmdate("D, d M Y H:i:s",(time()+$this->cacheTime));   $doOriginalHeaders = true;  if($doOriginalHeaders){    if($this->IMS){     header("HTTP/1.1 304 Not Modified");     header("Date: Wed, $currentTimeString GMT");     header("Last-Modified: $this->lastModified");     header("Server: $this->version");    }else{      header("HTTP/1.1 200 OK");     header("Date: Wed, $currentTimeString GMT");     header("Content-Type: ".$this->content_type);     header("Last-Modified: $this->lastModified");     header("Cache-Control: max-age=$this->cacheTime");     header("Expires: $expiredTime GMT");     header("Server: $this->version");     preg_match("/Set-Cookie:[^/n]*/i",$this->resultHeader,$result);     foreach($result as $i=>$value){      header($result[$i]);     }     preg_match("/Content-Encoding:[^/n]*/i",$this->resultHeader,$result);     foreach($result as $i=>$value){      //header($result[$i]);     }     preg_match("/Transfer-Encoding:[^/n]*/i",$this->resultHeader,$result);     foreach($result as $i=>$value){      //header($result[$i]);     }     echo($this->content);     /*     if(stristr($this->content, "error")){    echo print_r($this->sendPost);     }     */    }  }  else{    $headerString = $this->resultHeader; //string     $headerArray = explode("/n", $headerString);    foreach($headerArray as $privHeader){   header($privHeader);    }     if(stristr($headerString, "Transfer-encoding: chunked")){   flush();   ob_flush();   $i = 0;   $maxLen = strlen($this->content);    while($i < $maxLen){     $endChar = $i + self::chunkSize;     if($endChar >= $maxLen){    $endChar = $maxLen - 1;     }     $chunk = substr($this->content, $i, $endChar);     $this->dump_chunk($chunk);     flush();     ob_flush();     $i = $i + $endChar;   }    }    else{    echo($this->content);    }     //echo "header: ".print_r($headerArray);    //header($this->resultHeader);  }  }   function dump_chunk($chunk) {   echo sprintf("%x/r/n", strlen($chunk));   echo $chunk;   echo "/r/n"; }   function getOutsideHeaders(){   $headers = array();   foreach ($_SERVER as $name => $value){   if (substr($name, 0, 5) == 'HTTP_') {     $name = str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr($name, 5)))));     $headers[$name] = $value;   }elseif ($name == "CONTENT_TYPE") {     $headers["Content-Type"] = $value;   }elseif ($name == "CONTENT_LENGTH") {     $headers["Content-Length"] = $value;   }elseif(stristr($name, "X-Requested-With")) {     $headers["X-Requested-With"] = $value;    $this->XRequestedWith = $value;  }   }     //echo print_r($headers);    $this->outsideHeaders = $headers;   return $headers; }  }?>
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本三级韩国三级久久| 8090理伦午夜在线电影| 亚洲精品久久久久久久久久久久久| 91精品国产777在线观看| 国产精品网站视频| 日韩一区二区av| 成人信息集中地欧美| 国产精品视频99| 国内精品免费午夜毛片| 韩国美女主播一区| yellow中文字幕久久| 日韩免费在线看| 4444欧美成人kkkk| 一本大道香蕉久在线播放29| 91精品国产综合久久久久久久久| 国产一区二区激情| 亚洲精品wwwww| 亚洲激情小视频| 日韩美女在线播放| 亚洲精品国产精品乱码不99按摩| 欧美在线视频观看| 欧美日韩国产麻豆| 亚洲人成啪啪网站| 国产午夜精品美女视频明星a级| 精品欧美激情精品一区| 久久精品国产亚洲| 97av在线视频免费播放| 亚洲精品视频二区| 色噜噜久久综合伊人一本| 亚洲成人国产精品| 中文字幕在线看视频国产欧美| 91精品国产综合久久久久久蜜臀| 色香阁99久久精品久久久| 免费不卡欧美自拍视频| 欧美一级bbbbb性bbbb喷潮片| 国产精品第100页| 国产日产久久高清欧美一区| 成人福利网站在线观看11| 日本老师69xxx| 国产精品久久久久久久久久久不卡| 久久成人一区二区| 亚洲嫩模很污视频| 欧美在线一级va免费观看| 亚洲va久久久噜噜噜久久天堂| 久久视频免费观看| 国产精品美女午夜av| 少妇高潮 亚洲精品| 亚洲高清色综合| 久久99视频精品| 欧美精品成人在线| 2019精品视频| 欧美精品久久久久| 色狠狠av一区二区三区香蕉蜜桃| 在线亚洲国产精品网| 国产婷婷成人久久av免费高清| 成人美女免费网站视频| 亚洲欧洲激情在线| 亚洲黄页视频免费观看| 亚洲天堂免费视频| 91在线视频导航| 91黑丝高跟在线| 久久久最新网址| 国产乱人伦真实精品视频| 久久亚洲春色中文字幕| 日韩av电影在线播放| 欧美视频精品一区| 久久人人爽国产| 疯狂欧美牲乱大交777| 久久91超碰青草是什么| 久久精品视频va| 欧美人在线视频| 亚洲国产欧美一区二区丝袜黑人| 国产视频精品va久久久久久| 亚洲最大福利视频网站| 亚洲欧美日韩综合| 精品亚洲夜色av98在线观看| 日韩电影中文字幕一区| 92看片淫黄大片看国产片| 最近2019中文免费高清视频观看www99| 欧美国产亚洲精品久久久8v| 国产精品成熟老女人| 亚洲视频一区二区三区| 国产欧美精品一区二区三区介绍| 欧美国产日韩精品| 88国产精品欧美一区二区三区| 九色精品美女在线| 国内精品视频一区| 日韩av在线导航| 欧美日韩一区二区在线播放| 国产成人激情小视频| 97欧美精品一区二区三区| 亚洲精品一区二区在线| 黑人与娇小精品av专区| 91亚洲精品一区| 欧美丝袜一区二区三区| 午夜精品一区二区三区在线视| 欧美一区二区三区精品电影| 国模精品视频一区二区三区| 中文字幕亚洲欧美日韩在线不卡| 午夜精品一区二区三区视频免费看| 欧美激情精品久久久久久蜜臀| 国产精品久久久久久久电影| 亚洲第一网中文字幕| 成人性生交大片免费看小说| 精品伊人久久97| 日韩精品极品毛片系列视频| 日韩精品在线观看视频| 国产亚洲精品久久久久动| 亚洲精品免费在线视频| 久久久久久久久久久免费精品| 国产午夜一区二区| 亚洲成av人片在线观看香蕉| 久久97久久97精品免视看| 久久久噜噜噜久久| 亚洲一区二区三区香蕉| 亚洲欧美国产精品久久久久久久| 久久久精品久久久| 国产亚洲人成a一在线v站| 性欧美亚洲xxxx乳在线观看| 久久综合88中文色鬼| 在线看欧美日韩| 51视频国产精品一区二区| 亚洲小视频在线| 色无极亚洲影院| 丝袜亚洲欧美日韩综合| 日韩av中文字幕在线播放| 2019中文字幕在线观看| 亚洲图片欧美午夜| 亚洲国产精品网站| 亚洲欧美第一页| 亚洲成人三级在线| 欧美性猛交xxxx乱大交蜜桃| 青草青草久热精品视频在线观看| 欧美日韩亚洲精品一区二区三区| 久久久国产精彩视频美女艺术照福利| 亚洲国产精品一区二区三区| 国产成人精品日本亚洲专区61| 98午夜经典影视| 久久久久久久久久久av| 亚洲精品小视频在线观看| 欧美成人免费视频| 久久久久久免费精品| 欧美日韩性视频在线| 992tv成人免费视频| 这里只有精品丝袜| 在线播放日韩精品| 丝袜美腿精品国产二区| 8050国产精品久久久久久| 欧美日韩亚洲视频| 欧美日韩国产123| 日韩视频一区在线| 中文字幕欧美在线| 国产日韩av高清| 97人人做人人爱| 中文字幕日韩av电影| 国产欧美精品xxxx另类| 欧美自拍视频在线观看| 亚洲国产成人91精品| 日韩成人在线视频网站| 欧美wwwwww| 伊人久久精品视频| 亚洲新中文字幕| 91精品国产91久久久久久最新| 国产aaa精品|