회원가입아이디/비번찾기
홈으로

플래쉬를 이용한 게시판 자동등록 방지 알고리즘
16년 전
플래쉬를 이용한 게시판 자동등록 방지 알고리즘입니다.

알고리즘을 쉽게 설명하자면
글입력폼에서 전송버튼을 플래쉬로 만들고 플래쉬에서 Date.getTime()를 이용해 시간(키1값)과 그 시간을 약간 변형(키2값,간단한 암호화)시킨 두 값을 입력값 체크 함수에 넘겨줍니다.
입력값 체크후 폼 전송할때 그 두 값도 같이 넘겨줍니다.
그리고 글 저장하는 곳에서 다시 두값을 비교해 거짓이면 에러를 표시합니다.
참이면 키1값과 현재시간을 비교해 30분(글쓰는데 30분이면 넘치겠죠~)이 넘으면 에러를 표시하고 최근 30분간 등록된 키1값을 불러와 같은 키1값으로 등록시 에러를 표시합니다.
정상적으로 작성된 글들의 키1값은 저장합니다. 그리고 30분이 지난 키1값은 삭제합니다.

이 알고리즘의 핵심은 무조건 플래쉬버튼(전송버튼)을 눌러야만 키값이 생성되어 글이 등록된다는 것에 있습니다.(나 혼자만의 생각인가???)
그러기 위해선 암호화를 잘 시켜야 되는데...
플래쉬는 허접이어서...
그 부분은 아직 미흡한 상태입니다. 고수님들의 도움이 필요한 부분이죠~

아래는 소스예 입니다.
암호화부분 ㅋㅋ 저두 어떻게게 해야 할지 몰라서... 그냥 임의로 적어봤습니다.
_____________________________________________________________________

# 플래쉬 소스(버튼의 액션스크립트)
myDate = new Date;
time = myDate.getTime(); //시간을 구함

on (release) { //버튼을 클릭하면
        myString = new String(time);
        i = myString.split(""); //시간을 한 문자씩 자르구 값을 변형시킴(암호화 같지 않은 암호화)
        s1 =new String(int(i[12])+2);
        s2 =new String(int(i[3])+3);
        s3 =new String(int(i[10])+3);
        s4 =new String(int(i[7])+8);
        s5 =new String(int(i[9])+5);
        s6 =new String(int(i[8])+2);
        time2 = s1+s2+s3+s4+s5+s6;
        getURL("javascript:checkIt('"+time+"','"+time2+"');"); //글입력폼의 입력값체크 함수 호출 키1값과 키2값을 넘겨줌...
}

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

입력폼체크에서
function checkIt(ch_var1,ch_var2) {
...
...

form.ch_auto.value = ch_var1; //hidden 값
form.ch_auto2.value = ch_var2; ////hidden 값
form.submit();
}
이 두값을 같이 넘겨줌...

___________________________________________________________________________

###########################################
###### 게시판 자동등록 방지 ######
###########################################
function auto_error() {
Error("정상적으로 작성하여 주시기 바랍니다~ ");
exit;
}

if(!eregi($HTTP_HOST,$HTTP_REFERER)) {
auto_error();
}

if(getenv("REQUEST_METHOD") == 'GET' ) {
auto_error();
}

if(!$ch_auto OR !$ch_auto2) { //체크값이 없으면 종료
auto_error();
}

$signdate = time(); // DATE
$ch_auto3 = ($ch_auto[12]+2).($ch_auto[3]+3).($ch_auto[10]+3).($ch_auto[7]+8).($ch_auto[9]+5).($ch_auto[8]+2); //키1값은 플래쉬에서 암호화시킨것 처럼 다시 암호화..

if($ch_auto2 != $ch_auto3) {
auto_error();
}

$ch_auto4 = substr($ch_auto,0,10);

$i=intval($signdate) - intval($ch_auto4);

if ($i<10||$i>1800) { //30분이 지난 키값은 에러처리
auto_error();
}

// 먼저 게시판별 30분간 등록키를 처리를 할 manager라는 테이블을 만든다 id:등록게시판,ch_auto:키값저장...

$ch_query = "SELECT ch_auto FROM manager WHERE id = '등록게시판'"; //30분간 등록된 키를 불러온다
$ch_result = mysql_query($ch_query,$dbconn);

$ch_list = mysql_result($ch_result,0,0);
if(!$ch_list) { // 이전 등록된 값이 없으면 ...
$ch_num = 1;
$ch_data[1] = $ch_auto4;
} else { // 있으면 '|' 로 나눠 배열로 저장
$ch_data =explode("|",$ch_list);
$ch_num = 0; //저장된 키 갯수

for($j=1;$j<=$ch_data[0];$j++) { //30분안에 등록된 키로 다시 등록시 에러 처리
if($ch_data[$j] == $ch_auto4) auto_error();
$ch_time = intval($signdate) - intval($ch_data[$j]);
if($ch_time > 1800) {
$ch_data[$j] = ""; //30분이 지난 키값은 삭제
} else {
$ch_num ++;
$ch_data[$j] = $ch_data[$ch_num]; //배열 다시지정
}
}
$ch_num ++;
$ch_data[$ch_num] = $ch_auto4; //지금키값 저장
}

$w_list = $ch_num; // 배열을 조인 후 저장
for($w=1;$w<=$ch_num;$w++){
$w_list = $w_list."|".$ch_data[$w];
}

$ch2_query = "UPDATE manager SET ch_auto = '$w_list' WHERE id = '등록게시판'";
$ch2_result = mysql_query($ch2_query,$dbconn);

###########################################
###### END ######
###########################################
추천추천 : 270 추천 목록
번호 제목
2,885
input 입력 필드 앞뒤 공백 실시간 제거
2,884
Placeholder 포커스시 감추기
2,883
MySQL 중복된 데이터를 삭제
2,882
MySQL 중복 데이터 확인
2,881
sessionStorage.getItem 와 sessionStorage.setItem
2,880
제이쿼리 랜덤으로 배경색 변경
2,879
preg match에 관한 정규식
2,878
Stream an audio file with MediaPlayer 오디오 파일 스트리밍 하기
2,877
Audio Streaming PHP Code
2,876
PHP $ SERVER 환경 변수 정리
2,875
Vimeo (비메오) API 를 사용하여 플레이어 컨트롤하기
2,874
iframe 사용시 하단에 발생하는 공백 제거방법
2,873
아이프레임(iframe) 전체화면 가능하게 하기
2,872
부트스트랩(bootstrapk)에서 사용하는 class명 정리
2,871
부트스트랩 CSS
2,870
크롬에서 마진 조절
2,869
PHP 현재 페이지의 도메인명이나 url등의 정보 알아오기
2,868
PHP preg match all()
2,867
PHP 로 웹페이지 긁어오기 모든 방법 총정리!
2,866
[PHP] 원격지 파일 주소 노출 안하고 curl로 다운로드 받기
2,865
PHP 함수 정리
2,864
아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
2,863
PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
2,862
PHP 정규식 정리
2,861
PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
2,860
php 크롤링 또는 파싱 함수, 정규식 모음
2,859
제이쿼리 기본 명령어
2,858
웹페이지 가로 모드세로 모드 인식하기
2,857
모바일 웹 화면 강제 회전(가로모드 고정)
2,856
[HTML5]에서 frameset 대체 방법과 iframe 속성
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright ⓒ musictrot All rights reserved.