Capture the Flag

CTF 奪旗

aka 資安競賽、安全競賽、網路攻防戰

 

目標:取得隱藏的flag

CTF - 解謎形式

Crypt 古典密碼學 - 各種猜猜樂

難度:easy

easyctf{r_wlmg_vevm_mvvw_zm_zhxrr_gzyov}

CTF - 解謎形式

現代密碼學 - 演算法的漏洞

難度:easy

RSA、MD5碰撞、SHA-1碰撞

CTF - 解謎形式

Forensics - 資料鑑識

難度:?

還是猜猜樂

分析檔案

分析封包

分析映像檔

CTF - 解謎形式

Reverse - 逆向工程,不給你code

難度:mid+

用用GDB來debug

用用XXX Pro反組譯(支持正版)

用用Java Decompiler破解app

注入二進位資料

很便宜的歐(不看單位的話)

CTF - 解謎形式

Pwn - 弱點分析

難度:hard

 

SQL Injection

Binary code Injection

Any bugly code

...

CTF - 解謎形式

Recon

難度:Pro

 

My name is Julian Cohen.

CTF - 攻防戰

給大家充滿bug的伺服器網內互打

CTF 與 生活

雖然比的項目類型有些十分奇葩

但是就是生活的一部份

古典密碼學

恩尼格瑪密碼機

 

第二次世界大戰普遍被德國使用,傳遞軍事資訊。

 

密碼破解據信提早了兩年結束戰爭

雖然破解的主因是拿到密碼(物理)

現代密碼學

為何現代網站會要求HTTPS或一堆安全措施

資料鑑識

2006年的機密資料使用2007年公布的字體?

逆向工程

各大遊戲、資訊業頭痛問題

攻防戰

天天都在發生的事

CTF 不只是比賽

更是生活的縮影

常見Bug

使用PHP

型別系統

"1234"+1

你了解正在寫程式語言嗎?

C/C++

PHP

Javascript

Python3

C/C++

234
--------------------------------
Process exited after 0.1786 seconds with return value 0
請按任意鍵繼續 . . .
#include<bits/stdc++.h>
using namespace std;

int main()
{
    cout<< "1234"+1 ;
}

PHP


C:\Users\USER>php
<?php
echo "1234"+1;
1235

Javascript

console.log("1234"+1)
"12341"

Python3

>>>"1234"+1
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: must be str, not int

型別變換

晦澀的型別容易忽略傳入錯誤型別的處理

 

是否存在特殊數值會意外導致型別改變?

PHP的型別變換

Int vs Double

如果整數大於PHP_INT_MAX,會自動變double

 

64 bit : 9223372036854775807

32 bit : 2147483647

PHP的型別變換

Int vs Double

負數的最小值?

<?php

echo var_dump(PHP_INT_MIN);// = -9223372036854775808
echo var_dump(-9223372036854775808);
int(-9223372036854775808)
float(-9.2233720368548E+18) //WTF?

PHP的型別變換

Int vs Double

一般的程式語言沒有負數,只有負號運算(Ex. C++)

#define MB_LEN_MAX 5
#define SHRT_MIN (-32768)
#define SHRT_MAX 32767
#define USHRT_MAX 0xffffU
#define INT_MIN (-2147483647 - 1)
#define INT_MAX 2147483647

PHP的型別變換

Int vs Double

一般的程式語言沒有負數,只有負號運算(Ex. C++)

#define MB_LEN_MAX 5
#define SHRT_MIN (-32768)
#define SHRT_MAX 32767
#define USHRT_MAX 0xffffU
#define INT_MIN (-2147483647 - 1)
#define INT_MAX 2147483647

PHP的型別變換

string vs int+double

如果一個字串表示了一個合法的int

這個字串在被運算時會轉成int

 

若可以表示合法的double

這個字串在被運算時會轉成double

ex : "7122" , "6666","1.2e77"

PHP的型別變換

  • 如果不能完整轉換,就從一個字元開始嘗試轉換到不能轉
  • aka strtod
  • "1 apple" == 1
  • "no apple" == 0

string vs int+double

PHP的型別變換

  • 恩,很簡單
<?php

$data = "1000";
$str1 = "10e2";
$str2 = "ppap";

var_dump( $str1 == $data );
var_dump( $str2 == $data );
bool(true)
bool(false)

string vs int+double

PHP的型別變換

  • 0 vs "0" vs "" vs false vs [] vs null

true轉成字串是"1"

false傳成字串是"" ??

var_dump( (bool)"0" );
var_dump( (bool)"000" );
bool(false)
bool(true)

PHP字串 - 方便

$name = "apple";
$sql = "SELECT * FROM `sql` WHERE `name` = '{$name}'";
$name = "' OR 1=1 -- ";
$sql = "SELECT * FROM `sql` WHERE `name` = '{$name}'";
SELECT * FROM `sql` WHERE `name` = 'apple'
SELECT * FROM `sql` WHERE `name` = '' OR 1=1 -- '
true?'G':false?'t':'f'

C/C++:G

PHP:t

CTF & PHP bugly code

By sylveon

CTF & PHP bugly code

  • 735