구멍난 자바스크립트 보안

· 18년 전 · 3546

 

로컬파일로 접근

①번의 방법은 GET방식때문에 막혔습니다 그러면 자바스크립트를 우회하면서 POST방식으로 보내는 방법은 없을까요? 물론 있습니다

웹브라우져는 "소스보기" 라는 좋은 메뉴가 있습니다 있는건 적극 활용합시다 ㅎㅎ

소스보기한 후 바탕화면에 저장하여 약간 손을 보았습니다

즉 입력값을 체크하는 자바스크립트를 무력화 시키면서, action을 수정해 주었습니다

 

C:\Documents and Settings\Administrator\바탕 화면\client.html

<script>

/* 입력한값이 13자리인지 체크 후 전송 */

function validateValue() {

    return true;
}

</script>

 

<form name=f method=post action="http://www.jakartaproject.com/html/process.jsp" onsubmit="return validateValue()">
주민번호 <input type=text name=register_no> <input type=submit name=btn value=submit>
</form>

 

 

웹화면은 다음과 같겠죠

T200602211140519907749_jpg

"submit"버튼을 클릭합니다 ^^

 

역시나 자바스크립트를 거치지 않고 process.jsp에 13자리수가 아닌 "22"값을 무난히 보냈습니다

T200602211140519918590_jpg

 

그럼 서버쪽에서는 "어이쿠 이런 헤더정보도 체크해야 겠군" 하고 다음 코드를 추가해 버릴겁니다

즉 레퍼러값이 null인 경우는 허용할수 없다는 것이죠

 

http://www.jakartaproject.com/html/process.jsp

<%@ page contentType="text/html; charset=euc-kr" %>

 

<%

if (!"POST".equals(request.getMethod())
   return;


if (request.getHeader("referer") == null)
   return;

String register_no = request.getParameter("register_no");
%>

 

헤더정보 <%=request.getHeader("referer")%><br><br>
주민번호 <%=register_no%>

그럼 위와같은 소스가 될것입니다

그럼 과연 위 소스가 안전할까요?

 

HEADER값 조작

그렇다면 HEADER값을 조작해 봅시다 어떻게 조작할 수 있을까요?

여러가지 프로그램들이 있지만 그중에 Achilles 라는 proxy server를 이용하여 조작해 보겠습니다

Achilles라는 proxy server는 웹브라우져와 서버간의 HTTP 세션을 중간에서 가로채어 원하는대로 수정한 후 보낼수 있도록 해주는 작으면서도 강력한 프로그램입니다

 

※ 참고

Achilles 문서를 보면 맨 첫줄에 나오는 문장입니다

"Achilles is a tool designed for testing the security of web applications"

이 프로그램은 웹어플리케이션의 보안 테스팅을 하는데 작성되었으므로 테스팅용으로만 사용합시다

 

다운로드

http://www.mavensecurity.com/achilles

 

우선 위에서 작성한 바탕화면에 저장된 C:\Documents and Settings\Administrator\바탕 화면\client.html 를 실행한 결과를 Achilles가 Intercept한 결과입니다
T200602211140520230177_jpg
여러 가지 헤더정보들이 보이며 쿠키값까지 조작할수 있습니다

하지만 위의 헤더정보에는 referer값이 없습니다 그래서 referer체크에서 null이 나와 로직에 걸립니다

그렇다면 referer정보를 추가해 줍시다

T200602221140603109108_jpg

파랑색으로 줄쳐진 부분을 에디팅하여 추가해주었습니다

Referer: http://www.jakartaproject.com/html/input.html

그런다음 "Send"버튼으로 전송합니다

T200602211140519964661_jpg

짠~

그러면 조작된 헤더정보를 알아채지 못하고 헤더의 referer값을 가져오는군요!

 

 

4. 서버쪽 로직 추가!

위에서 자바스크립트를 우회하는 몇가지 방법들을 알아보았습니다

결론은 하나입니다 즉! 서버쪽에서도 동일하게 체크해 주어야 합니다

 

<%@ page contentType="text/html; charset=euc-kr" %>

 

<%

String register_no = request.getParameter("register_no");

 

if (!"POST".equals(request.getMethod())
   return;


if (request.getHeader("referer") == null)
   return;

 

if (register_no.length() != 13)

   return;
%>

 

헤더정보 <%=request.getHeader("referer")%><br><br>
주민번호 <%=register_no%>

 

그렇다면 서버쪽에서만 체크하고 클라이언트에서는 체크할 필요가 없다고 생각할지도 모르지만,

그만큼 서버쪽으로 오는 request를 줄이면 더더욱 좋겠죠

자잘한것 하나때문에 서버쪽 부하를 줄수 없는 노릇아니겠습니까?

 

자 이러이러 하고 저러저러한 이유로 우리는 이제부터라도 클라이언트에서는 자바스크립트로,

서버쪽에서는 또 서버쪽 스크립트로 사용자가 입력한 값에대해 유효성을 검증해야 하는것을 알았습니다

로직이 복잡한 경우 가뜩이나 자바스크립트도 복잡한데 그 로직을 서버쪽에서 다시한번 만든다는게 힘들다는거 다들 압니다 하지만 안전한 웹페이지를 만들기 위해 다같이 노력해야 되지 않겠습니까?

[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
18년 전 조회 3,564
18년 전 조회 3,362
18년 전 조회 3,232
18년 전 조회 2,864
18년 전 조회 4,212
18년 전 조회 5,545
18년 전 조회 3,795
18년 전 조회 3,247
18년 전 조회 3,670
18년 전 조회 2,319
18년 전 조회 2,746
18년 전 조회 3,983
18년 전 조회 2,911
18년 전 조회 4,430
18년 전 조회 2,137
18년 전 조회 2,579
18년 전 조회 2,471
18년 전 조회 3,837
18년 전 조회 3,899
18년 전 조회 2,633
18년 전 조회 2,714
18년 전 조회 3,033
18년 전 조회 2,865
18년 전 조회 2,078
18년 전 조회 2,240
18년 전 조회 4,893
18년 전 조회 4,250
18년 전 조회 2,864
18년 전 조회 2,430
18년 전 조회 2,928
18년 전 조회 2,393
18년 전 조회 3,572
18년 전 조회 2,230
18년 전 조회 2,025
18년 전 조회 1,884
18년 전 조회 1,704
18년 전 조회 3,295
18년 전 조회 4,623
18년 전 조회 4,903
18년 전 조회 2,188
18년 전 조회 3,639
18년 전 조회 3,358
18년 전 조회 4,647
18년 전 조회 3,297
18년 전 조회 4,279
18년 전 조회 3,973
18년 전 조회 3,665
18년 전 조회 3,070
18년 전 조회 2,970
18년 전 조회 3,547
18년 전 조회 2,198
18년 전 조회 2,141
18년 전 조회 5,550
18년 전 조회 2,730
18년 전 조회 2,473
18년 전 조회 2,773
18년 전 조회 2,124
18년 전 조회 3,109
18년 전 조회 1만
18년 전 조회 1,960
18년 전 조회 2,879
18년 전 조회 2,916
18년 전 조회 2,163
18년 전 조회 3,017
18년 전 조회 4,018
18년 전 조회 2,972
18년 전 조회 2,358
18년 전 조회 6,091
18년 전 조회 3,708
18년 전 조회 6,383
18년 전 조회 2,482
18년 전 조회 2,400
18년 전 조회 2,419
18년 전 조회 3,369
18년 전 조회 3,225
18년 전 조회 2,014
18년 전 조회 3,755
18년 전 조회 1,663
18년 전 조회 1,410
18년 전 조회 1,440
18년 전 조회 1,588
18년 전 조회 1,682
18년 전 조회 3,460
18년 전 조회 2,308
18년 전 조회 1,755
18년 전 조회 2,156
18년 전 조회 4,655
18년 전 조회 2,390
18년 전 조회 3,027
18년 전 조회 2,018
18년 전 조회 3,515
18년 전 조회 1,883
18년 전 조회 7,692
18년 전 조회 3,352
18년 전 조회 1,339
18년 전 조회 2,371
18년 전 조회 3,575
18년 전 조회 2,414
18년 전 조회 2,190
18년 전 조회 2,811