Скрипт прокси сервера

Discussion in 'PHP' started by Satell, 25 Jan 2007.

  1. Satell

    Satell Elder - Старейшина

    Joined:
    13 Jan 2007
    Messages:
    91
    Likes Received:
    5
    Reputations:
    1
    где взять?
     
  2. Tem

    Tem -

    Joined:
    5 Oct 2005
    Messages:
    557
    Likes Received:
    157
    Reputations:
    179
    1) Самому писать.

    2) Взять у друга в аське.

    3) Гугл рулит.

    4) Украсть.

    5) Купить.

    6) Попросить написать комуто.
     
  3. gizmo

    gizmo Elder - Старейшина

    Joined:
    21 Dec 2006
    Messages:
    126
    Likes Received:
    28
    Reputations:
    9
    Code:
    <?PHP
    /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
     *  PHP-anonymizer * PHP-анонимайзер * Версия 1.05, 2006-11-28
     *  
     *  Скрипт может быть использован для анонимного серфинга в интернете и экономии 
     *  траффика (при размещении на сервере у провайдера). Не требует установки и 
     *  настройки. Не использует временные файлы. Не требует разрешения на запись. 
     *  Поддержка post-запросов, basic-авторизации, download и upload файлов. 
     *  Работает при safe mode. Поддерживает HTTP. Возможна поддержка HTTPS, если
     *  PHP сконфигурирован с поддержкой SSL.
     * 
     *  Требования:  PHP4 c разрешенным fsockopen и конфигурацией как модуль Apache.
     *   
     *  Бесплатная загрузка: http://usfree.chat.ru
     *  Автор: Малыгин Александр
     *  Поддержите развитие программы: Yandex-деньги 4100138666526, WebMoney R193471382669
     * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ 
    ####################################### настройки ####################################
    // кодировка сервера (раскомментируйте строку, если сервер поддерживает только одну кодировку)
    // $charset_default="windows-1251";
    // $charset_default="koi8-r";
    
    // кодировка запросов (предпочитаемая кодировка страницы)
    $charset_query="windows-1251";
    
    // адрес по умолчанию
    $url_default="http://yandex.ru";
    
    // сжатие gzip или deflate для экономии траффика
    $compression=1;
    
    // разрешенные адреса (раскомментируйте и измените строку, если хотите разрешить доступ только к определенным сайтам)
    // $location_allow=array("http://yandex.ru","http://news.yandex.ru","http://yaca.yandex.ru");
    
    // максимальное время работы скрипта
    $time_limit=600;
    
    // время кэширования (для отмены установите значение меньше 0)
    $expires_default=3600;
    
    // время установки cookie
    $cookie_expires=3600;
    
    // массив расширений для обязательного заголовка загрузки
    $ras_array=array("zip","rar");
    
    // вывод информации о скрипте
    $info_allow=0;
    
    // демо-версия
    $demo_version=0;
    
    ######################################################################################
    // массивы необрабатываемых ссылок
    // полное совпадение со ссылкой
    $no_replace_all_array=array("http://","\\",".");
    // совпадение с началом ссылки
    $no_replace_left_array=array("+","#","mailto:","javascript:","ftp://");
    
    // максимальное время работы скрипта
    @ini_restore("safe_mode");
    @ini_restore("open_basedir");
    @set_time_limit($time_limit);
    
    // кэширование
    if ($expires_default>0){
    header("Expires: ".gmdate('D, d M Y H:i:s',time()+$expires_default)." GMT");
    }
    if ($expires_default<0){
    header("Expires: Thu, 01 Jan 1970 00:00:01 GMT");
    header("Cache-Control: no-cache");
    header("Pragma: no-cache");
    }
    
    // получение и дешифровка адреса
    $session_get=$HTTP_GET_VARS['session_new'];
    if ($session_get){
    $location_get=$session_get;
    $strpos=strpos($session_get,"?");
    if ($strpos && (substr($session_get,0,7)!="http://" && substr($session_get,0,8)!="https://")){
    $session_get=substr($session_get,0,$strpos+1);
    $location_get=decode($session_get);
    $session_add=getenv('QUERY_STRING');
    $strpos=strpos($session_add,"?");
    $location_get=$location_get.substr($session_add,$strpos+1);
    $pos1=strpos($location_get,"?");
    $pos2=strpos($location_get,"&");
    if (($pos1 && $pos2 && $pos2<$pos1) || (!$pos1 && $pos2)){$location_get=preg_replace("#&#si","?",$location_get,1);}
    }
    $location=$location_get;
    }
    $session_post=$HTTP_POST_VARS['session_new'];
    if ($session_post){
    $location_post=decode($session_post);
    $location=$location_post;
    }
    $url_array=url($location,1);
    $location=$url_array[0];
    $location_code=code($location);
    
    
    if (!$location){
    // вывод информации о скрипте
    $info="";
    if ($demo_version){$info.="* Демо-версия *<br><br>";}
    if ($info_allow){
    $info.="Максимальное время работы скрипта: $time_limit сек.";
    if (count($location_allow)){
    $info.="<br><br>Разрешенные сайты:<br>";
    $info.=implode("<br>",$location_allow);
    $info.="<br>На остальные сайты будет выполнена переадресация.";
    }
    }
    // начальная форма
    $content="<html>
    <head>
    <title>PHP-анонимайзер (".getenv('SERVER_NAME').")</title>
    <meta http-equiv=\"Content-Type\" content=\"text/html; charset=windows-1251\">
    </head>
    <body>
    <br><br>
    <form action=\"\" method=\"POST\">
    <div align=\"center\">Ссылка: <input type=\"Text\" name=\"session_new\" value=\"http://\">
    <input type=\"Submit\" value=\"Вперед >>\">
    </font>
    </form>
    $info
    </div>
    </body>
    </html>";
    if ($charset_default){
    header("Content-Type: text/html; charset=$charset_default");
    $content=decode_charset($content,"windows-1251",$charset_default);
    }
    echo $content;
    exit;
    }
    
    // поиск разрешенного адреса
    if (count($location_allow)){
    $sovp=0;
    for ($j=0;$j<count($location_allow);$j++){
    if ($location_allow[$j]==substr($location,0,strlen($location_allow[$j]))){
    $sovp=1;
    break;
    }
    }
    if ($sovp==0){
    header("Location: $location");
    echo "Выполняется переадресация...";
    exit;
    }
    }
    
    // получение referer
    if ($HTTP_POST_VARS['referer_new']){$referer_new=decode($HTTP_POST_VARS['referer_new']);}
    if ($HTTP_GET_VARS['referer_new']){$referer_new=$HTTP_GET_VARS['referer_new'];}
    if (!$referer_new && getenv('HTTP_REFERER')){
    $tmp=@parse_url(getenv('HTTP_REFERER'));
    parse_str($tmp[query],$tmp);
    $referer_new=$tmp[session_new];
    if ($referer_new){
    $strpos=strpos($referer_new,"?");
    if ($strpos && (substr($referer_new,0,7)!="http://" && substr($referer_new,0,8)!="https://")){
    $find=substr($referer_new,0,$strpos+1);
    $replace=decode($find);
    $referer_new=str_replace($find,$replace,$referer_new);
    }
    }
    }
    if ($referer_new){
    $url_array=url($referer_new,0);
    $referer_new=$url_array[0];
    }
    
    // получение данных www-аутентификации
    if ($PHP_AUTH_USER && $PHP_AUTH_PW){$auth_new=base64_encode("$PHP_AUTH_USER:$PHP_AUTH_PW");}
    
    // данные о кодировке
    $charset_new=$HTTP_POST_VARS['charset_new'];
    if (!$charset_new){$charset_new=$charset_query;}
    
    // запрос
    $connection=connection($location);
    $message=$connection[0];
    $head=$connection[1];
    $content=$connection[2];
    
    // установка cookie
    $tmp=explode(".",$host_new);
    $host_cookie=$tmp[count($tmp)-2]."_".$tmp[count($tmp)-1];
    if (stristr($head,"Cookie:")){
    preg_match_all("#Set-Cookie: (.*?)=\"?(.*?)\"?(; expires=(.*?))?[;\r]#is",$head,$cookie_array);
    $perem_array=$cookie_array[1];
    $value_array=$cookie_array[2];
    $expires_array=$cookie_array[4];
    for ($i=0; $i<count($perem_array); $i++){
    if ($expires_array[$i] && strtotime($expires_array[$i],"\n")){$expires_array[$i]=strtotime($expires_array[$i],"\n");} else {$expires_array[$i]=time()+$cookie_expires;}
    setcookie ($host_cookie."[".$perem_array[$i]."]",$value_array[$i],$expires_array[$i]);
    $HTTP_COOKIE_VARS[$host_cookie][$perem_array[$i]]=$value_array[$i];
    }
    }
    
    // расширение файла
    $content_ras=strtolower(substr($path_new,strrpos($path_new,".")+1));
    if (!$content_ras || strlen($content_ras)>4){$content_ras="html";}
    
    // получаем тип данных и кодировку
    if (stristr($head,"Content-Type:")){
    preg_match("#Content-Type: ([^\"';\s]+);?( charset=([^\"';\s]+))?[\s\r\n]#is",$head,$type);
    $content_type=strtolower($type[1]);
    $content_charset=strtolower($type[3]);
    }
    if (!$content_type){$content_type="text/html";}
    for($i=0;$i<count($ras_array);$i++){
    if ($content_ras==$ras_array[$i]){$content_type="application/octet-stream";}
    }
    if (!$content_charset){
    preg_match("#<meta[\s]http-equiv=\"?'?Content-Type\"?'?.*?charset=(.*?)[\"'\s>]#is",$content,$content_charset);
    $content_charset=strtolower($content_charset[1]);
    }
    if (!$content_charset){$content_charset=$charset_query;}
    
    // заголовок www-аутентификации
    if (stristr($head,"WWW-Authenticate:")){
    preg_match("#WWW-Authenticate: (.*?)[\r\n]#is",$head,$auth);
    header("WWW-Authenticate: $auth[1]");
    header("HTTP/1.0 401 Unauthorized");
    }
    
    // обработка переадресаций
    $refresh="";
    if (preg_match("#Location: (.*?)[\s\r\n]#is",$head,$tmp)){
    $refresh=parse($tmp[1]);
    $refresh="http://".getenv('HTTP_HOST').getenv('SCRIPT_NAME')."?session_new=".code($refresh);
    header("Location: $refresh");
    }
    preg_match_all("#<meta.*?http-equiv=.*?refresh.*?url=(.*?)[\'\" ].*?[>]#is",$content,$refresh_array);
    replace($refresh_array[0],$refresh_array[0],$refresh_array[1],"?session_new=","");
    
    // длина файла
    $content_len=strlen($content);
    if (!$content_len){exit;}
    
    // вывод файла
    if ($content_type!="text/html" && $content_type!="text/plain" && $content_type!="application/x-javascript"){
    if (strrchr($path_new, "/")){$filename=substr(strrchr($path_new, "/"), 1);} else {$filename=$path_new;}
    if (preg_match("#(text|image).*?#si",$content_type)){
    header("Content-Type: $content_type");
    } else {
    header("Content-type: application/octet-stream");
    header("Content-Disposition: attachment; filename=$filename");
    header("Accept-Ranges: bytes");
    header("Content-length: $content_len");
    }
    echo $content;
    exit;
    }
    
    // перекодирование и заголовок кодировки
    if ($charset_default){
    $content_new=decode_charset($content,$content_charset,$charset_default);
    if ($content_new==$content){
    $head_charset=$content_charset;
    } else {
    $head_charset=$charset_default;
    $content=$content_new;
    }
    } else {
    $head_charset=$content_charset;
    }
    if ($head_charset){header("Content-Type: $content_type; charset=$head_charset");}
    
    // содержимое без скриптов
    $content_no_script=preg_replace("#<script[^>]*?[>].*?</script>#is","",$content);
    // содержимое скриптов
    preg_match_all("#<script[^>]*?[>].*?</script>#is",$content,$script_array);
    if ($script_array[0]){$content_script=implode("\n",array_unique($script_array[0]));}
    if ($content_ras=="js" || $content_type=="application/x-javascript"){$content_script=$content; $content_no_script="";}
    
    // обработка base
    preg_match("#<base[\s]*?href=[\"']?(.*?)[\"'\s>]#si",$content,$base_array); 
    $base_href=$base_array[1];
    if ($base_href){
    $url_array=url($base_href,0);
    $preffix_new=$url_array[7];
    $content=preg_replace("#<base[\s\n]*?href=.*?[>]#si","",$content);
    }
    
    // обработка форм
    preg_match_all("!(<form[\s>].*?\>|<form>)!is",$content,$form_array); 
    $form_array=array_values(array_unique($form_array[0]));
    for ($i=0;$i<count($form_array);$i++){
    preg_match("! action[\s]*=[\s]*\"?'?(.*?)[\"\'\s>]!is",$form_array[$i],$tmp);
    $action_array[$i]=$tmp[1];
    if (!$action_array[$i]){$action_array[$i]=$location;}
    if (stristr($form_array[$i],"post")){$method_new="POST";} else {$method_new="GET";}
    $form_array_new[$i]=preg_replace("' action=.*?([\s>])'si","$1",$form_array[$i]);
    $form_array_new[$i]=preg_replace("' method=.*?([\s>])'si","$1",$form_array_new[$i]);
    $form_array_new[$i]=preg_replace("'<form'si","<form method=post",$form_array_new[$i]);
    $session_code=code($action_array[$i]);
    $replace="$form_array_new[$i]
    <input type=\"hidden\" name=\"session_new\" value=\"$session_code\">
    <input type=\"hidden\" name=\"referer_new\" value=\"$location_code\">
    <input type=\"hidden\" name=\"method_new\" value=\"$method_new\">";
    if ($charset_default){$replace.="\n<input type=\"hidden\" name=\"charset_new\" value=\"$content_charset\">";}
    $content=str_replace($form_array[$i],$replace,$content);
    }
    preg_match_all("#\.action[\s]*=[\s]*[\"'](.*?)[\"']#is",$content,$script_action_array);
    $script_action_replace=str_replace(".action",".session_new.value",$script_action_array[0]);
    replace($script_action_array[0],$script_action_replace,$script_action_array[1],"","");
    
    // обработка ссылок
    preg_match_all("#(<a|link|area)[\s].*?href[\s]*=[\s]*\\\?\"?'?(.*?)\\\?[\"'\s>]#is",$content,$href_array);
    replace($href_array[0],$href_array[0],$href_array[2],"?session_new=","");
    preg_match_all("#<(img|embed|frame|iframe|input|script)[\s][^>]*?src[\s]*=[\s]*\\\?\"?'?([^>]*?)\\\?[\"'\s>]#is",$content,$src_array);
    replace($src_array[0],$src_array[0],$src_array[2],"?session_new=","");
    preg_match_all("#\.src[\s]*=[\s]*[\"'](.*?)[\"']#is",$content,$script_src_array);
    replace($script_src_array[0],$script_src_array[0],$script_src_array[1],"?session_new=","");
    preg_match_all("#<(body|table|td)[\s].*?background[\s]*=[\s]*\"?'?(.*?)[\"'\s>]#is",$content,$background_array);
    replace($background_array[0],$background_array[0],$background_array[2],"?session_new=","");
    preg_match_all("#(location.href|document.location|document.url|parent.location)[\s]*=[\s]*[\"'](.*?)[\"']#is",$content,$location_array);
    replace($location_array[0],$location_array[0],$location_array[2],"?session_new=","");
    preg_match_all("#(window.open|location.assign)\([\"'](.*?)[\"',\s>\)]#is",$content,$window_array);
    replace($window_array[0],$window_array[0],$window_array[2],"?session_new=","");
    preg_match_all("#[\"'](https?://.*?|https?%3A%2F%2F.*?)[\"'\s\)>]#is",$content_script,$http_array);
    replace($http_array[0],$http_array[0],$http_array[1],"?session_new=","");
    
    // обработка cookie в скриптах
    preg_match_all("#document.cookie[\s]*=[\s]*[\"'](.*?)[\"']#is",$content,$script_cookie_array);
    $script_cookie_array=$script_cookie_array[1];
    for ($i=0; $i<count($script_cookie_array); $i++){
    preg_match("#(.*?)=(.*?)[;\s]#is",$script_cookie_array[$i],$perem_cookie_array);
    $find=$perem_cookie_array[1];
    if ($find){
    $replace=$host_cookie."[".$find."]";
    $replace=str_replace("$find=","$replace=",$script_cookie_array[$i]);
    $find=$script_cookie_array[$i];
    $content=str_replace($find,$replace,$content);
    }
    }
    
    // обработка имени хоста в скриптах
    $host_find=$host_new;
    if (substr($host_find,0,4)=="www."){$host_find=substr($host_find,4);}
    $host_proxy=getenv('HTTP_HOST');
    preg_match_all("#[=(][\s]*[\"'](www\.)?".$host_find."/?[\"']#is",$content,$script_host_array);
    $script_host_array=array_unique($script_host_array[0]);
    for ($i=0;$i<count($script_host_array);$i++){
    $find=$script_host_array[$i];
    $replace=str_replace($host_new,$host_proxy,$script_host_array[$i]);
    $content=str_replace($find,$replace,$content);
    }
    
    // сжатие
    if ($compression){
    function compress_output_gzip($output){return gzencode($output);}
    function compress_output_deflate($output) {return gzdeflate($output,9);}
    $support_gzip=0; $support_deflate=0;
    if (isset($_SERVER['HTTP_ACCEPT_ENCODING'])){$AE = $_SERVER['HTTP_ACCEPT_ENCODING'];} else {$AE = $_SERVER['HTTP_TE'];}
    if (strpos($AE,'gzip')){$support_gzip=1;}
    if (strpos($AE,'deflate')){$support_deflate=1;}
    if ($support_gzip){
    header("Content-Encoding: gzip");
    ob_start("compress_output_gzip");
    } elseif ($support_deflate){
    header("Content-Encoding: deflate");
    ob_start("compress_output_deflate");
    }
    }
    
    // вывод
    echo $content;
    
    ################################# функция соединения ################################
    function connection($location){
    global $HTTP_POST_VARS,$HTTP_COOKIE_VARS,$HTTP_POST_FILES,$referer_new,$auth_new,$charset_default;
    
    $url_array=url($location,0);
    $scheme=$url_array[1];
    $method=$url_array[2];
    $host=$url_array[3];
    $port=$url_array[4];
    if ($scheme=="https"){$port=443;}
    $path=$url_array[5];
    $get=$url_array[6];
    $referer=$referer_new;
    $auth=$auth_new;
    $charset=$charset_default;
    
    // обработка и кодирование GET, POST
    $post=mass($HTTP_POST_VARS,1,"\$perem=\$value&");
    if ($post && substr($post,-1)=="&"){$post=substr($post,0,-1);}
    if ($method=="GET" && $post){
    if ($get){$get="$get&$post";} else {$get="$post";}
    $post="";
    }
    if ($get){$get="?$get";}
    $len=strlen($post);
     
  4. gizmo

    gizmo Elder - Старейшина

    Joined:
    21 Dec 2006
    Messages:
    126
    Likes Received:
    28
    Reputations:
    9
    Code:
    // обработка и кодирование GET, POST
    $post=mass($HTTP_POST_VARS,1,"\$perem=\$value&");
    if ($post && substr($post,-1)=="&"){$post=substr($post,0,-1);}
    if ($method=="GET" && $post){
    if ($get){$get="$get&$post";} else {$get="$post";}
    $post="";
    }
    if ($get){$get="?$get";}
    $len=strlen($post);
    
    // обработка и кодирование COOKIE
    $tmp=explode(".",$host); $host_cookie=$tmp[count($tmp)-2]."_".$tmp[count($tmp)-1];
    $mass=$HTTP_COOKIE_VARS[$host_cookie];
    $cookie=mass($mass,1,"\$perem=\$value; ");
    if (substr($cookie,-2)=="; "){$cookie=substr($cookie,0,-2);}
    
    // обработка multipart/form-data
    $type=getenv('CONTENT_TYPE');
    if ($type && stristr($type,"multipart/form-data")){
    preg_match("#boundary=(.*)#si",$type,$boundary);
    $boundary=$boundary[1];
    $post=mass($HTTP_POST_VARS,0,"--$boundary\r\nContent-Disposition: form-data; name=\"\$perem\"\r\n\r\n\$value\r\n");
    // поддержка upload
    $mass=$HTTP_POST_FILES;
    if ($mass){
    reset($mass);
    for ($i=0; $i<count($mass); $i++){
    $perem=key($mass);
    $filename=$mass[$perem][name];
    $filetype=$mass[$perem][type];
    if ($filename){
    global ${"$perem"};
    $filecontent=implode("",file(${"$perem"}));
    $post.="--$boundary\r\nContent-Disposition: form-data; name=\"$perem\"; filename=\"$filename\"\r\nContent-Type: $filetype\r\n\r\n$filecontent\r\n";
    }
    }
    }
    $post.="--$boundary--";
    $len=strlen($post)+2;
    }
    
    // формирование заголовка запроса
    $message="$method $path$get HTTP/1.0\r\n";
    $message.="Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-excel, application/msword, application/x-shockwave-flash, */*\r\n";
    if ($referer){$message.="Referer: $referer\r\n";}
    $message.="Accept-Language: ru\r\n";
    if ($charset){$message.="Accept-Charset: $charset\r\n";}
    if ($auth){$message.="Authorization: Basic $auth\r\n";}
    if ($post && $boundary){$message.="Content-Type: multipart/form-data; boundary=$boundary\r\n";}
    if ($post && !$boundary){$message.="Content-Type: application/x-www-form-urlencoded\r\n";}
    $message.="User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)\r\n";
    $message.="Host: $host\r\n";
    if ($post){$message.="Content-length: $len\r\n";}
    $message.="Connection: close\r\n";
    $message.="Cache-Control: no-cache\r\n";
    $message.="Pragma: no-cache\r\n";
    if ($cookie){$message.="Cookie: $cookie\r\n";}
    if ($post){$message.="\r\n$post\r\n";}
    $message.="\r\n";
    // echo $message;  exit;
    
    // запрос
    if ($scheme=="http"){
    $fp=fsockopen($host,$port,$errno,$errstr);
    if (!$fp){echo "Нет связи с сервером. Повторите попытку позднее. $errno ($errstr).";}
    }
    if ($scheme=="https"){
    $fp=pfsockopen("ssl://$host",$port,$errno,$errstr);
    if (!$fp){echo "Невозможно соединиться с сервером. Нет поддержки SSL.";}
    }
    if (!$fp){exit;}
    fputs($fp,$message);
    while(!feof($fp)){$fgets=fgets($fp,2048); if ($fgets=="\r\n" || $fgets=="\n"){break;} $head.=$fgets;}
    while(!feof($fp)){$content.=fread($fp,2048);}
    fclose($fp);
    // echo $head;
    // echo $content;
    
    return array($message,$head,$content);
    }
    
    ############################ функция обработки адреса ###############################
    function url($location,$save){
    if (!$location){return;}
    global $url_default,$scheme_new,$method_new,$host_new,$port_new,$path_new,$preffix_new;
    // установки по умолчанию
    $url=@parse_url($url_default);
    $scheme_default=$url[scheme];
    $host_default=$url[host];
    $path_default=$url[path];
    $method_default="GET";
    $port_default=80;
    // разбор адреса
    $url=preg_replace("#://?#si","://",$location,1);
    $url=@parse_url($url);
    $scheme=$url[scheme];
    if (!$scheme){$scheme=$scheme_new;}
    if (!$scheme){$scheme=$scheme_default;}
    $method=$method_new;
    if (!$method){$method=$method_new;}
    if (!$method){$method=$method_default;}
    $host=$url[host];
    if (!$host){$host=$host_new;}
    if (!$host){$host=$host_default;}
    $port=$url[port];
    if (!$port){$port=$port_new;}
    if (!$port){$port=$port_default;}
    $path=$url[path];
    $path=str_replace("\\","/",$path);
    $path="/$path";
    $path=preg_replace("'/{2,100}'si","/",$path);
    // обработка /./ и /../
    for ($i=0;$i<10;$i++){$path=preg_replace("#/[^\./][^/]+/\.\.?/#si","/",$path);}
    for ($i=0;$i<10;$i++){$path=preg_replace("#/\.\.?/#si","/",$path);}
    $get=$url[query];
    $get=get($get);
    $adr=$scheme."://".$host;
    if (($scheme=="http" && $port!=80) || ($scheme=="https" && $port!=443)){$adr.=":".$port;}
    $preffix=$adr.substr($path,0,strrpos($path,"/"))."/";
    $location=$adr.$path;
    if ($get){$location.="?$get";}
    // обновление переменных
    if ($save){
    $scheme_new=$scheme;
    $method_new=$method;
    $host_new=$host;
    $port_new=$port;
    $path_new=$path;
    $preffix_new=$preffix;
    $location_new=$location;
    }
    // вывод
    return array($location,$scheme,$method,$host,$port,$path,$get,$preffix);
    }
    ############################ функция обработки ссылок ###############################
    function parse($url){
    global $scheme_new,$host_new,$port_new,$path_new,$preffix_new,$base_href;
    // получение полного адреса
    if (!$url || $url=="http://" || $url=="https://" || $url=="\\"){return $preffix_new;}
    if ($base_href){$adr=$base_href;} else {$adr=$scheme_new."://".$host_new;}
    if ($port_new && (($scheme_new=="http" && $port_new!=80) || ($scheme_new=="https" && $port_new!=443))){$adr.=":".$port_new;}
    if (substr($url,0,1)=="/"){
    $url=$adr.$url;
    } elseif (substr($url,0,1)=="?"){
    if ($base_href){$url=$adr.$url;} else {$url=$adr.$path_new.$url;}
    } else {
    $tmp=@parse_url($url);
    if ($tmp[scheme]!="http" && $tmp[scheme]!="https" && $tmp[scheme]!="ftp"){$url=$preffix_new.$url;}
    }
    return $url;
    }
    ################################## функция кодирования ##############################
    function code($str){
    if (!$str){return;}
    $str=parse($str);
    $str=base64_encode($str);
    $str=str_replace("=","$",$str);
    $code="$str?";
    return $code;
    }
    ################################ функция декодирования ##############################
    function decode($code){
    if (!$code){return;}
    if (substr($code,0,7)=="http://" || substr($code,0,8)=="https://"){return $code;}
    if (substr($code,-1)=="?"){$code=substr($code,0,-1);}
    $code=str_replace("$","=",$code);
    $str=base64_decode($code);
    return $str;
    }
    ################################# функция замены ссылок #############################
    function replace($mass1,$mass2,$mass3,$left,$right){
    global $content,$no_replace_all_array,$no_replace_left_array;
    for ($i=0;$i<count($mass1);$i++){
    $mass3[$i]=trim($mass3[$i]);
    if ($mass3[$i]){
    $sovp=0;
    for ($j=0;$j<count($no_replace_all_array);$j++){if ($no_replace_all_array[$j]==$mass3[$i]){$sovp=1;}}
    for ($j=0;$j<count($no_replace_left_array);$j++){if ($no_replace_left_array[$j]==substr($mass3[$i],0,strlen($no_replace_left_array[$j]))){$sovp=1;}}
    if (!$sovp){
    $replace=$mass3[$i];
    $replace=$left.code($replace).$right;
    $replace=str_replace($mass3[$i],$replace,$mass2[$i]);
    $content=str_replace($mass1[$i],$replace,$content);
    }
    }
    }
    }
    
    ################################# функция обработки GET #############################
    function get($get){
    if (!$get){return;}
    global $charset_default,$charset_new;
    // декодирование HTML-мнемоник
    $get=str_replace("&amp;","&",$get);
    $get=str_replace("&quot;","\"",$get);
    $get=str_replace("'","'",$get);
    $get=str_replace("&lt;","<",$get);
    $get=str_replace("&gt;",">",$get);
    // url-кодирование
    preg_match_all("#=([^&;]+)#is",$get,$mass);
    $mass=$mass[1];
    for ($i=0; $i<count($mass); $i++){
    $find=$replace=$mass[$i];
    $replace=urldecode($replace);
    if ($charset_default){$replace=decode_charset($replace,$charset_default,$charset_new);}
    $replace=urlencode(stripslashes($replace));
    $get=str_replace("=$find","=$replace",$get);
    }
    // декодирование символов
    $get=str_replace("%3A",":",$get);
    $get=str_replace("%40","@",$get);
    return $get;
    }
    
    ######################## поиск ключей многомерного массива #########################
    function keys($mass,$c,$d){
    global $a,$b;
    $keys=array_keys($mass);
    for($i=0;$i<count($keys);$i++){
    $perem=$d[$c]=$b[$a][$c]=$keys[$i];
    $value=$mass[$perem];
    for($j=1;$j<$c;$j++){$b[$a][$j]=$d[$j];}
    if (is_array($value)){$c++; keys($value,$c,$d); $c--;} else {$a++;}
    }
    }
    
    ############################ функция обработки POST/COOKIE ##########################
    function mass($mass,$code,$repl){
    if (!$mass){return;}
    global $charset_default,$charset_new;
    global $a,$b;
    $a=0; $b="";
    // поиск ключей массива
    keys($mass,1,null);
    // формирование запроса
    for($i=0;$i<count($b);$i++){
    $perem="";
    $value=$mass;
    for($j=1;$j<=count($b[$i]);$j++){
    if ($j==1){$perem.=$b[$i][$j];} else {$perem.="[".$b[$i][$j]."]";}
    $value=$value[$b[$i][$j]];
    }
    if ($perem!="session_new" && $perem!="referer_new" && $perem!="method_new" && $perem!="charset_new"){
    $value=urldecode($value);
    if ($charset_default){$value=decode_charset($value,$charset_default,$charset_new);}
    if ($code){$value=urlencode(stripslashes($value));}
    $new=str_replace("\$perem",$perem,$repl);
    $new=str_replace("\$value",$value,$new);
    $zapr.=$new;
    }
    }
    // декодирование символов
    $zapr=str_replace("%3A",":",$zapr);
    $zapr=str_replace("%40","@",$zapr);
    return $zapr;
    }
    ######################### функция конвертирования кирилицы #########################
    function decode_charset($content,$code,$decode){
    if (!$content || !$code || !$decode || $code==$decode){return $content;}
    $charset=array("koi8-r"=>"k","windows-1251"=>"w","iso8859-5"=>"i","x-cp866"=>"a","x-mac-cyrillic"=>"m","utf-8"=>"u");
    $from=$charset[$code];
    $to=$charset[$decode];
    if (!$from || !$to){return $content;}
    if ($from=="u"){
    $content=convert_utf_string($content,"w");
    $content=convert_cyr_string ($content,"w",$to);
    } elseif ($to=="u"){
    $content=convert_cyr_string ($content,$from,"w");
    $content=convert_utf_string($content,"u");
    } else {
    $content=convert_cyr_string ($content,$from,$to);
    }
    return $content;
    }
    ########################### функция конвертирования utf-8 ##########################
    function convert_utf_string($str,$type){
    // w - encodes from UTF to win ; u - encodes from win to UTF 
    static $conv='';
    if(!is_array($conv)){  
    $conv=array();
    for ($x=128;$x<=143; $x++){
    $conv['utf'][]=chr(209).chr($x);
    $conv['win'][]=chr($x+112);
    }
    for ($x=144; $x<=191; $x++){
    $conv['utf'][]=chr(208).chr($x);
    $conv['win'][]=chr($x+48);
    }
    $conv['utf'][]=chr(208).chr(129);
    $conv['win'][]=chr(168);
    $conv['utf'][]=chr(209).chr(145);
    $conv['win'][]=chr(184);
    }
    if ($type=='w'){
    return str_replace($conv['utf'],$conv['win'],$str );
    } elseif ($type=='u'){
    return str_replace ($conv['win'],$conv['utf'],$str);
    } else {
    return $str;
    }
    }
    #####################################################################################
    
    ?>
     
  5. gizmo

    gizmo Elder - Старейшина

    Joined:
    21 Dec 2006
    Messages:
    126
    Likes Received:
    28
    Reputations:
    9
    слить в 1 файл, ессно. лимит в 20к символов.
     
    1 person likes this.
  6. Satell

    Satell Elder - Старейшина

    Joined:
    13 Jan 2007
    Messages:
    91
    Likes Received:
    5
    Reputations:
    1
    вот нашел такой проксик на перле
    http://www.jmarshall.com/tools/cgiproxy/
    там в форму вводится адрес сайта, он отправляется скрипту через форму броузера и возвращается скриптом сайт, насколько я понял это не такой прокси, который слушает определённый порт, который можно прописать в настройках экплорера и серфить через него? возможен ли впринципе такой скрипт на перле, который будет слушать определенный порт?

    php анонимайзер у меня почему-то при запуске показывает только исходный код(
     
  7. gizmo

    gizmo Elder - Старейшина

    Joined:
    21 Dec 2006
    Messages:
    126
    Likes Received:
    28
    Reputations:
    9
    у меня тот, что выложил, пашет.
    Если тебе нужен описанный прокси - тебе нужен 3proxy. У создателя есть сайт с очень подробными инструкциями по установке. Только вот не помню адреса, Яндекс тебе в помощь.


    http://webfile.ru/1299970
     
    #7 gizmo, 26 Jan 2007
    Last edited: 26 Jan 2007
  8. Satell

    Satell Elder - Старейшина

    Joined:
    13 Jan 2007
    Messages:
    91
    Likes Received:
    5
    Reputations:
    1
    спасибо! а 3proxy можно на фрихостинг ставить без шелл доступа?
     
  9. hsi

    hsi Member

    Joined:
    11 Sep 2006
    Messages:
    214
    Likes Received:
    61
    Reputations:
    7
    Satell
    3proxy
    Установить этот socks-сервер можно даже с правами nobody.
    На счет фрихоста - это точно там запрещено, то есть работать будет (на некоторых, где нет жесткой фильтрации траффика), пока админ не засечет.
    Легкоусвояемый ман по настройке - link
     
    #9 hsi, 27 Jan 2007
    Last edited: 27 Jan 2007