웹마스터 팁

130523 10:10  -  스팸IP 인지 조회하는 부분 조금 보완 - 기존 IP 변수에 저장해 쿼리 줄임

 

----------------------------------

 

XE 공홈에 있던 글에서 아이디어를 얻어서 기능을 만들어보았습니다.

스팸은 모든 유저가 겪는 고통이기에, 이 기능만큼은 무료로 기능 구현방법을 공개합니다

솔직히 이 팁이 Core 에 포함되었으면 하는데, 과연 포함될지는 미지수죠 ^^;;;

(사용해보시고 도움이 되시면,  XE Core Issue 쪽에 건의해보세요 ^^;  호응이 좋으면 될지도)

 

관리자페이지 -> 회원목록 에서 회원을 선택해서 삭제할 경우

일반삭제는 그냥 회원정보만 삭제되고 기존글/댓글이 유지되지만.

'스팸처리' 를 눌러서 삭제하면,  회원정보가 삭제 되면서 동시에 그 회원이 쓴 모든 글 / 모든 댓글 도 같이 삭제되며. 또한 해당 글/댓글의  IP 주소를 스팸필터에 자동등록하게 하는 기능이 포함되어있습니다..

 

처음에는 지금 만든기능을 트리거화 하려했는데, 일반회원의 탈퇴나 삭제시 관련글들이 다 지워지면 안 되니.

결국 Core 업데이트될때마다 재수정을 해시는 방법밖에 없지만,  수정량이 많은건 아니니 스팸에 시달리는 것보다는 낫겠죠?

 

스팸처리 기능 관련 문의사항은..

http://sejin7940.co.kr/index.php?mid=sejin7940_works&category=92002&page=1    에 남겨주세요.

 

 

수정방법은 아래에 기록해둡니다.

XE 1.5 와 XE 1.7 이 조금 다릅니다.  1번은 버전에 따라 수정법이 다르고,  2번.3번 사항은 동일합니다.

 

혹시나의 상황을 대비해, DB는 꼭 백업을 해두고 진행하세요 ^^

 

 

1. modules/member/tpl/member_list.html 에서

 

(1) XE 1.5 기반에서 수정방법

130번째줄 부근의

<span class="btn"><button type="submit" name="type" value="delete">{$lang->cmd_delete}</button></span> 

밑에다가 추가

<span class="btn"><button type="submit" name="type" value="spam">스팸처리</button></span>

 


(2) XE 1.7 기반에서 수정방법

1)
<a href="#listManager" data-value="delete" class="modalAnchor _member x_btn">{$lang->delete}</a>  아래에다가 추가 (2군데 있음. 26번째줄과 105번째줄

부근)

<a href="#listManager" data-value="spam" class="modalAnchor _member x_btn">스팸처리</a>


2)
166번째 줄 부근의

<button type="submit" name="type" value="modify|delete" class="x_btn x_btn-inverse">{$lang->confirm}</button>

를 아래걸로 교체

<button type="submit" name="type" value="modify|delete|spam" class="x_btn x_btn-inverse">{$lang->confirm}</button>

 

 

이후에 기술할 2. 3. 은   XE 1.5 와 XE 1.7 모두 동일함


2. modules/member/member.admin.controller.php 에서

function procMemberAdminSelectedMemberManage() 함수 내부에


case 'delete':{  위에다가 추가


    
     case 'spam':{   // sejin7940 스팸회원 삭제 위해
      $output = $this->sejin7940_spamMember($member_srl);
      if(!$output->toBool()) {
       $oDB->rollback();
       return $output;
      }
      break;
     }

 

 

3. modules/member/member.admin.controller.php  에서

제일 끝에 함수 하나 추가  (제일 끝이란 끝부분의  } ?>  위를 말합니다)

 

 
  //  sejin7940 - 스팸회원 삭제/ 관련 글/ 관련 댓글 자동 삭제 및 IP 스팸등록 기능
  function sejin7940_spamMember($member_srl) {
   // 스팸 유저가 쓴 모든 글 자동 삭제
   $oDocumentModel = &getModel('document');
   $oDocumentController = &getController('document');
   $obj->member_srl = $member_srl;
   $obj->list_count = '99999999999';
   
   $columnList = array('document_srl','ipaddress');
   $document_list = $oDocumentModel->getDocumentList($obj,false,true,$columnList);
   foreach($document_list->data as $key_document => $val_document) {

    // 회원 IP 스팸에 등록
    $args_spam->ipaddress = $val_document->get('ipaddress');
    if($args_spam->ipaddress &&  ($ipaddress_bk != $args_spam->ipaddress )) {
     $output_spam = executeQuery('spamfilter.isDeniedIP', $args_spam);
     if(!$output_spam->data->count) {
      $ipaddress_bk = $args_spam->ipaddress;
      executeQuery('spamfilter.insertDeniedIP', $args_spam);
     }
    }
    // 글 삭제
    $oDocumentController->deleteDocument($val_document->document_srl);
   }

   // 스팸 유저가 쓴 모든 댓글 자동 삭제
   $oCommentModel = &getModel('comment');
   $obj->search_target = 'member_srl';
   $obj->search_keyword = $member_srl;
   $comment_list = $oCommentModel->getTotalCommentList($obj);
   $oCommentController = &getController('comment');
   foreach($comment_list->data as $key_comment => $val_comment) {
    // 회원 IP 스팸에 등록
    $args_spam->ipaddress = $val_comment->get('ipaddress');
    if($args_spam->ipaddress &&  ($ipaddress_bk != $args_spam->ipaddress )) {
     $output_spam = executeQuery('spamfilter.isDeniedIP', $args_spam);
     if(!$output_spam->data->count) {
      $ipaddress_bk = $args_spam->ipaddress;
      executeQuery('spamfilter.insertDeniedIP', $args_spam);
     }
    }
    $oCommentController->deleteComment($val_comment->comment_srl);
   }

   // 회원정보 삭제
   $oMemberController = &getController('member');   
   $oMemberController->memberInfo = null;
   $oMemberController = &getController('member');
          $output = $oMemberController->deleteMember($obj->member_srl);
                 if(!$output->toBool()) return $output;

   return $output;
  }


 

ps. 한줄 광고

XE 기반의 사이트 제작이나  기능제작등을 원하시면 ^^

XE 전문제작자 에게 맡겨보세요   =>   http://sejin7940.co.kr/index.php?mid=order_qna 

제목 글쓴이 날짜
회원이 글 삭제하면 삭제하지 않고 글을 다른 게시판으로 보내기 [5] SCAC 2012.07.03
FTP로 폴더가 삭제가 안될때~! [6] file 웹엔진 2012.01.30
에디터에서 URL 클릭시 "http://" 삭제하는 방법 [2] 콜롬보. 2015.03.13
[공유]게시물 자동삭제 애드온 (Made by 송동우) [11] file 시릐우스 2012.09.11
게시글을 삭제하면 해당 글 내부에 첨부된 첨부파일이 서버에서 사라지지 않는 버그 수정법 [6] sejin7940 2015.01.05
화일첨부 디렉토리의 빈 폴더 삭제... [13] 카르마 2012.01.20
phpmyadmin 설치뒤 setup 스크립트는 삭제해야 [1] YJSoft 2014.11.12
파일 삭제시 (글 수정시 파일삭제 / 파일관리에서 삭제 등) 사용자정의값이 삭제되지 않도록 패치 [3] sejin7940 2014.12.11
파일첨부 된 글을 게시글 이동시, 사용자정의 값이 전부 삭제되는 버그 패치 [5] sejin7940 2014.11.20
업글타일 모듈에서 fail_to_trash가 뜨지만 삭제는 정상으로 진행된다면 SeungXE 2014.10.11
댓글 삭제/수정/답글 시 팝업창으로 띄우기 [22] file 고진감래 2009.10.21
관리자설정-> 관리자 메뉴설정 에서 삭제가 안 되는 현상 수정하는 방법 [1] sejin7940 2014.08.11
MySQL Replication 사용중 Binary Log 삭제 하기 박희망찬삶 2014.07.29
스팸 회원 삭제시 동시에 관련 글 / 댓글 자동 삭제 + 스팸IP 등록기능 구현방법입니다 [20] sejin7940 2013.05.22
회원가입폼 비밀번호 찾기 질문/답변 삭제및 필수항목 선택 (송동우님 팁) [8] 때린데 또때려 2012.04.09
중복레코드 검색 및 삭제 ByteCMC 2014.02.10
[수정] 댓글 삭제 간략화하기 [9] XE만세 2013.11.26
스케치북5 sns버튼에서 요즘 삭제하기 [6] 도라미 2013.07.07
IE7에서 관리자페이지->콘텐츠->문서 에서 일괄 삭제/이동/복사 등이 안 되는 경우 [1] sejin7940 2012.07.12
SSL 환경에서 메시지톡 쪽지 보내기, 친구 찾기, 메시지 삭제 등 안될 때 [2] Arisae 2013.09.02