Курс 2016 года “Разработка на UMI.CMS от 0 до готового сайта”
Автоматическая смена справочника в поле объекта каталога

Автор bosyaРаздел Настройка системы и модулей

Ответов: 5
Просмотров: 3580
Последний ответ 30 Июня 2012, 11:33:43
от hnika206
Смена последовательности фильтруемых параметрах в фильтре XSLT

Автор shotoРаздел Шаблоны XSLT

Ответов: 4
Просмотров: 2967
Последний ответ 02 Августа 2012, 17:15:33
от admin
Смена доменного имени с localhost на приемлемый вариант.

Автор SeweryssРаздел Настройка системы и модулей

Ответов: 3
Просмотров: 2594
Последний ответ 13 Ноября 2013, 20:00:12
от Seweryss
Смена шагов оформления заказа на этапе delivery

Автор webtrendРаздел Шаблоны XSLT

Ответов: 4
Просмотров: 1460
Последний ответ 10 Апреля 2016, 20:48:25
от webtrend
Смена технического домена на нормальтный.

Автор akarihРаздел Настройка системы и модулей

Ответов: 2
Просмотров: 3673
Последний ответ 14 Декабря 2011, 21:31:26
от akarih

0 Пользователей и 1 Гость просматривают эту тему.

*

HardHardy

  • **
  • 74
  • +1/-0
    • Просмотр профиля
    • Фортис
Смена Каптчи
« : 18 Октября 2011, 16:26:35 »
Здравствуйте!
В категории решения проблем и ошибок Юмикмс есть вот такое решение по смене каптчи:
http://wiki.umisoft.ru/%D0%A1%D0%BC%D0%B5%D0%BD%D0%B0_%D0%BA%D0%B0%D0%BF%D1%82%D1%87%D0%B8

Просьба пояснить для не столь одаренных
Цитировать
Далее мы немного модифицируем сам класс каптчи /kcaptcha/kcaptcha.php Добавим две приватные переменные:
private $img_captch;
private $jpeg_quality;

Уберём вывод каптчи из основного метода
header('Expires: Mon, 26 Jul 1997 05:00:00 GMT');
header('Cache-Control: no-store, no-cache, must-revalidate');
header('Cache-Control: post-check=0, pre-check=0', FALSE);
header('Pragma: no-cache');
 
if(function_exists("imagejpeg")){
   header("Content-Type: image/jpeg");
   imagejpeg($img2, null, $jpeg_quality);
}else if(function_exists("imagegif")){
   header("Content-Type: image/gif");
   imagegif($img2);
}else if(function_exists("imagepng")){
   header("Content-Type: image/x-png");
   imagepng($img2);
}

и заменим на
$this->img_captch = $img2;
$this->jpeg_quality = $jpeg_quality;

Пишем метод для вывода каптчи
public function getImageCaptcha()
{
   if(function_exists("imagejpeg")){
      header("Content-Type: image/jpeg");
      imagejpeg($this->img_captch, null, $this->jpeg_quality);
   }else if(function_exists("imagegif")){
      header("Content-Type: image/gif");
      imagegif($this->img_captch);
   }else if(function_exists("imagepng")){
      header("Content-Type: image/x-png");
      imagepng($this->img_captch);
   }
}

Я так понял все эти изменения производятся в файле /kcaptcha/kcaptcha.php
Но в каких строчках записывать приватные переменные и метод для вывода каптчи??
если не будет трудно, просьба вывести откорректированный пример /kcaptcha/kcaptcha.php

*

HardHardy

  • **
  • 74
  • +1/-0
    • Просмотр профиля
    • Фортис
Re:Смена Каптчи
« Ответ #1 : 19 Октября 2011, 13:03:52 »
Вот исходный код /kcaptcha/kcaptcha.php
class KCAPTCHA{

// generates keystring and image
function KCAPTCHA(){

require(dirname(__FILE__).'/kcaptcha_config.php');
$fonts=array();
$fontsdir_absolute=dirname(__FILE__).'/'.$fontsdir;
if ($handle = opendir($fontsdir_absolute)) {
while (false !== ($file = readdir($handle))) {
if (preg_match('/\.png$/i', $file)) {
$fonts[]=$fontsdir_absolute.'/'.$file;
}
}
    closedir($handle);
}

$alphabet_length=strlen($alphabet);

do{
// generating random keystring
while(true){
$this->keystring='';
for($i=0;$i<$length;$i++){
$this->keystring.=$allowed_symbols{mt_rand(0,strlen($allowed_symbols)-1)};
}
if(!preg_match('/cp|cb|ck|c6|c9|rn|rm|mm|co|do|cl|db|qp|qb|dp|ww/', $this->keystring)) break;
}

$font_file=$fonts[mt_rand(0, count($fonts)-1)];
$font=imagecreatefrompng($font_file);
imagealphablending($font, true);

$fontfile_width=imagesx($font);
$fontfile_height=imagesy($font)-1;

$font_metrics=array();
$symbol=0;
$reading_symbol=false;

// loading font
for($i=0;$i<$fontfile_width && $symbol<$alphabet_length;$i++){
$transparent = (imagecolorat($font, $i, 0) >> 24) == 127;

if(!$reading_symbol && !$transparent){
$font_metrics[$alphabet{$symbol}]=array('start'=>$i);
$reading_symbol=true;
continue;
}

if($reading_symbol && $transparent){
$font_metrics[$alphabet{$symbol}]['end']=$i;
$reading_symbol=false;
$symbol++;
continue;
}
}

$img=imagecreatetruecolor($width, $height);
imagealphablending($img, true);
$white=imagecolorallocate($img, 255, 255, 255);
$black=imagecolorallocate($img, 0, 0, 0);

imagefilledrectangle($img, 0, 0, $width-1, $height-1, $white);

// draw text
$x=1;
$odd=mt_rand(0,1);
if($odd==0) $odd=-1;
for($i=0;$i<$length;$i++){
$m=$font_metrics[$this->keystring{$i}];

$y=(($i%2)*$fluctuation_amplitude - $fluctuation_amplitude/2)*$odd
+ mt_rand(-round($fluctuation_amplitude/3), round($fluctuation_amplitude/3))
+ ($height-$fontfile_height)/2;

if($no_spaces){
$shift=0;
if($i>0){
$shift=10000;
for($sy=3;$sy<$fontfile_height-10;$sy+=1){
for($sx=$m['start']-1;$sx<$m['end'];$sx+=1){
        $rgb=imagecolorat($font, $sx, $sy);
        $opacity=$rgb>>24;
if($opacity<127){
$left=$sx-$m['start']+$x;
$py=$sy+$y;
if($py>$height) break;
for($px=min($left,$width-1);$px>$left-200 && $px>=0;$px-=1){
        $color=imagecolorat($img, $px, $py) & 0xff;
if($color+$opacity<170){ // 170 - threshold
if($shift>$left-$px){
$shift=$left-$px;
}
break;
}
}
break;
}
}
}
if($shift==10000){
$shift=mt_rand(4,6);
}

}
}else{
$shift=1;
}
imagecopy($img, $font, $x-$shift, $y, $m['start'], 1, $m['end']-$m['start'], $fontfile_height);
$x+=$m['end']-$m['start']-$shift;
}
}while($x>=$width-10); // while not fit in canvas

//noise
$white=imagecolorallocate($font, 255, 255, 255);
$black=imagecolorallocate($font, 0, 0, 0);
for($i=0;$i<(($height-30)*$x)*$white_noise_density;$i++){
imagesetpixel($img, mt_rand(0, $x-1), mt_rand(10, $height-15), $white);
}
for($i=0;$i<(($height-30)*$x)*$black_noise_density;$i++){
imagesetpixel($img, mt_rand(0, $x-1), mt_rand(10, $height-15), $black);
}


$center=$x/2;

// credits. To remove, see configuration file
$img2=imagecreatetruecolor($width, $height+($show_credits?12:0));
$foreground=imagecolorallocate($img2, $foreground_color[0], $foreground_color[1], $foreground_color[2]);
$background=imagecolorallocate($img2, $background_color[0], $background_color[1], $background_color[2]);
imagefilledrectangle($img2, 0, 0, $width-1, $height-1, $background);
imagefilledrectangle($img2, 0, $height, $width-1, $height+12, $foreground);
$credits=empty($credits)?$_SERVER['HTTP_HOST']:$credits;
imagestring($img2, 2, $width/2-imagefontwidth(2)*strlen($credits)/2, $height-2, $credits, $background);

// periods
$rand1=mt_rand(750000,1200000)/10000000;
$rand2=mt_rand(750000,1200000)/10000000;
$rand3=mt_rand(750000,1200000)/10000000;
$rand4=mt_rand(750000,1200000)/10000000;
// phases
$rand5=mt_rand(0,31415926)/10000000;
$rand6=mt_rand(0,31415926)/10000000;
$rand7=mt_rand(0,31415926)/10000000;
$rand8=mt_rand(0,31415926)/10000000;
// amplitudes
$rand9=mt_rand(330,420)/110;
$rand10=mt_rand(330,450)/100;

//wave distortion

for($x=0;$x<$width;$x++){
for($y=0;$y<$height;$y++){
$sx=$x+(sin($x*$rand1+$rand5)+sin($y*$rand3+$rand6))*$rand9-$width/2+$center+1;
$sy=$y+(sin($x*$rand2+$rand7)+sin($y*$rand4+$rand8))*$rand10;

if($sx<0 || $sy<0 || $sx>=$width-1 || $sy>=$height-1){
continue;
}else{
$color=imagecolorat($img, $sx, $sy) & 0xFF;
$color_x=imagecolorat($img, $sx+1, $sy) & 0xFF;
$color_y=imagecolorat($img, $sx, $sy+1) & 0xFF;
$color_xy=imagecolorat($img, $sx+1, $sy+1) & 0xFF;
}

if($color==255 && $color_x==255 && $color_y==255 && $color_xy==255){
continue;
}else if($color==0 && $color_x==0 && $color_y==0 && $color_xy==0){
$newred=$foreground_color[0];
$newgreen=$foreground_color[1];
$newblue=$foreground_color[2];
}else{
$frsx=$sx-floor($sx);
$frsy=$sy-floor($sy);
$frsx1=1-$frsx;
$frsy1=1-$frsy;

$newcolor=(
$color*$frsx1*$frsy1+
$color_x*$frsx*$frsy1+
$color_y*$frsx1*$frsy+
$color_xy*$frsx*$frsy);

if($newcolor>255) $newcolor=255;
$newcolor=$newcolor/255;
$newcolor0=1-$newcolor;

$newred=$newcolor0*$foreground_color[0]+$newcolor*$background_color[0];
$newgreen=$newcolor0*$foreground_color[1]+$newcolor*$background_color[1];
$newblue=$newcolor0*$foreground_color[2]+$newcolor*$background_color[2];
}

imagesetpixel($img2, $x, $y, imagecolorallocate($img2, $newred, $newgreen, $newblue));
}
}

header('Expires: Mon, 26 Jul 1997 05:00:00 GMT');
header('Cache-Control: no-store, no-cache, must-revalidate');
header('Cache-Control: post-check=0, pre-check=0', FALSE);
header('Pragma: no-cache');
if(function_exists("imagejpeg")){
header("Content-Type: image/jpeg");
imagejpeg($img2, null, $jpeg_quality);
}else if(function_exists("imagegif")){
header("Content-Type: image/gif");
imagegif($img2);
}else if(function_exists("imagepng")){
header("Content-Type: image/x-png");
imagepng($img2);
}
}

// returns keystring
function getKeyString(){
return $this->keystring;
}
}

?>

*

HardHardy

  • **
  • 74
  • +1/-0
    • Просмотр профиля
    • Фортис
Re:Смена Каптчи
« Ответ #2 : 09 Ноября 2011, 08:24:51 »
Всем привет! :)
Чет мне так не кто и не помог. :'(
Если у кого есть готовое решение по изменению стандартной каптчи или же пояснения по приведенному выше примеру, огромная просьба помочь в этом деле! :)
Плиз.

*

sempl84

  • *
  • 8
  • +1/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #3 : 05 Декабря 2011, 12:22:11 »
Я менял каптчу в конфиг файле. просто прописываешь captcha.drawer = "kcaptcha"
та же kcaptcha получается, только ничего нигде прописывать не надо) все настройки в юми уже есть

*

HardHardy

  • **
  • 74
  • +1/-0
    • Просмотр профиля
    • Фортис

*

AllaVK

  • **
  • 64
  • +0/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #5 : 19 Декабря 2011, 12:12:20 »
Я менял каптчу в конфиг файле. просто прописываешь captcha.drawer = "kcaptcha"
та же kcaptcha получается, только ничего нигде прописывать не надо) все настройки в юми уже есть

воспользовалась этим же способом, спасибо...
посмотрим, будут через нее боты проходить или все же поменьше спама станет...

*

AllaVK

  • **
  • 64
  • +0/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #6 : 27 Января 2012, 10:45:30 »
ну я воспользовался вот этим решением http://wiki.umisoft.ru/Captcha_%D0%B8_%D0%B5%D0%B5_%D1%81%D0%BC%D0%B5%D0%BD%D0%B0_%D0%BF%D1%80%D0%B8_%D0%BA%D0%B0%D0%B6%D0%B4%D0%BE%D0%BC_%D0%BE%D0%B1%D0%BD%D0%BE%D0%B2%D0%BB%D0%B5%D0%BD%D0%B8%D0%B8_%D1%81%D1%82%D1%80%D0%B0%D0%BD%D0%B8%D1%86%D1%8B

Т.к. спам так и продолжал сыпаться (даже после замены captcha.drawer = "kcaptcha"), добавила и этот способ, проверим )

*

HardHardy

  • **
  • 74
  • +1/-0
    • Просмотр профиля
    • Фортис
Re:Смена Каптчи
« Ответ #7 : 27 Января 2012, 11:18:02 »
Т.к. спам так и продолжал сыпаться (даже после замены captcha.drawer = "kcaptcha"), добавила и этот способ, проверим )

У меня тож спам летел. Сейчас нет.

*

AllaVK

  • **
  • 64
  • +0/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #8 : 30 Января 2012, 16:20:52 »
а у меня так и не прекратился ((((
пока даже и не знаю, что еще предпринять....

*

AllaVK

  • **
  • 64
  • +0/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #9 : 13 Февраля 2012, 10:47:04 »
Доброе утро! подскажите, пожалуйста, еще какие-нибудь способы борьбы  со спамом... все перечисленные в этой теме попробовала - не помогли ((((

*

Vladimir

  • ****
  • 279
  • +48/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #10 : 14 Февраля 2012, 13:05:35 »
чисто теоретически поменять каптчу еще http://mainsource.ru/info/articles/a-57/
Хотя, смотря на это со стороны посетителя, я при виде такой каптчи вспоминаю разработчиков разными словами)

Можно попробовать снизить привлекательность форума для спамеров, закрывая ссылки в noindex и rel=nofollow
У меня это уменьшило поток спама примерно в 1,5 раза.

Можно проводить синтаксический анализ сообщений. Например, для русскоязычного форума логично предположить определенное соотношение кириллических и латинских символов;
далее, начинают разговор люди, как правило, вступительным словом на родном языке, а если сразу лепят <a href=... , то явно это спам. Отфильтрованные таким образом сообщения заполняют свою базу ip. При кажущейся ненадежности ip, как показала практика, они нечасто меняются; видимо, сайт попадает в некие списки, и дальше боты бьют по цели не задумываясь о результате.
Такая фильтрация работает у меня на форуме, за 3 дня набегает 1000 отфильтрованых комментариев.
Для контроля, конечно, следует просматривать логи хотя бы на первых порах.

*

AllaVK

  • **
  • 64
  • +0/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #11 : 14 Февраля 2012, 17:20:32 »
Vladimir, спасибо большое за ответ!
попробую закрыть ссылки с отправкой сообщений в noindex и rel=nofollow, за несколько дней станет понятно, помогло или нет...
и потом попробую заменить каптчу на двухсловную...
P.S.: у меня спам идет не в форумах, а при отправке сообщений на почту через модуль "Обратная связь"...

*

Vladimir

  • ****
  • 279
  • +48/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #12 : 14 Февраля 2012, 19:42:20 »
ах обратная связь!
А посмотрите тогда с какого ip? Может, достаточно будет всю их подсеть заблокировать. Нормальный человек слать спам на почту не будет, явно это робот, который спутал вашу форму с форумом. Заблокировать его прямо в htaccess, получив несколько дней в ответ на обращение к сайту 403 ошибку есть шанс, что владельцы вычеркнут вас из списков.
Однажды такой ход у меня прошел. (Правда, у меня и опыт мизерный)

*

AllaVK

  • **
  • 64
  • +0/-0
    • Просмотр профиля
Re:Смена Каптчи
« Ответ #13 : 15 Февраля 2012, 12:25:33 »
Vladimir, спасибо еще раз! добавила в текст письма еще и IP отправителя... будем отслеживать. Пишет действительно не человек, а робот, тк приходит просто набор букв...