profile

이 세상에 하나는 남기고 가자

세상에 필요한 소스코드 한줄 남기고 가자

HTTP referrer(referer) 숨기기

유영재

브라우저에서 http 요청을 하는 경우 대부분 referrer 정보가 넘어간다.(HTTP 리퍼러를 정의한 RFC에서 'referrer'를 'referer'라고 잘못 친 것에서 기인하여 HTTP 리퍼러는 'HTTP referer'라고 불린다 : 위키백과)

그런데 간혹 이 referrer를 숨기고 싶을 때가 있다. 현 페이지에서 resouces(js, css, image, ajax 등)를 요청할 때나 페이지를 이동할 때 referrer가 전송되는데 여기서는 resouces를 호출할 때 referrer를 숨기는 방법에 대해 설명하려고 한다.


  • <meta> Tag를 이용한 referrer 제거

Remove http referrer에 보면 아래와 같이 referrer를 제거하는 방법을 소개하고 있다.

<meta name="referrer" content="no-referrer" />
var meta = document.createElement('meta');
meta.name = "referrer";
meta.content = "no-referrer";
document.getElementsByTagName('head')[0].appendChild(meta);

html, javascript로 처리하는 두가지 방식이 있는데 html의 경우 <head> 내부에 넣어주면 된다. 그리고 javascript의 경우는 필요한 시점에 실행해주면 된다. 예를들어 특정 ajax 호출시에만 referrer를 숨기고자 하는 경우 등이다.

no-referrer 외에 사용할 수 있는 값은 unsafe-url, origin-when-cross-origin 등이 있는데 자세한 내용은 W3C Referrer Policy를 참고하면 된다. 여기보면 <a href="http://example.com" referrerpolicy="origin"> 와 같이 개별 링크에 Referrer 정책을 지정하는 방법들도 안내되어 있다.


  • <IFrame> Tag를 이용한 referrer 제거

다른 방법으로는 iframe을 이용해서 referrer를 제거할 수 있다. 일단 아래의 코드를 보자.

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
    <style type="text/css">
        html, body { width:100%; height:100%; margin:0; padding:0; }
        textarea { display:none; }
        iframe { width:100%; height:100%; }
    </style>
</head>
<body>
<textarea id="html"><!-- 실제 들어갈 HTML --></textarea>
<script type="text/javascript">
    var iframe = document.createElement('iframe');
    document.body.appendChild(iframe);

    var html = document.getElementById('html').value;

    // 가장 간단하지만 crass domain 문제가 있을 수 있다.
    // iframe.src = 'data:text/html;charset=utf-8,' + encodeURI(html);

    // cross domain issue 해결
    iframe.srcdoc = html;

    // (iframe.contentDefault || iframe.contentWindow.document).domain = document.domain;
</script>
</body>
</html>

srcdoc이 생소하다면 Which is the difference between srcdoc=“…” and src=“data:text/html,…” in an