알짜게시판

무단링크 방지법

웹서버(아파치) 차원에서 무단링크 막는방법
다음의 설정내용을 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>


이정도만 하면 어느정도 막을 수는 있겠지만 스니퍼등의 로우패킷 캡처를 할경우 대책은
없습니다.
근본적인 대책은 인증서를 발급받아 보안툴을 설치해야겠지만 그렇지 못할경우 각 변수들을
인코딩/디코딩하는 방법도 괜찮을 것입니다.
번호 제목 글쓴이 조회 날짜
238 [Delphi] TrayIcon 이 흐릿하게 보이는 버그? 수정 8,502 12-12
237 [Delphi] 실행 중인 프로세스가 활성 창인지 확인하는 함수 43,957 11-02
236 [Delphi] 메세지 다이어그램(Message Dialog) 에 체크박스(CheckBox) 추가 46,186 10-30
235 [그누보드] 부트스트랩 테마 예제로 사용중인 main.php 53,449 10-21
234 [그누보드] 유튜브 스킨 59,546 10-14
233 [윈도우] TLS 연결 끊김 해결 방법 - Kyber 비활성화 60,796 10-12
232 [PHP] 검색 로봇 접속시 종료 55,544 10-07
231 [윈도우] WinDivert 사용중인 어플리케이션 검색 43,605 09-12
230 [워드프레스] 답글 남기기 메시지 변경 42,025 09-05
229 [리눅스] PHP-FPM 튜닝을 위한 메모리 계산 40,529 08-29
228 [윈도우] 아이폰 벨소리 쉽게 추가하기 93,354 06-14
227 [윈도우] C:\Windows\Installer 폴더 다른 드라이브로 옮기기 103,871 05-29
226 작업 표시줄 (기타 시스템 트레이 아이콘) 제거 프로그램 108,636 05-18
225 [워드프레스] cdn.jsdelivr.net 에서 ssl 인증서 오류 문제 101,517 05-02
224 [그누보드] cdn.jsdelivr.net 에서 ssl 인증서 오류 문제 96,866 05-02
223 [PHP] REQUEST 값 받기(application/json 포함) 98,509 04-20
222 [Linux] 데몬(systemd service) 작성 및 실행하기 65,363 03-14
221 [PHP] Porto 테마에서 포스팅만 Loading Overlay 57,682 03-08
220 [그누보드] 아이디 대신 이메일로 회원 가입하기 88,198 02-02
219 [시크릿DNS] Kaspersky 백신 사용시 DNS 암호화 관련 4 98,159 01-04
218 [칼무리] 영역화면 크기 오류인 경우 121,034 12-12
217 [MySQL] 업데이트 이후 에러 발생([ERROR] Incorrect definition of table … 91,112 12-08
216 구글 크롬 탭검색 비활성화 71,821 12-04
215 [MySQL] MySQL, MariaDB 업데이트 73,289 11-24
214 [아이폰] HTTPS 감청 우회하기 203,096 11-01
213 Windows에 Rust 설치하기 57,105 10-05
212 HTTPS/DNS 차단 쉽게 이해하기 84,164 08-16
211 ChangeDNS - DNS 서버를 손쉽게 변경합니다. 75,523 08-13
210 [ReactNative] android directory was detected in the project. 65,165 07-20
209 [리눅스] 메일(Mail) 삭제/초기화 57,993 07-18
208 [Delphi] 윈도우 알림센터에 메시지 출력하기 55,219 06-20