предпросмотр изображений

<?php
/*
*предпросмотр изображений
*автор: nc_soft
*15.09.07
*/

//путь к файлу картинки (jpg,gif,png)
$img='example.jpg';

$info=getimagesize($img);

//оригинальная ширина
$w_or=$info[0];

//оригинальная высота
$h_or=$info[1];

//тип
$type=$info['mime'];


//создаем изображение
$im1='';

if ($type=='image/jpeg')
$im1=ImageCreateFromJpeg($img);

if ($type=='image/gif')
$im1=ImageCreateFromGif($img);

if ($type=='image/png')
$im1=ImageCreateFromPng($img);

if (!$im1)
die('ошибка');

//далее условимся, что максимальный размер одной из сторон превьюшки равен 80 пикселей
//высчитаем коэффицент масштаба
if ($w_or>$h_or)
{
    $k=$w_or/80;
}
else
{
    $k=$h_or/80;
}

//высчитаем размеры превьюшки
$w=round($w_or/$k);
$h=round($h_or/$k);


//$im2=ImageCreate($w,$h); (если хотите ПЛОХОЕ качество картинки испоьзуйте эту функцию ;) )
$im2=imagecreatetruecolor($w,$h);

//ImageCopyResized($im2,$im1,0,0,0,0,$w,$h,$w_or,$h_or); (если хотите ПЛОХОЕ качество картинки испоьзуйте эту функцию ;) )
imagecopyresampled($im2,$im1,0,0,0,0,$w,$h,$w_or,$h_or);

if ($type=='image/jpeg')
{
    header('Content-type:image/jpeg');
    ImageJpeg($im2);
}
elseif ($type=='image/gif')
{
    header('Content-type:image/gif');
    ImageGif($im2);
}
elseif ($type=='image/png')
{
    header('Content-type:image/png');
    ImagePng($im2);
}
else die('ошибка');

?>
15 сентября 2007, 19:37

Определение числа файлов и их размер в папке произвольной вложенности

<?php
/**
 *Определение числа файлов и их размер в папке произвольной вложенности
 *автор: nc_soft
 *13.09.07
*/

//рекурсивная функция, которая вызывает сама себя
function count_files($directory)
{
    //нужна внешняя переменная чтобы учитывать суммарное кол-во файлов
    GLOBAL $i,$size;

    //открываем директорию
    $dir=opendir($directory);

    //читаем директорию в цикле
    while (false!==($file=readdir($dir)))
    {
        //если это файл, то
        if (is_file($directory.'/'.$file))
        {
            //увеличиваем счетчик
            $i++;

			//увеличиваем размер
			$size+=filesize($directory.'/'.$file);

            /*если необходимо, то можно удалить все файлы для примера вот так:
            unlink($directory.'/'.$file); */
        }
        //если же наткнулись на директорию
        elseif (is_dir($directory.'/'.$file) && $file!='.' && $file!='..')
        {
            //снова вызываем функцию уже для этой директории
            count_files($directory.'/'.$file);
        }
    }
    //закрываем директорию
    closedir($dir);
}

$i=0;
$size=0;

//посчитаем файлы в текущей директории
count_files('.');

echo 'файлов :'.$i;
echo ' размером :'.$size;

?>
13 сентября 2007, 23:54

рисование копирайтов на изображениях

<?php
/*
*создание прозрачного копирайта на изображении
*автор: nc_soft
*13.09.07
*/

//заголовок
header ("Content-type: image/png");

//оригинальное изображение (в данном случаи 128*97
$img = imagecreatefromjpeg("example.jpg");


/*
*все координаты задаются от ВЕРХНЕГО ЛЕВОГО угла изображения (там 0.0)
*/

//верхняя левая точка прямоугольника (все изображение в примере 128*97)
$x1=50;
$y1=5;

//нижняя правая точка прямоугольника (все изображение в примере 128*97)
$x2=125;
$y2=20;

//степень прозрачности прямоугольника
$DARKNESS=100;

//цвет прямоугольника
$dark = imagecolorallocatealpha($img, 0, 0, 0, $DARKNESS);

//рисуем прямоугольник
imagefilledrectangle($img,$x1,$y1,$x2,$y2,$dark);

//цвет надписи (белый)
$white=imagecolorallocate($img,255,255,255);

//координаты надписи (где-то в прямоугольнике ;) )
$x=55;
$y=10;

//рисуем надпись
imagestring($img,1,$x,$y,"snippets.pp.ru",$white);

//выводим и освобождаем память
imagepng($img);
imagedestroy($img);

/*
создано по материалам учебника
http://www.codenet.ru/webmast/php/gd/Rectangle.php
*/

?>
13 сентября 2007, 21:34

отправка письма с вложением (attach)

<?php
/*
*отправка письма с вложением (attach)
*автор: disable
*11.09.07
*/

$to='example@mail.ru';
$text='текст';
$thm='тема';

//файл
$path='example.txt';

$file = file_get_contents($path);

// генерируем разделитель
$boundary = "--".md5(uniqid(time()));

$headers .= "MIME-Version: 1.0\n";
$headers .="Content-Type: multipart/mixed; boundary=\"$boundary\"\n";
$multipart .= "--$boundary\n";

//кодировка
$kod = 'utf-8';
$multipart .= "Content-Type: text/plain; charset=$kod\n";
$multipart .= "Content-Transfer-Encoding: Quot-Printed\n\n";
$multipart .= "$text\n\n";

$message_part = "--$boundary\n";
$message_part .= "Content-Type: application/octet-stream\n";
$message_part .= "Content-Transfer-Encoding: base64\n";
$message_part .= "Content-Disposition: attachment; filename = \"$path\"\n\n";
$message_part .= chunk_split(base64_encode($file))."\n";
$multipart .= $message_part."--$boundary--\n";

if(!mail($to, $thm, $multipart, $headers))
{
    exit("К сожалению, письмо не отправлено");
}

?>
11 сентября 2007, 23:08

опрелеление текущего курса доллара и евро

<?php
/*
*Опрелеление текущего курса доллара и евро
*взято из книги "Головоломки на PHP для хакера
*10.09.07
*
*/
// Ссылка на XML-файл
$url = "http://www.cbr.ru/scripts/XML_daily.asp?date_req=".date("d/m/Y");
// Загружаем файл
$content = file_get_contents($url);
// Регулярное выражение
$pattern = "|<valute id=\"([^\"]+)\">[\s]*<NumCode>([^<]+)</NumCode>[\s]*<CharCode>([^<]+)</CharCode>[\s]*<Nominal>([^<]+)</Nominal>[\s]*<Name>([^<]+)</Name>[\s]*<Value>([^<]+)</Value>[\s]*</Valute>|is";
preg_match_all($pattern, $content, $out);
for($i = 0; $i < count($out[1]); $i++)
{
    $out[6][$i] = str_replace(",",".",$out[6][$i]);
    if($out[3][$i] == "USD") echo "Доллар - ".sprintf("%3.2f",$out[6][$i]/$out[4][$i])."<br>";
    if($out[3][$i] == "EUR") echo "Евро - ".sprintf("%3.2f",$out[6][$i]/$out[4][$i])."<br>";
}
?>
10 сентября 2007, 16:59

получение страницы по https через socket

<?php
/*
*получение страницы по https через socket
*автор: disable
*09.09.07
*/

//хостинг должен поддерживать ssl соединение!

$sock = fsockopen("ssl://security.webmoney.ru", 443, $errno, $errstr, 30);
if (!$sock) die("$errstr ($errno)\n");

fputs($sock, "GET /asp/default.asp HTTP/1.0\r\n");
fputs($sock, "Host: security.webmoney.ru\r\n");
fputs($sock, "Accept: */*\r\n");
fputs($sock, "\r\n");

$headers = "";

while ($str = trim(fgets($sock, 4096)))
$headers .= "$str\n";

$body = "";

while (!feof($sock))
$body.= fgets($sock, 4096);
fclose($sock);

echo '<div>'.$headers.'</div>';
echo '<div>'.$body.'<div>';

//как видим, отличий не много.

?>
9 сентября 2007, 12:31

выяснение адресов почтовых ретрансляторов

<?php  
/*
*Выяснение адресов почтовых ретрансляторов
*взято из книги
* "Головоломки на PHP для хакера
*07.09.07
*/

$email="example@mail.ru";

$host = strtok($email,'@');
getmxrr($host, $mxhostsarr, $weight);
echo "На $email письма могут отправляться через следующие хосты:<br />";
for ($i=0; $i < count($mxhostsarr); $i++)
{
    echo ("$mxhostsarr[$i] (приоритет: $weight[$i])<br />");
}
?>
7 сентября 2007, 19:28

получение письма по протоколу pop3

<?php
/*
*получение письма по протоколу pop3
*автор: disable
*07.09.07
*/

//задаем форматированный вывод, чтобы удобнее было читать ответы по строкам
echo '<pre>';

$login='example@mail.ru';
$pass='*******';

//подключаемся к серверу
$f=fsockopen('pop.mail.ru',110,$errno,$errstr,10);
if(!$f)
{
    die("Не удается подключиться к pop.mail.ru: [$errno] $errstr");
}

/*
*читаем статус ответа, он может быть либо +OK, либо -ERR
*/
echo $s=fgets($f);
if (strpos($s,'+OK')!==0) die('ошибка подключения');

//авторизируемся, для этого надо отправить имя пользователя
fwrite($f,"USER $login\r\n");

//отправляем пароль
fwrite($f,"PASS $pass\r\n");

echo $s=fgets($f);

/*
*если авторизация успешна, то сервер выбросит сколько писем в ящике,
*иначе будет ошибка авторизации
*/
echo $s=fgets($f);
if (strpos($s,'+OK')!==0) die('ошибка авторизации');

//для примера получим первое сообщение командой TOP 1 1000(если задать много строк, то возвратится все сообщение.
// Для получения сообщения целиком можно также воспользоваться командой RETR 1, в данном случаи, если сообщение короче 1000 строк это тоже самое) 
//сначала будут идти заголовки, потом пуcтая строка \r\n, потом само сообщение
//многострочные ответы почтовый сервер завершает строкой .\r\n

//посылка команды
fwrite($f,"TOP 1 1000\r\n");

$msg='';
$head='';

//чтение ответа
while (false!==($s=fgets($f)))
{
    //строка .\r\n данные закончились
    if ($s===".\r\n") break;

    //строка \r\n, заголовки закончились
    if ($s=="\r\n" && !$msg)
    $msg=' ';

    if (!$msg) $head.=$s;
    else $msg.=$s;
}

//выводим сообщение и заголовки
echo trim($head);
echo "\n\n---конец заголовков---\n\n";
echo trim($msg);

?>
7 сентября 2007, 19:08

pop3 авторизация

<?php
/*
*pop3 авторизация и получение информации о количесве писем в ящике
*автор: disable
*07.09.07
*/

$login='example@mail.ru';
$pass='*****';

//подключаемся к серверу
$f=fsockopen('pop.mail.ru',110,$errno,$errstr,10);
if(!$f)
{
    die("Не удается подключиться к pop.mail.ru: [$errno] $errstr");
}

/*
*читаем статус ответа, он может быть либо +OK, либо -ERR
*/
echo $s=fgets($f).'<br />';
if (strpos($s,'+OK')!==0) die('ошибка подключения');

//авторизируемся, для этого надо отправить имя пользователя
fwrite($f,"USER $login\r\n");

//отправляем пароль
fwrite($f,"PASS $pass\r\n");

echo $s=fgets($f).'<br />';

/*
*если авторизация успешна, то сервер выбросит сколько писем в ящике, 
*иначе будет ошибка авторизации
*/
echo $s=fgets($f).'<br />--<br />';
if (strpos($s,'+OK')!==0) die('ошибка авторизации');

//определим, сколько же у нас новых писем
preg_match('|maildrop has (\d+) messages \((\d+) octets\)|',$s,$num);
$messages=$num[1];
$octets=$num[2];

echo "в ящике писем: $messages<br />
общий размер: $octets байт";

?>
7 сентября 2007, 17:50

Функция перекодировки utf-8 в windows-1251

<?php
/*
*Функция перекодировки utf-8 -> windows-1251
*автор: PHPInside №8
*30.08.07
*/

function utf8win1251($s){
    $out = $c1 = "";
    $byte2=false;
    for ($c=0;$c<strlen($s);$c++){
        $i=ord($s[$c]);
        if ($i<=127) $out.=$s[$c];
        if ($byte2){
            $new_c2=($c1&3)*64+($i&63);
            $new_c1=($c1>>2)&5;
            $new_i=$new_c1*256+$new_c2;
            if ($new_i==1025){ $out_i=168; }
            else{
                if ($new_i==1105){
                    $out_i=184; }
                    else {
                        $out_i=$new_i-848;
                    }
            }
            $out.=chr($out_i);
            $byte2=false;
        }
        if (($i>>5)==6) {
            $c1=$i;
            $byte2=true;
        }
    }
    return $out;
}

//пример
echo utf8win1251('текст в utf-8');
?>
31 августа 2007, 12:29

Функция перекодировки windows-1251 в utf-8

<?php
/*
*Функция перекодировки windows-1251 -> utf-8
*автор: ?
*31.08.07
*/

function win2utf($str)
{
    static $table = array(
    "\xA8" => "\xD0\x81",
    "\xB8" => "\xD1\x91",
    "\xA1" => "\xD0\x8E",
    "\xA2" => "\xD1\x9E",
    "\xAA" => "\xD0\x84",
    "\xAF" => "\xD0\x87",
    "\xB2" => "\xD0\x86",
    "\xB3" => "\xD1\x96",
    "\xBA" => "\xD1\x94",
    "\xBF" => "\xD1\x97",
    "\x8C" => "\xD3\x90",
    "\x8D" => "\xD3\x96",
    "\x8E" => "\xD2\xAA",
    "\x8F" => "\xD3\xB2",
    "\x9C" => "\xD3\x91",
    "\x9D" => "\xD3\x97",
    "\x9E" => "\xD2\xAB",
    "\x9F" => "\xD3\xB3",
    );
    return preg_replace('#[\x80-\xFF]#se',
    ' "$0" >= "\xF0" ? "\xD1".chr(ord("$0")-0x70) :
                       ("$0" >= "\xC0" ? "\xD0".chr(ord("$0")-0x30) :
                        (isset($table["$0"]) ? $table["$0"] : "")
                       )',
    $str
    );
}

//пример
echo win2utf('тест в windows-1251');
?>
31 августа 2007, 12:29

загрузка нескольких файлов на сервер (upload)

<?php
/*
*Загрузка нескольких файлов на сервер (upload)
*автор: nc_soft
*29.08.07
*/

//соответственно состоит из формы и обработчика
if (isset($_FILES))
{
    foreach ($_FILES['file']['name'] as $k=>$v)
    {
        if (move_uploaded_file($_FILES['file']['tmp_name'][$k],'./'.$v))
        {
            echo 'файл загружен в папку скрипта, этот пример создан лишь для демонстративных целей, потому что
            он не проверяет сами файлы, а сохраняет их в том же виде, как и при отправке.<br />';
        }
    }
}

//ну и сама форма для загрузки, обратите внимание на name="file[]"
?>
<form action="upload.php" method="post" enctype="multipart/form-data">
<input name="file[]" type="file" /><br />
<input name="file[]" type="file" /><br />
<input name="file[]" type="file" /><br />
<input type="submit" value="Upload" />
</form>
29 августа 2007, 01:14

GET запрос при помощи file_get_contents

<?php
/*
*GET запрос с посылкой http заголовков при помощи file_get_contents
*автор: nc_soft
*29.08.07
*/

/*задать необходимые заголовки можно в массиве http, для примера посланы 2 заголовка
User-Agent и Connection
*/

//заздаем контекст :)
$context = stream_context_create(
array(
        'http'=>array(
                        'header' => "User-Agent: Brauzer 2/0\r\nConnection: Close\r\n\r\n"
                     )
    )
);

$contents = file_get_contents("http://wen.ru", false ,$context);
echo $contents;
?>
28 августа 2007, 15:16

POST запрос при помощи file_get_contents

<?php
/*
*POST запрос при помощи file_get_contents
*автор: nc_soft
*29.08.07
*/

/*задать необходимые заголовки можно в массиве http, для примера посланы 2 заголовка
User-Agent и Connection
*/

//строка с POST данными
$data='a=1&b=2';

//задаем контекст
$context = stream_context_create(
array(
        'http'=>array(
                        'header' => "User-Agent: Brauzer 2/0\r\nConnection: Close\r\n\r\n",
                        'method' => 'POST',
                        'content' => $data                
                     )
    )
);

$contents = file_get_contents("http://wen.ru", false ,$context);
echo $contents;
?>
28 августа 2007, 15:16

upload файла на удаленный сервер через socket

<?php
/*
*Upload файла на удаленный сервер через socket
*автор: nc_soft
*28.08.07
*/

//генерация разделителя
$boundary = md5(time());

//отправляем файл (например example.jar )

//имя пересылаемого файла
$file_name = 'example.jar';

//MIME тип пересылаемого файла
$application = 'application/java-archive';

//запись в переменную
$bufer = file_get_contents('./example.jar');

$form_file_name = 'file1'; //это имя у поля формы <input type="file" name="******">

//формируем тело запроса
$post_str = '';
$post_str .= "--$boundary\r\n";
$post_str .= "Content-Disposition: form-data; name=\"$form_file_name\"; filename=\"$file_name\"\r\n";
$post_str .= "Content-Type: $application\r\n";
$post_str .= "Content-Transfer-Encoding: binary\r\n\r\n";
$post_str .= "$bufer\r\n";
$post_str .= "--$boundary--\r\n";


//сайт
$host = 'site.ru';

//обработчик формы
$path = 'handler.php';

//открываем сокет
$fp = @fsockopen("tcp://".$host, 80, $errno, $errstr, 10);
if (!$fp)
{
    die($errstr.':'.$errno);
}
else
{
    $header  = "POST $path HTTP/1.0\r\n";
    $header .= "Host: $host\r\n";
    
    //указываем что это пост данные с вложенным файлом
    $header .= "Content-Type: multipart/form-data; boundary=$boundary\r\n";
    $header .= "Content-Length: ".strlen($post_str)."\r\n\r\n";

    //посылаем данные
    fwrite($fp, $header.$post_str);

    $headers='';

    //читаем заголовки
    while ($str = trim(fgets($fp, 4096)))
    $headers .= "$str\n";

    $body='';

    //читаем ответ
    while (!feof($fp))
    $body.= fgets($fp, 4096);

    //закрываем сокет
    fclose($fp);
}

//выводим данные
echo $headers.'<hr/>'.$body;

?>
28 августа 2007, 12:16

upload файла на kmx.ru при помощи socket

<?php
/*
*Upload файла на kmx.ru через socket
*автор: nc_soft
*28.08.07
*/

/*для uploada нам потребуется изучить структуру форм и заголовки по адресу
http://wap.kmx.ru/upload
после изучения страницы можно заметить, что чтобы попасть на форму с аплоадом,
необходимо всего лишь послать такую куку
uploadkey=284891272; expires=Thu, 31-Dec-2009 21:00:00 GMT
(где цифры как вы правильно догадались это секретный ключ), далее изучаем саму форму и
приходим к выводу, что необходимо послать следующие данные:
dir (имя директории в которую сохранить)
file1 (первый файл)
file2 (второй файл) итд*/

//имя директории в которую грузим
$dir='/';

//имя пересылаемого файла
$file_name = 'example.jar';

//MIME тип пересылаемого файла
$application = 'application/java-archive';

//запись файла в переменную
$bufer = file_get_contents('./example.jar');

//имя поля формы для файла
$form_file_name = 'file1';

//генерация разделителя
$boundary = md5(time());

//формируем POST данные
$post_str = '';
$post_str .= "--$boundary\r\n";
$post_str .="Content-Disposition: form-data; name=\"dir\"\r\n\r\n"; 
$post_str .= "$dir\r\n";

//формируем отправку файла
$post_str .= "--$boundary\r\n";
$post_str .= "Content-Disposition: form-data; name=\"$form_file_name\"; filename=\"$file_name\"\r\n";
$post_str .= "Content-Type: $application\r\n";
$post_str .= "Content-Transfer-Encoding: binary\r\n\r\n";
$post_str .= "$bufer\r\n";
$post_str .= "--$boundary--\r\n";


//сайт
$host='wap.kmx.ru';

//обработчик формы
$path='/upload';

//открываем сокет
$fp = @fsockopen("tcp://".$host, 80, $errno, $errstr, 10);
if (!$fp)
{
    die($errstr.':'.$errno);
}
else
{
    $header  = "POST $path HTTP/1.0\r\n";
    $header .= "Host: $host\r\n";
    
    //подделываем  кукис
    $header .= "Cookie: uploadkey=284891272; expires=Thu, 31-Dec-2009 21:00:00 GMT\r\n";
    
    //указываем что это пост данные с вложенным файлом
    $header .= "Content-Type: multipart/form-data; boundary=$boundary\r\n";
    $header .= "Content-Length: ".strlen($post_str)."\r\n\r\n";

    //посылаем данные
    fwrite($fp, $header.$post_str);

    $headers='';

    //читаем заголовки
    while ($str = trim(fgets($fp, 4096)))
    $headers .= "$str\n";

    $body='';

    //читаем ответ
    while (!feof($fp))
    $body.= fgets($fp, 4096);

    //закрываем сокет
    fclose($fp);
}

//выводим данные
echo $headers.'<hr/>'.$body;

?>
28 августа 2007, 12:16

upload файла на kmx.ru при помощи CURL

<?php
/*
*Upload файла на kmx.ru при помощи CURL
*автор: nc_soft
*28.08.07
*/

/*подготовим данные для отправки
dir директория куда сохраняем
file1 файл1
file2 файл2 итд
*/

$params = array(
'dir'=>'/',
'file1' => '@z:/home/snippets/www/articles/http/example.jar'
);

/*обратите внимание, что путь к файлу необходимо указать абсолютный,
его можно сформировать и так $_SERVER['DOCUMENT_ROOT'].'/example.jar'
также необходимо поставить @ перед адресом файла
*/

//инициализируем сеанс cURL
$ch = curl_init();

//задаем адрес
curl_setopt ($ch, CURLOPT_URL, 'http://wap.kmx.ru/upload');

//устанавливаем кукис (если необходимо)
curl_setopt($ch,CURLOPT_COOKIE,'uploadkey=284891272; expires=Thu, 31-Dec-2009 21:00:00 GMT');

//указываем что это POST данные
curl_setopt ($ch, CURLOPT_POST, 1);

//отправляем POST запрос
curl_setopt ($ch, CURLOPT_POSTFIELDS, $params);

//выводим данные в переменную
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);

$buf = curl_exec($ch);

//закрываем CURL
curl_close($ch);

//выводим результат
echo $buf;
?>
28 августа 2007, 12:15

перекодировка из hex-unicode

<?php
/*
*перекодировка из hex-unicode
*автор: nc_soft
*28.08.07
*/

//в переменную s добавляется строка для перевода
//пара символов для теста:
$s='АБВ';

//регулярное выражение
$s=preg_replace_callback("|&#x(.{3});|is","unicode2win",$s);

//вывод обрабатываемой строки в кодировке виндовс-1251
echo $s;

//функция обратного вызова для обработки
function unicode2win($val)
{
    $val=hexdec($val[1]);
    if ($val==401) return "Ё";
    if ($val==451) return "ё";
    return chr($val-848);
}
?>
28 августа 2007, 07:39

создание таблицы в mysql

<?php
/*
*создание таблицы в БД
*автор: nc_soft
*25.08.07
*/

//подключаем файл конфигурации
require_once('mysql.php');

/*формируем запрос
*таблица будет состоять всего из 2 полей,
*(имя юзера и ключа)
*кодировку установим utf-8
*/

$q="CREATE TABLE `test_table` (
                        `id` INT(7) NOT NULL AUTO_INCREMENT,
                        `user` TINYTEXT NOT NULL,
                        PRIMARY KEY (`id`) ) TYPE=MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci; ";

//выполняем запрос
if (false==mysql_query($q))
{
    //в случаи ошибки выводим информацию
    die(mysql_error());
}
else 
{
    //если нет ошибки, то запрос прошел удачно
    echo 'ok';
}

?>
26 августа 2007, 02:38

подключение к сайту через proxy с использованием socket

<?php
/*
*подключение к сайту через прокси с использованием socket
*автор: nc_soft
*25.08.07
*/

//используем прокси
$proxy='165.228.130.10';

//порт для прокси
$port='3128';

//сайт
$host='wen.ru';

//запрашиваемая страница
$path='/';

//открываем сокет
$fp = fsockopen("tcp://".$proxy, $port, $errno, $errstr, 10);
if (!$fp)
{
    die("$errstr:$errno");
}
else
{
    //формируем заголовки
    $out  = "GET http://$host$path HTTP/1.0\r\n";
    $out .= "Host: $host\r\n";
    $out .= "Connection: Close\r\n";
    $out .= "\r\n";

    //отправляем запрос
    fwrite($fp, $out);

    //читаем ответ
    while (!feof($fp))
    {
        echo fgets($fp, 1024);
    }

    //закрываем сокет
    fclose($fp);
}

/*
на момент написания snippet этот проксик работал, обычно бесплатные прокси живут не долго, 
поэтому для теста надо найти рабочий
*/

?>
26 августа 2007, 02:17