알짜게시판

무단링크 방지법

웹서버(아파치) 차원에서 무단링크 막는방법
다음의 설정내용을 httpd.conf에 명시하면
해당 쿠키값이 존재하지 않을경우 퍼미션을 허가하지 않는다.
이외에도 User-Agent 또는 Referer등을 체크하여 링크를 막을 수 도 있다.


SetEnvIf 모듈을 사용하여 httpd.conf 에 설정한다.
(웹서버에 요청이 들어올때 쿠키값으로 check 쿠키변수에 ok라는 값이 들어오면 true를
세팅한다.)

아파치에서 쿠키값을 가지고 있는 요청만을 처리하도록 하면 됨..
보통 버추얼 호스트나 웹 디렉토리 설정에서 allow 또는 deny 설정하는데,
아래와 같이 하면 쿠키값이 있는 요청만을 처리한다.


#무단링크방지
SetEnvIf Cookie check=ok true

<Directory "해당디렉토리">
  Options FollowSymLinks Includes ExecCGI
  Order allow,deny
  allow from env=true    <--- 이부분이 SetEnvIf에 의해 세팅된 변수만 허가함
</Directory>



이번엔 웹서버 차원이 아닌 웹문서수준에서 소스보기와 링크 막기

1.드래그 막기
<body oncontextmenu='return false' ondragstart='return false'
onselectstart='return false'>


2. 윈도네임 체크(새창을 띄울경우)
<script>
  if(window.self.name!='do_not_link') self.close();
  location.href='무단링크하지마.html';
</script>


3. 윈도사이즈 체크
<script>
  available_width=document.body.clientWidth;
  available_height=document.body.clientHeight;
  if(available_width!=특정사이즈 || available_width!=특정사이즈) self.close();
</script>

4. F11(Full Screen), 마우스오른쪽버튼 키보드 막기
<script>
function keypressed() {
  if(event.keyCode==122) self.close();
    else return false;
}
document.onkeydown=keypressed;
</script>

5. view-source 막기
이건 좀 복잡한데..리디렉션을 이용합니다..

첫번째 파일에서 쿠키값을 php등의 스크립트 언어로 하나만들고,
또하나는 자바스크립트로 만듭니다.
당연히 view-source 하면 자바스크립트로 만든 쿠키는 구워지지 않겠죠??
그리고 리디렉션되는곳에서 두개의 쿠키를 체크하여 쿠키값이 없을경우 exit합니다.

또는 다음과 같이 쿠키가 아닌 POST변수로 값을 넘겨도 되구요..
역시 view-source 했을 경우 값이 넘어 가지 않습니다..

  <form method=post name=form1 action=./next_script.php>
  <input type=hidden name=a value='$a'>
  <input type=hidden name=b value='$b'>
  <input type=hidden name=c value='$c'>
  </form>

  <script>document.form1.submit();</script>


이정도만 하면 어느정도 막을 수는 있겠지만 스니퍼등의 로우패킷 캡처를 할경우 대책은
없습니다.
근본적인 대책은 인증서를 발급받아 보안툴을 설치해야겠지만 그렇지 못할경우 각 변수들을
인코딩/디코딩하는 방법도 괜찮을 것입니다.
번호 제목 글쓴이 조회 날짜
67 답변글 [수정분] 이지보드 모듈 - NE멤버 0.923 (편리한 기능 추가) 1 7,878 01-25
66 제목읽기에서 라고 나오고 안되시는분들 12 11,639 01-11
65 채팅창에 성별에 따른 레벨 아이콘 나타내기 6,860 01-06
64 길호챗 설치 후기입니다. 각종 문제가 있었지만... 7,196 01-05
63 제목읽는 중... 저는 이렇게 풀었습니다. 3 7,865 01-04
62 방이 자꾸 깨지는분 2 5,854 12-18
61 방만들기 때 계속 로그인 하라고 하네요... 3 6,110 12-11
60 제목읽기중으로 나올때=&gt;강추 1 9,202 12-09
59 404에러났을때 고치는법! 3 8,299 12-08
58 _headtag 적용후에..최근게시물,외부로그인이 출력이 안됩니다. 5,309 12-07
57 현재 강퇴기능상의 문제점.. 3 7,301 12-04
56 제목이 멈추는 분들 보세요. 1 6,275 12-01
55 CAB 파일때문에 문제 일때 5,120 11-30
54 방 깨짐 현상 3 6,159 11-29
53 길호쳇방에서의 미니돌2.6 작은아바타 나타내기랍니다. 5 7,119 11-28
52 답변글 [re] 길호쳇방에서의 미니돌2.6 작은아바타 나타내기랍니다. 5 7,467 11-30
51 챗방에 손님이 들어오면 소리를 나오게하기 9 8,983 11-27
50 방깨짐이 자주 일어나는분 2 6,217 11-25
49 이모티 사용자분 참고하세요^^ 3 7,745 11-25
48 phpMyAdmin 2.5.4 입니다. 11 10,667 11-22
47 제목에서 멈추는분 이거 받아서 사용 9 7,857 11-22
46 절대 경로 주소 알아보기 6,381 11-19
45 사람이 없는데 방이 목록에 남아있는 경우... 3 5,578 11-18
44 그누보드3.21~22버전 로그인 하라는 메세지 출력 4 7,517 11-16
43 제로보드 사용자 채팅방에서 남녀 얼굴 나타내기.. 6 8,969 11-15
42 공지 날리기 두번째 1 6,541 11-14
41 db에러는 해결^^ ㅡㅡㅋ 302는 뭐여.. 1 6,270 11-14
40 로그인 후에 하얀화면만 나와요. 6,107 11-14
39 초간단 이모니콘 적용..... 10 7,405 11-13
38 새창띠우신분들은... 5,870 11-13
37 11월01 및 11월08 버젼 메뉴얼 4 6,431 11-12