알짜게시판

무단링크 방지법

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

이 정도만 하면 어느 정도 막을 수는 있겠지만
스니퍼 등의 로우패킷 캡처를 할 경우 대책은 없다.

근본적인 대책은 인증서를 발급받아 보안툴을 설치해야겠지만,
그렇지 못할 경우 각 변수들을 인코딩/디코딩하는 방법도 괜찮을 것이다.

로그인 후 댓글내용을 입력해주세요

제목 글쓴이 조회 날짜
리눅스 아파치 일반 계정 파일 접근 권한 설정과 mod-ruid2 적용 방법 131 26-04-26
델파이 Delphi IDE 메인 폼 안열림 dproj 설정으로 해결 107 26-04-26
개발팁 VSCode 한국어 설정법, Configure Display Language로 UI 언… 148 26-04-24
기타 RustDesk 자체 서버 구축으로 공용 서버 로그인 문제 해결 266 26-04-16
리눅스 Dante SOCKS5 프록시 서버 구축 및 설정 309 26-04-10
윈도우 윈도우 실행파일(exe) 서비스 등록 자동화 쉽게 하는 방법 - NSSM 424 26-04-05
기타 CLIProxyAPI Windows 설치 가이드 704 26-04-04
워드프레스 그누보드7 데이터를 WordPress WXR로 변환하기 427 26-04-01
기타 Ollama 설치 경로 C드라이브 고정 문제 해결 및 드라이브 변경 방법 420 26-03-31
개발팁 Apache Access Log 기반 도메인별 방문자 카운터 구현 340 26-03-31
윈도우 ZImage AI 이미지 생성 환경 구축 방법 514 26-03-26
윈도우 파일 복사 후 실행 배치파일 - 에러 감지 포함 537 26-03-10
개발팁 네이버 검색 Open API 845 26-02-10
개발팁 네이버 검색광고 키워드 도구 API 검색 1,023 26-02-10
개발팁 MariaDB column_stats 테이블 오류 해결 방법 1,026 25-12-06
개발팁 PHP-FPM 에러 로그 실시간 모니터링 921 25-12-03
윈도우 윈도우11 업데이트 후 네트워크 드라이브 접근 불가 문제 해결 방법 1,676 25-11-24
개발팁 다국어 번역 함수 구현 방법 3,345 25-11-08
워드프레스 "치명적인 오류가 발생했습니다" 디버깅 가이드 14,140 25-10-31
리눅스 Apache 웹 로그 분석하기 – awk와 GoAccess 활용 18,727 25-10-28
길호넷 칼무리 - 외부 명령으로 캡처 자동화하기 1 40,447 25-10-14
윈도우 윈도11 강제업데이트 피하고 윈도10 계속 쓰기 41,884 25-10-12
리눅스 PHP 파일 업로드 용량 늘리기 56,796 25-10-03
개발팁 애드센스 충돌 문제 해결하기 74,780 25-09-20
파이썬 Python Playwright로 Edge 브라우저 제어하기 76,860 25-09-12
델파이 TDirectory.Delete 대신 CMD 으로 폴더 삭제 75,162 25-09-10
윈도우 Chrome 및 Edge를 TLS 1.2 모드로 실행 74,569 25-08-30
개발팁 애드센스 자동 광고 사용 시 빈 화면이 출력된다면? 159,427 25-06-20
윈도우 브라우저 환경설정 추출 146,041 25-06-18
워드프레스 xmlrpc.php 차단으로 보안 강화하기 137,150 25-06-05
델파이 폼이 모니터 한 가운데 있는 경우 자연스럽게 왼쪽으로 이동시키기 134,733 25-05-26
철학인문지원톡톡결혼준비웹프로그래밍결혼의신