Çerez Hacking
Reading time: 13 minutes
tip
AWS Hacking'i öğrenin ve pratik yapın:HackTricks Training AWS Red Team Expert (ARTE)
GCP Hacking'i öğrenin ve pratik yapın: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks'i Destekleyin
- abonelik planlarını kontrol edin!
- Bize katılın 💬 Discord grubuna veya telegram grubuna veya bizi takip edin Twitter'da 🐦 @hacktricks_live.
- Hacking ipuçlarını paylaşın, HackTricks ve HackTricks Cloud github reposuna PR göndererek.
Çerez Nitelikleri
Çerezler, kullanıcının tarayıcısındaki davranışlarını kontrol eden birkaç nitelik ile gelir. İşte bu niteliklerin daha pasif bir sesle özeti:
Süre Dolma ve Max-Age
Bir çerezin son kullanma tarihi Expires
niteliği ile belirlenir. Tersine, Max-age
niteliği bir çerezin silinmesine kadar geçen süreyi saniye cinsinden tanımlar. Daha modern uygulamaları yansıttığı için Max-age
seçin.
Alan
Bir çerezi alacak olan ana bilgisayarlar Domain
niteliği ile belirtilir. Varsayılan olarak, bu çerezi veren ana bilgisayara ayarlanır, alt alan adlarını içermez. Ancak, Domain
niteliği açıkça ayarlandığında, alt alan adlarını da kapsar. Bu, Domain
niteliğinin belirlenmesini daha az kısıtlayıcı bir seçenek haline getirir ve alt alan adları arasında çerez paylaşımının gerekli olduğu senaryolar için faydalıdır. Örneğin, Domain=mozilla.org
ayarlandığında, developer.mozilla.org
gibi alt alan adlarında çerezlere erişim sağlanır.
Yol
Cookie
başlığının gönderilmesi için istenen URL'de bulunması gereken belirli bir URL yolu Path
niteliği ile belirtilir. Bu nitelik /
karakterini bir dizin ayırıcı olarak kabul eder ve alt dizinlerde eşleşmelere de izin verir.
Sıralama Kuralları
İki çerez aynı isme sahip olduğunda, gönderilmek üzere seçilen çerez:
- İstenen URL'deki en uzun yolu eşleşen çerez.
- Yollar aynıysa en son ayarlanan çerez.
SameSite
SameSite
niteliği, çerezlerin üçüncü taraf alanlardan gelen isteklerde gönderilip gönderilmeyeceğini belirler. Üç ayar sunar:- Strict: Çerezin üçüncü taraf isteklerinde gönderilmesini kısıtlar.
- Lax: Çerezin üçüncü taraf web siteleri tarafından başlatılan GET istekleri ile gönderilmesine izin verir.
- None: Çerezin herhangi bir üçüncü taraf alanından gönderilmesine izin verir.
Çerezleri yapılandırırken, bu nitelikleri anlamak, farklı senaryolar arasında beklenildiği gibi davranmalarını sağlamaya yardımcı olabilir.
İstek Türü | Örnek Kod | Çerezler Ne Zaman Gönderilir |
---|---|---|
Bağlantı | <a href="..."></a> | NotSet*, Lax, None |
Önceden Yükleme | <link rel="prerender" href=".."/> | NotSet*, Lax, None |
Form GET | <form method="GET" action="..."> | NotSet*, Lax, None |
Form POST | <form method="POST" action="..."> | NotSet*, None |
iframe | <iframe src="..."></iframe> | NotSet*, None |
AJAX | $.get("...") | NotSet*, None |
Resim | <img src="..."> | NetSet*, None |
Tablo Invicti kaynağından alınmış ve hafifçe değiştirilmiştir.
SameSite niteliğine sahip bir çerez, CSRF saldırılarını azaltacaktır.
*Chrome80 (şub/2019) itibarıyla, bir çerez için varsayılan davranış, çerez samesite nitelikleri yoksa lax olacaktır (https://www.troyhunt.com/promiscuous-cookies-and-their-impending-death-via-the-samesite-policy/).
Bu değişiklik uygulandıktan sonra, SameSite politikası olmayan çerezler Chrome'da ilk 2 dakika boyunca None olarak değerlendirilecek ve ardından üst düzey çapraz site POST isteği için Lax olarak değerlendirilecektir.
Çerez Bayrakları
HttpOnly
Bu, istemcinin çereze erişimini engeller (Örneğin Javascript ile: document.cookie
)
Aşmalar
- Eğer sayfa, bir isteğin yanıtı olarak çerezleri gönderiyorsa (örneğin bir PHPinfo sayfasında), XSS'i kötüye kullanarak bu sayfaya bir istek göndermek ve çerezleri yanıtından çalmak mümkündür (örneği kontrol edin https://hackcommander.github.io/posts/2022/11/12/bypass-httponly-via-php-info-page/).
- Bu, TRACE HTTP istekleri ile aşılabilir çünkü sunucudan gelen yanıt, gönderilen çerezleri yansıtacaktır. Bu teknik Cross-Site Tracking olarak adlandırılır.
- Modern tarayıcılar, JS'den TRACE isteği göndermeye izin vermeyerek bu tekniği engeller. Ancak, IE6.0 SP2'ye
TRACE
yerine\r\nTRACE
göndererek bazı aşmalar bulunmuştur. - Diğer bir yol, tarayıcıların sıfır/günlük açıklarını istismar etmektir.
- Bir Çerez Jar taşma saldırısı gerçekleştirerek HttpOnly çerezlerini aşmak mümkündür:
- Bu çerezleri dışarı aktarmak için Cookie Smuggling saldırısı kullanılabilir.
Güvenli
İstek, yalnızca güvenli bir kanal üzerinden (tipik olarak HTTPS) iletilirse çerezi sadece HTTP isteğinde gönderir.
Çerez Ön Ekleri
__Secure-
ile başlayan çerezlerin, HTTPS ile güvence altına alınmış sayfalardan secure
bayrağı ile birlikte ayarlanması gerekmektedir.
__Host-
ile başlayan çerezler için birkaç koşulun karşılanması gerekir:
secure
bayrağı ile ayarlanmalıdır.- HTTPS ile güvence altına alınmış bir sayfadan gelmelidir.
- Bir alan belirtmeleri yasaktır, bu da alt alanlara iletimlerini engeller.
- Bu çerezlerin yolu
/
olarak ayarlanmalıdır.
__Host-
ile başlayan çerezlerin süper alanlara veya alt alanlara gönderilmesine izin verilmediğini belirtmek önemlidir. Bu kısıtlama, uygulama çerezlerini izole etmeye yardımcı olur. Bu nedenle, tüm uygulama çerezleri için __Host-
ön ekinin kullanılması, güvenliği ve izolasyonu artırmak için iyi bir uygulama olarak kabul edilebilir.
Çerezleri Üzerine Yazma
Dolayısıyla, __Host-
ile başlayan çerezlerin korunmasından biri, alt alanlardan üzerine yazılmalarını engellemektir. Örneğin Cookie Tossing saldırılarını önlemek. Cookie Crumbles: Unveiling Web Session Integrity Vulnerabilities (makale) konuşmasında, alt alanlardan __HOST-
ile başlayan çerezlerin ayarlanmasının, örneğin başına veya sonuna "=" ekleyerek, ayrıştırıcıyı kandırarak mümkün olduğu sunulmuştur:
Ya da PHP'de çerez adının başına başka karakterler ekleyerek, bunların alt çizgi karakterleri ile değiştirileceği mümkün olmuştur, bu da __HOST-
çerezlerini üzerine yazmaya olanak tanır:
Çerez Saldırıları
Özel bir çerez hassas veriler içeriyorsa, bunu kontrol edin (özellikle bir CTF oynuyorsanız), çünkü bu savunmasız olabilir.
Çerezleri Çözme ve Manipüle Etme
Çerezlerde gömülü hassas veriler her zaman incelenmelidir. Base64 veya benzeri formatlarda kodlanmış çerezler genellikle çözülebilir. Bu zafiyet, saldırganların çerezin içeriğini değiştirmesine ve değiştirilmiş verilerini çereze geri kodlayarak diğer kullanıcıları taklit etmesine olanak tanır.
Oturum Ele Geçirme
Bu saldırı, bir kullanıcının çerezini çalarak uygulama içindeki hesabına yetkisiz erişim sağlamayı içerir. Çalınan çerez kullanılarak, bir saldırgan meşru kullanıcıyı taklit edebilir.
Oturum Sabitleme
Bu senaryoda, bir saldırgan bir kurbanı belirli bir çerezi kullanarak oturum açmaya kandırır. Uygulama oturum açıldığında yeni bir çerez atamazsa, saldırgan, orijinal çerezi elinde bulundurarak kurbanı taklit edebilir. Bu teknik, kurbanın saldırgan tarafından sağlanan bir çerezle oturum açmasına dayanır.
Eğer bir alt alanında XSS bulduysanız veya bir alt alanı kontrol ediyorsanız, okuyun:
Oturum Bağışı
Burada, saldırgan kurbanı saldırganın oturum çerezini kullanmaya ikna eder. Kurban, kendi hesabında oturum açtığını düşünerek, istemeden saldırganın hesabı bağlamında eylemler gerçekleştirir.
Eğer bir alt alanında XSS bulduysanız veya bir alt alanı kontrol ediyorsanız, okuyun:
JWT Çerezleri
JWT'deki olası hataları açıklayan bir sayfaya erişmek için önceki bağlantıya tıklayın.
Çerezlerde kullanılan JSON Web Token'lar (JWT) da zafiyetler içerebilir. Potansiyel hatalar ve bunları nasıl istismar edeceğiniz hakkında derinlemesine bilgi için, JWT hacking ile ilgili bağlantılı belgeyi erişmeniz önerilir.
Cross-Site Request Forgery (CSRF)
Bu saldırı, oturum açmış bir kullanıcının, şu anda kimlik doğrulaması yapılmış olduğu bir web uygulamasında istenmeyen eylemleri gerçekleştirmesini zorlar. Saldırganlar, savunmasız siteye her istekte otomatik olarak gönderilen çerezleri istismar edebilir.
Boş Çerezler
(Başka detaylar için orijinal araştırmaya bakın) Tarayıcılar, isim olmadan çerez oluşturulmasına izin verir, bu da JavaScript ile şu şekilde gösterilebilir:
document.cookie = "a=v1"
document.cookie = "=test value;" // Setting an empty named cookie
document.cookie = "b=v2"
Gönderilen çerez başlığındaki sonuç a=v1; test value; b=v2;
şeklindedir. İlginç bir şekilde, bu, boş bir isim çerezi ayarlandığında çerezlerin manipüle edilmesine olanak tanır; bu, boş çerezi belirli bir değere ayarlayarak diğer çerezleri kontrol etme potansiyeli taşır:
function setCookie(name, value) {
document.cookie = `${name}=${value}`
}
setCookie("", "a=b") // Setting the empty cookie modifies another cookie's value
Bu, tarayıcının her web sunucusu tarafından a
adında ve b
değerinde bir çerez olarak yorumlanan bir çerez başlığı göndermesine yol açar.
Chrome Hatası: Unicode Yedek Kod Noktası Sorunu
Chrome'da, bir Unicode yedek kod noktası ayarlanmış bir çerezin parçasıysa, document.cookie
bozulur ve sonrasında boş bir dize döner:
document.cookie = "\ud800=meep"
Bu, document.cookie
'nin boş bir dize döndürmesiyle sonuçlanır ve kalıcı bir bozulmayı gösterir.
Ayrıştırma Sorunlarından Kaynaklanan Cookie Smuggling
(Daha fazla ayrıntı için orijinal araştırmaya bakın) Java (Jetty, TomCat, Undertow) ve Python (Zope, cherrypy, web.py, aiohttp, bottle, webob) gibi birkaç web sunucusu, eski RFC2965 desteği nedeniyle çerez dizelerini yanlış işler. Çift tırnak içinde bir çerez değeri, normalde anahtar-değer çiftlerini ayırması gereken noktalı virgüller içerse bile, tek bir değer olarak okunur:
RENDER_TEXT="hello world; JSESSIONID=13371337; ASDF=end";
Cookie Injection Vulnerabilities
(Check further details in theoriginal research) Sunucuların çerezleri yanlış analiz etmesi, özellikle Undertow, Zope ve Python'un http.cookie.SimpleCookie
ve http.cookie.BaseCookie
kullananlar, çerez enjeksiyon saldırıları için fırsatlar yaratır. Bu sunucular, yeni çerezlerin başlangıcını düzgün bir şekilde ayırt edemez, bu da saldırganların çerezleri taklit etmesine olanak tanır:
- Undertow, alıntılanmış bir değerden hemen sonra bir yeni çerez bekler, noktalı virgül olmadan.
- Zope, bir sonraki çerezi analiz etmeye başlamak için bir virgül arar.
- Python'un çerez sınıfları, bir boşluk karakterinde analiz yapmaya başlar.
Bu zafiyet, çerez tabanlı CSRF korumasına dayanan web uygulamalarında özellikle tehlikelidir, çünkü saldırganların taklit CSRF-token çerezlerini enjekte etmesine olanak tanır ve bu da güvenlik önlemlerinin aşılmasına yol açabilir. Sorun, Python'un tekrar eden çerez adlarını ele almasıyla daha da kötüleşir; burada son gerçekleşme, önceki olanları geçersiz kılar. Ayrıca, __Secure-
ve __Host-
çerezleri için güvensiz bağlamlarda endişeleri artırır ve çerezlerin taklit edilme eğiliminde olan arka uç sunuculara iletilmesi durumunda yetkilendirme aşımına yol açabilir.
Cookies $version
WAF Bypass
According to this blogpost, arka ucu çerezi analiz etmek için eski bir mantığı kullanmaya zorlamak amacıyla çerez niteliği $Version=1
kullanmak mümkün olabilir, bu da RFC2109'dan kaynaklanmaktadır. Ayrıca, $Domain
ve $Path
gibi diğer değerler, çerezi kullanarak arka ucun davranışını değiştirmek için kullanılabilir.
Cookie Sandwich Attack
According to this blogpost çerez sandviçi tekniğini kullanarak HttpOnly çerezlerini çalmak mümkündür. İşte gereksinimler ve adımlar:
- Görünüşte gereksiz bir çerezin yanıtta yansıtıldığı bir yer bulun
- Değeri
1
olan$Version
adında bir çerez oluşturun (bunu JS'den bir XSS saldırısı ile yapabilirsiniz) daha spesifik bir yol ile böylece başlangıç konumunu alır (bazı çerçeve dilleri bu adımı gerektirmez) - Yansıtılan çerezi oluşturun ve değeri açık çift tırnak bırakan ve belirli bir yol ile böylece önceki çerezin (
$Version
) ardından çerez veritabanında konumlanmasını sağlayın - Sonra, meşru çerez sırada bir sonraki olacaktır
- Değeri içinde çift tırnağı kapatan bir sahte çerez oluşturun
Bu şekilde, kurban çerezi yeni çerez versiyon 1 içinde sıkışır ve her yansıtıldığında yansıtılır.
document.cookie = `$Version=1;`;
document.cookie = `param1="start`;
// any cookies inside the sandwich will be placed into param1 value server-side
document.cookie = `param2=end";`;
WAF bypasses
Cookies $version
Önceki bölüme bakın.
Alıntı dizgesi kodlaması ile değer analizini atlama
Bu ayrıştırma, çerezler içindeki kaçış karakterlerini çözmek için kaçış değerlerini geri almayı gösterir, böylece "\a" "a" olur. Bu, WAF'ları atlamak için yararlı olabilir:
eval('test') => yasak
"\e\v\a\l\(\'\t\e\s\t\'\)" => izin verildi
Çerez adı kara liste atlaması
RFC2109'da virgülün çerez değerleri arasında ayırıcı olarak kullanılabileceği belirtilmiştir. Ayrıca eşittir işaretinden önce ve sonra boşluklar ve sekmeler eklemek mümkündür. Bu nedenle, $Version=1; foo=bar, abc = qux
gibi bir çerez, "foo":"bar, admin = qux"
çerezini oluşturmaz, bunun yerine foo":"bar"
ve "admin":"qux"
çerezlerini oluşturur. İki çerez nasıl oluşturulduğuna ve admin'in eşittir işaretinden önce ve sonra boşluğun nasıl kaldırıldığına dikkat edin.
Çerez bölme ile değer analizini atlama
Son olarak, farklı arka kapılar, farklı çerez başlıklarında geçen farklı çerezleri bir dize içinde birleştirebilir:
GET / HTTP/1.1
Host: example.com
Cookie: param1=value1;
Cookie: param2=value2;
Bu, bu örnekte olduğu gibi bir WAF'ı atlamayı mümkün kılabilir:
Cookie: name=eval('test//
Cookie: comment')
Resulting cookie: name=eval('test//, comment') => allowed
Ekstra Hassas Çerez Kontrolleri
Temel kontroller
- Çerez her seferinde giriş yaptığınızda aynıdır.
- Çıkış yapın ve aynı çerezi kullanmaya çalışın.
- Aynı çerezi kullanarak 2 cihazda (veya tarayıcıda) aynı hesaba giriş yapmayı deneyin.
- Çerezde herhangi bir bilgi olup olmadığını kontrol edin ve bunu değiştirmeye çalışın.
- Neredeyse aynı kullanıcı adıyla birkaç hesap oluşturmaya çalışın ve benzerlikleri görüp göremediğinizi kontrol edin.
- Varsa "beni hatırla" seçeneğini kontrol edin ve nasıl çalıştığını görün. Varsa ve hassas olabileceğini düşünüyorsanız, her zaman başka bir çerez olmadan beni hatırla çerezini kullanın.
- Önceki çerezin, şifreyi değiştirdikten sonra bile çalışıp çalışmadığını kontrol edin.
Gelişmiş çerez saldırıları
Çerez giriş yaptığınızda aynı (veya neredeyse aynı) kalıyorsa, bu muhtemelen çerezin hesabınızdaki bir alanla (muhtemelen kullanıcı adıyla) ilişkili olduğu anlamına gelir. O zaman şunları yapabilirsiniz:
- Çok benzer kullanıcı adlarına sahip birçok hesap oluşturmaya çalışın ve algoritmanın nasıl çalıştığını tahmin etmeye çalışın.
- Kullanıcı adını brute force etmeyi deneyin. Eğer çerez yalnızca kullanıcı adınız için bir kimlik doğrulama yöntemi olarak kaydediliyorsa, o zaman "Bmin" kullanıcı adıyla bir hesap oluşturabilir ve çerezin her bir bitini brute force edebilirsiniz çünkü deneyeceğiniz çerezlerden biri "admin"e ait olan olacaktır.
- Padding Oracle denemesi yapın (çerezin içeriğini şifreleyebilirsiniz). padbuster kullanın.
Padding Oracle - Padbuster örnekleri
padbuster <URL/path/when/successfully/login/with/cookie> <COOKIE> <PAD[8-16]>
# When cookies and regular Base64
padbuster http://web.com/index.php u7bvLewln6PJPSAbMb5pFfnCHSEd6olf 8 -cookies auth=u7bvLewln6PJPSAbMb5pFfnCHSEd6olf
# If Base64 urlsafe or hex-lowercase or hex-uppercase --encoding parameter is needed, for example:
padBuster http://web.com/home.jsp?UID=7B216A634951170FF851D6CC68FC9537858795A28ED4AAC6
7B216A634951170FF851D6CC68FC9537858795A28ED4AAC6 8 -encoding 2
Padbuster birkaç deneme yapacak ve size hangi durumun hata durumu olduğunu soracaktır (geçersiz olan).
Ardından çerezi şifrelemeye başlayacaktır (bu birkaç dakika sürebilir).
Eğer saldırı başarıyla gerçekleştirilmişse, o zaman seçtiğiniz bir dizeyi şifrelemeyi deneyebilirsiniz. Örneğin, encrypt user=administrator istiyorsanız.
padbuster http://web.com/index.php 1dMjA5hfXh0jenxJQ0iW6QXKkzAGIWsiDAKV3UwJPT2lBP+zAD0D0w== 8 -cookies thecookie=1dMjA5hfXh0jenxJQ0iW6QXKkzAGIWsiDAKV3UwJPT2lBP+zAD0D0w== -plaintext user=administrator
Bu yürütme, içinde user=administrator dizesi bulunan çerezi doğru bir şekilde şifrelenmiş ve kodlanmış olarak verecektir.
CBC-MAC
Belki bir çerez bazı değerlere sahip olabilir ve CBC kullanılarak imzalanabilir. O zaman, değerin bütünlüğü, aynı değerle CBC kullanılarak oluşturulan imzadır. IV olarak null vektör kullanılması önerildiğinden, bu tür bir bütünlük kontrolü savunmasız olabilir.
Saldırı
- Kullanıcı adı administ için imzayı al = t
- Kullanıcı adı rator\x00\x00\x00 XOR t için imzayı al = t'
- Çerezde değeri administrator+t' olarak ayarla (t' geçerli bir imza olacaktır (rator\x00\x00\x00 XOR t) XOR t = rator\x00\x00\x00
ECB
Eğer çerez ECB kullanılarak şifrelenmişse, savunmasız olabilir.
Giriş yaptığınızda aldığınız çerez her zaman aynı olmalıdır.
Nasıl tespit edilir ve saldırılır:
Neredeyse aynı verilere sahip 2 kullanıcı oluşturun (kullanıcı adı, şifre, e-posta vb.) ve verilen çerez içinde bir desen keşfetmeye çalışın.
Örneğin "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa" adında bir kullanıcı oluşturun ve çerezde herhangi bir desen olup olmadığını kontrol edin (çünkü ECB her bloğu aynı anahtar ile şifrelediğinden, kullanıcı adı şifrelendiğinde aynı şifrelenmiş baytlar görünebilir).
Kullanılan bir bloğun boyutunda bir desen olmalıdır. Yani, bir grup "a" nın nasıl şifrelendiğini bilerek bir kullanıcı adı oluşturabilirsiniz: "a"*(bloğun boyutu)+"admin". Ardından, çerezden bir "a" bloğunun şifrelenmiş desenini silebilirsiniz. Ve "admin" kullanıcı adının çerezine sahip olacaksınız.
Referanslar
- https://blog.ankursundara.com/cookie-bugs/
- https://www.linkedin.com/posts/rickey-martin-24533653_100daysofhacking-penetrationtester-ethicalhacking-activity-7016286424526180352-bwDd
- https://portswigger.net/research/bypassing-wafs-with-the-phantom-version-cookie
tip
AWS Hacking'i öğrenin ve pratik yapın:HackTricks Training AWS Red Team Expert (ARTE)
GCP Hacking'i öğrenin ve pratik yapın: HackTricks Training GCP Red Team Expert (GRTE)
HackTricks'i Destekleyin
- abonelik planlarını kontrol edin!
- Bize katılın 💬 Discord grubuna veya telegram grubuna veya bizi takip edin Twitter'da 🐦 @hacktricks_live.
- Hacking ipuçlarını paylaşın, HackTricks ve HackTricks Cloud github reposuna PR göndererek.