자동글 방지 팁입니다.

· 17년 전 · 1873

우선 메인에서
session_start();
$main_page="y";
session_register("main_page");
이런식으로 세션을 하나 만듭니다.

그리고 deny_invalid.php 라는 파일을 만들어서 모든 페이지들이 이 파일을 포함시키도록 합니다.
그리고 파일내용에 다음과 같이 부정 접속자를 걸려내서 차단목록을 작성하도록 만듭니다.

<?
session_start();

$SERVER_ROOT=$_SERVER["DOCUMENT_ROOT"];
$REMOTE_ADDR=$_SERVER["REMOTE_ADDR"];
$REQUEST_URI=$_SERVER["REQUEST_URI"];

//echo $REMOTE_ADDR;

/** 메인페이지를 통해서 들어오도록 강요 **/
if($HTTP_SESSION_VARS['main_page']!="y"){ exit; }

/** 허용 클라이언트인지 검사 **/
$is_admin=false;
if(in_array($REMOTE_ADDR,array("119.66.185.XX"))){ $is_admin=true;return true; }

/** 거부 클라이언트인지 검사 **/
$deny_list=implode(",",file("$SERVER_ROOT/deny.list"));
if(strpos($deny_list,$REMOTE_ADDR)!==false){ header("HTTP/1.1 403 Forbidden");exit; }

/** 불량 접속자인지 검사 **/
function add_bad_client($detail){
 global $SERVER_ROOT;
 global $REMOTE_ADDR;
 $fp=fopen("$SERVER_ROOT/XX.list","a+");
 fwrite($fp,"[".date("Y-m-d H:i:s",time())."] $REMOTE_ADDR ".$detail."\r\n");
 fclose($fp);
 header("HTTP/1.1 403 Forbidden");
}

list($usec, $sec) = explode(" ",microtime());
$access_time=((float)$usec+(float)substr($sec,7));

$access_table=$HTTP_SESSION_VARS['access_table'];
$access_table[$REQUEST_URI]["call"]++;
$access_table[$REQUEST_URI]["time"][]=$access_time;
session_register("access_table");

 /**
 특정페이지의 호출 횟수가 비이상적으로 많은 경우
 불량 접속자로 처리한다.
 **/
[로직부분]

 /**
 페이지를 호출하는 간격이 너무 빠른 경우
 불량 접속자로 처리한다.
 **/
 [로직부분]

?>

[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
17년 전 조회 1,906
17년 전 조회 2,592
17년 전 조회 1,301
17년 전 조회 3,178
17년 전 조회 2,160
17년 전 조회 2,603
17년 전 조회 1,404
17년 전 조회 1,754
17년 전 조회 1,150
17년 전 조회 1,205
17년 전 조회 1,778
17년 전 조회 1,224
17년 전 조회 4,304
17년 전 조회 1,500
17년 전 조회 2,002
17년 전 조회 7,089
17년 전 조회 1,378
17년 전 조회 1,895
17년 전 조회 3,125
17년 전 조회 1,223
17년 전 조회 1,982
17년 전 조회 1,154
17년 전 조회 1,852
17년 전 조회 2,150
17년 전 조회 2,961
17년 전 조회 1,240
17년 전 조회 1,329
17년 전 조회 1,556
17년 전 조회 1,223
17년 전 조회 4,355
17년 전 조회 3,898
17년 전 조회 2,786
17년 전 조회 1,589
17년 전 조회 1,335
17년 전 조회 1,602
17년 전 조회 2,519
17년 전 조회 1,733
17년 전 조회 2,017
17년 전 조회 1,305
17년 전 조회 1,039
17년 전 조회 1,120
17년 전 조회 2,923
17년 전 조회 2,460
17년 전 조회 2,041
17년 전 조회 2,042
17년 전 조회 1,794
17년 전 조회 2,240
17년 전 조회 2,013
17년 전 조회 1,986
17년 전 조회 1,874
17년 전 조회 1,209
17년 전 조회 1,825
17년 전 조회 2,228
17년 전 조회 2,300
17년 전 조회 1,638
17년 전 조회 1,509
17년 전 조회 1,356
17년 전 조회 2,576
17년 전 조회 2,671
17년 전 조회 2,068
17년 전 조회 2,414
17년 전 조회 2,720
17년 전 조회 1,322
17년 전 조회 1,188
17년 전 조회 6,322
17년 전 조회 1,173
17년 전 조회 1,624
17년 전 조회 1,774
17년 전 조회 1,097
17년 전 조회 1,190
17년 전 조회 1,890
17년 전 조회 1,520
17년 전 조회 3,618
17년 전 조회 1,204
17년 전 조회 1,908
17년 전 조회 1,166
17년 전 조회 1,381
17년 전 조회 2,360
17년 전 조회 2,013
17년 전 조회 1,035
17년 전 조회 1,038
17년 전 조회 1,090
17년 전 조회 6,045
17년 전 조회 5,850
17년 전 조회 2,025
17년 전 조회 1,021
17년 전 조회 1,118
17년 전 조회 2,080
17년 전 조회 1,511
17년 전 조회 1,157
17년 전 조회 1,184
17년 전 조회 1,127
17년 전 조회 1,042
17년 전 조회 3,957
17년 전 조회 2,164
17년 전 조회 1,618
17년 전 조회 2,764
17년 전 조회 1,467
17년 전 조회 1,151
17년 전 조회 1,173
🐛 버그신고