보안 공부/webhacking.kr

webhacking,kr 6번

무무뭉? 2021. 1. 26. 21:53

webhacking,kr 6번 


https://webhacking.kr/challenge/web-06/

6번 문제는 id와 pw가 음.... 아마 웹에서 기본 정보를 준것 같다.

view-source를 클릭하여 소스 코드를 보면 아래처럼 되어있다.



<?php

include "../../config.php";
if(
$_GET['view_source']) view_source();
if(!
$_COOKIE['user']){
  
$val_id="guest";
  
$val_pw="123qwe";
  for(
$i=0;$i<20;$i++){
    
$val_id=base64_encode($val_id);
    
$val_pw=base64_encode($val_pw);
  }
  
$val_id=str_replace("1","!",$val_id);
  
$val_id=str_replace("2","@",$val_id);
  
$val_id=str_replace("3","$",$val_id);
  
$val_id=str_replace("4","^",$val_id);
  
$val_id=str_replace("5","&",$val_id);
  
$val_id=str_replace("6","*",$val_id);
  
$val_id=str_replace("7","(",$val_id);
  
$val_id=str_replace("8",")",$val_id);

  
$val_pw=str_replace("1","!",$val_pw);
  
$val_pw=str_replace("2","@",$val_pw);
  
$val_pw=str_replace("3","$",$val_pw);
  
$val_pw=str_replace("4","^",$val_pw);
  
$val_pw=str_replace("5","&",$val_pw);
  
$val_pw=str_replace("6","*",$val_pw);
  
$val_pw=str_replace("7","(",$val_pw);
  
$val_pw=str_replace("8",")",$val_pw);

  
Setcookie("user",$val_id,time()+86400,"/challenge/web-06/");
  
Setcookie("password",$val_pw,time()+86400,"/challenge/web-06/");
  echo(
"<meta http-equiv=refresh content=0>");
  exit;
}
?>
<html>
<head>
<title>Challenge 6</title>
<style type="text/css">
body { background:black; color:white; font-size:10pt; }
</style>
</head>
<body>
<?php
$decode_id
=$_COOKIE['user'];
$decode_pw=$_COOKIE['password'];

$decode_id=str_replace("!","1",$decode_id);
$decode_id=str_replace("@","2",$decode_id);
$decode_id=str_replace("$","3",$decode_id);
$decode_id=str_replace("^","4",$decode_id);
$decode_id=str_replace("&","5",$decode_id);
$decode_id=str_replace("*","6",$decode_id);
$decode_id=str_replace("(","7",$decode_id);
$decode_id=str_replace(")","8",$decode_id);

$decode_pw=str_replace("!","1",$decode_pw);
$decode_pw=str_replace("@","2",$decode_pw);
$decode_pw=str_replace("$","3",$decode_pw);
$decode_pw=str_replace("^","4",$decode_pw);
$decode_pw=str_replace("&","5",$decode_pw);
$decode_pw=str_replace("*","6",$decode_pw);
$decode_pw=str_replace("(","7",$decode_pw);
$decode_pw=str_replace(")","8",$decode_pw);

for(
$i=0;$i<20;$i++){
  
$decode_id=base64_decode($decode_id);
  
$decode_pw=base64_decode($decode_pw);
}

echo(
"<hr><a href=./?view_source=1 style=color:yellow;>view-source</a><br><br>");
echo(
"ID : $decode_id<br>PW : $decode_pw<hr>");

if(
$decode_id=="admin" && $decode_pw=="nimda"){
  
solve(6);
}
?>
</body>
</html>


소스코드가 무엇을 말하고자 하는가 살펴보면 음 쿠키의 아이디값이 admin, 비번이 nimda이면 되는 건데 

encode decode를 20번 하라고 나와있다. (왜 쿠키값을 변경해야 하냐고 물어보면 값을 입력 받을 input 태그가 없기 때문이 아닐까 생각된다.)


즉 admin과 nimda 값을 bade64로 인코딩을 20번 한 후 해당 문자열을 치환해주면 될 것 같다.

파이썬으로 풀어보면


이렇게 코딩하면 될 듯 하다.

결과값은 아래처럼 나오는데 아우 지저분하다 ㅋㅋㅋㅋㅋ


https://chrome.google.com/webstore/detail/editthiscookie/fngmhnnpilhplaeedifhccceomclgfbg?hl=ko

쿠키값을 변경시키기 위해서 (나는 크롬을 사용하므로 크롬 확장프로그램을 사용하겠다.)

editthiscookie를 이용해 값을 바꿔준 후 새로고침 하면 값을 구할 수 있다.


파이썬 코드는 아래의 깃허브에

https://github.com/jo-gunhee/Webhacking.kr