<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Zihni Kaya &#187; güvenlik</title>
	<atom:link href="http://www.zihni.net/tag/guvenlik/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.zihni.net</link>
	<description></description>
	<lastBuildDate>Wed, 16 Nov 2011 07:22:20 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1.3</generator>
		<item>
		<title>Güvenli PHP Uygulamaları &#8211; Formların Güvenliği</title>
		<link>http://www.zihni.net/php/guvenli-php-uygulamalari-formlarin-guvenligi/</link>
		<comments>http://www.zihni.net/php/guvenli-php-uygulamalari-formlarin-guvenligi/#comments</comments>
		<pubDate>Wed, 18 Feb 2009 17:47:24 +0000</pubDate>
		<dc:creator>Zihni</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[güvenlik]]></category>
		<category><![CDATA[rand]]></category>

		<guid isPermaLink="false">http://www.zihni.net/?p=431</guid>
		<description><![CDATA[Betiklerimize istemediğimiz yerlerden form verilerinin gönderilmesiyle ortaya çıkar. Aşağıdaki gibi bir formumuz(form.php) olsun: &#60;form action=&#34;formIsle.php&#34; method=&#34;POST&#34;&#62; &#60;input type=&#34;radio&#34; name=&#34;medeniHali&#34; value=&#34;bekar&#34; checked=&#34;checked&#34;&#62; &#60;input type=&#34;radio&#34; name=&#34;medeniHali&#34; value=&#34;evli&#34;&#62; &#60;input type=&#34;radio&#34; name=&#34;medeniHali&#34; value=&#34;dul&#34;&#62; &#60;input type=&#34;submit&#34; value=&#34;Gönder&#34; /&#62; &#60;/form&#62; Bu formu işleyen sayfamız(formIsle.php) ise aşağıdaki gibi olsun, formdan gelen medeni hali bilgisini yazdırıyor. 1 2 3 4 &#60;?php echo $_POST&#91;'medeniHali'&#93;; [...]]]></description>
			<content:encoded><![CDATA[<p>Betiklerimize istemediğimiz yerlerden form verilerinin gönderilmesiyle ortaya çıkar.</p>
<p>Aşağıdaki gibi bir formumuz(form.php) olsun:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>form action<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;formIsle.php&quot;</span> method<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;POST&quot;</span><span style="color: #339933;">&gt;</span>
	<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;radio&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;medeniHali&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;bekar&quot;</span> checked<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;checked&quot;</span><span style="color: #339933;">&gt;</span>
	<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;radio&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;medeniHali&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;evli&quot;</span><span style="color: #339933;">&gt;</span>
	<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;radio&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;medeniHali&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;dul&quot;</span><span style="color: #339933;">&gt;</span>
	<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;submit&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;Gönder&quot;</span> <span style="color: #339933;">/&gt;</span>
<span style="color: #339933;">&lt;/</span>form<span style="color: #339933;">&gt;</span></pre></div></div>

<p>Bu formu işleyen sayfamız(formIsle.php) ise aşağıdaki gibi olsun, formdan gelen medeni hali bilgisini yazdırıyor.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #990000;">echo</span> <span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'medeniHali'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>       
<span style="color: #666666; font-style: italic;">// Çıktı: bekar</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Saldırganın aşağıdaki formu(form.php) kendi bilgisayarından gönderdiğini varsayalım. Formun action özelliğine tam adresi yazıyor.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>form action<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;http://www.siteadresi.com/formIsle.php&quot;</span> method<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;POST&quot;</span><span style="color: #339933;">&gt;</span>
	<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;text&quot;</span> <span style="color: #000066;">name</span><span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;medeniHali&quot;</span> value<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;yalancı&quot;</span><span style="color: #339933;">&gt;</span>
	<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;submit&quot;</span> value<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;Gönder&quot;</span> <span style="color: #339933;">/&gt;</span>
<span style="color: #339933;">&lt;/</span>form<span style="color: #339933;">&gt;</span></pre></td></tr></table></div>

<p>Form işleyen(formIsle.php) sayfamız yukarıda gönderilen formu işler.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #990000;">echo</span> <span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'medeniHali'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>
<span style="color: #666666; font-style: italic;">// Çıktı: yalancı</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Medeni hali, bekar-evli-dul değerlerinden birini alması gerekirken, &#8220;yalancı&#8221; diye bir değer almıştır. </p>
<p>Bunu önlemek için tek kullanımlık bir şifre oluşturulabilir:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span> 
<span style="color: #000088;">$formAnahtar</span> <span style="color: #339933;">=</span> <span style="color: #990000;">rand</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">10000</span><span style="color: #339933;">,</span><span style="color: #cc66cc;">1000000</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$_SESSION</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'formAnahtar'</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$formAnahtar</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span>
&lt;form action=&quot;http://www.siteadresi.com/formIsle.php&quot; method=&quot;POST&quot;&gt;
	&lt;input type=&quot;radio&quot; name=&quot;medeniHali&quot; value=&quot;bekar&quot; checked=&quot;checked&quot;&gt;
	&lt;input type=&quot;radio&quot; name=&quot;medeniHali&quot; value=&quot;evli&quot;&gt;
	&lt;input type=&quot;radio&quot; name=&quot;medeniHali&quot; value=&quot;dul&quot;&gt;
	&lt;input type=&quot;hidden&quot; name=&quot;formAnahtar&quot; value=&quot;<span style="color: #000000; font-weight: bold;">&lt;?php</span> <span style="color: #990000;">echo</span> <span style="color: #000088;">$formAnahtar</span><span style="color: #339933;">;</span> <span style="color: #000000; font-weight: bold;">?&gt;</span>&quot;&gt;
	&lt;input type=&quot;submit&quot; value=&quot;Gönder&quot; /&gt;
&lt;/form&gt;</pre></td></tr></table></div>

<p>Formu işleyen(formIsle.php) sayfamız:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
&nbsp;
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_SESSION</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'formAnahtar'</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">==</span> <span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'formAnahtar'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span>
	<span style="color: #990000;">echo</span> <span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'medeniHali'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>
<span style="color: #b1b100;">else</span> 
	<span style="color: #990000;">echo</span> <span style="color: #0000ff;">&quot;Bu form başka bir yerden geliyor.&quot;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

]]></content:encoded>
			<wfw:commentRss>http://www.zihni.net/php/guvenli-php-uygulamalari-formlarin-guvenligi/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>Güvenli PHP Uygulamaları &#8211; Cross site scripting(XSS)</title>
		<link>http://www.zihni.net/php/guvenli-php-uygulamalari-cross-site-scripting-xss/</link>
		<comments>http://www.zihni.net/php/guvenli-php-uygulamalari-cross-site-scripting-xss/#comments</comments>
		<pubDate>Fri, 13 Feb 2009 22:42:39 +0000</pubDate>
		<dc:creator>Zihni</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[güvenlik]]></category>
		<category><![CDATA[htmlentities]]></category>

		<guid isPermaLink="false">http://www.zihni.net/?p=417</guid>
		<description><![CDATA[Kullanıcının betiklerimize html kodu enjekte etmesiyle ortaya çıkar. Girdi filtrelenmeden çıktı olarak sunuluyorsa bu saldıya uğranabilir. Aşağıdaki gibi bir formumuz olsun: 1 2 3 4 &#60;form id=&#34;form1&#34; action=&#34;&#34; method=&#34;post&#34;&#62; &#60;textarea name=&#34;mesaj&#34;&#62;&#60;/textarea&#62; &#60;input type=&#34;submit&#34; value=&#34;gönder&#34; /&#62; &#60;/form&#62; Formdaki mesaj alanına aşağıdaki javascript kodunun enjekte edildiğini varsayalım. 1 2 3 &#60;?php &#60;script type=&#34;text/javascript&#34;&#62;window.location = 'http://www.zihni.net' &#60;/script&#62; ?&#62; [...]]]></description>
			<content:encoded><![CDATA[<p>Kullanıcının betiklerimize html kodu enjekte etmesiyle ortaya çıkar.<br />
Girdi filtrelenmeden çıktı olarak sunuluyorsa bu saldıya uğranabilir.</p>
<p>Aşağıdaki gibi bir formumuz olsun:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code"><pre class="javascript" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>form id<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;form1&quot;</span> action<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;&quot;</span> method<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;post&quot;</span><span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>textarea <span style="color: #000066;">name</span><span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;mesaj&quot;</span><span style="color: #339933;">&gt;&lt;/</span>textarea<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;submit&quot;</span> value<span style="color: #339933;">=</span><span style="color: #3366CC;">&quot;gönder&quot;</span> <span style="color: #339933;">/&gt;</span>
<span style="color: #339933;">&lt;/</span>form<span style="color: #339933;">&gt;</span></pre></td></tr></table></div>

<p>Formdaki mesaj alanına  aşağıdaki javascript kodunun enjekte edildiğini varsayalım.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span> 
<span style="color: #339933;">&lt;</span>script type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;text/javascript&quot;</span><span style="color: #339933;">&gt;</span>window<span style="color: #339933;">.</span>location <span style="color: #339933;">=</span> <span style="color: #0000ff;">'http://www.zihni.net'</span> <span style="color: #000000; font-weight: bold;">&lt;/script&gt;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Girdiyi filtrelemeden, aşağıdaki şekilde ekrana yazdırırsak, sayfaya giren her kullanıcıyı istediğimiz siteye yönlendiririz.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span> 
<span style="color: #990000;">echo</span> <span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'mesaj'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>Yukardaki kodun zararlı etkilerinden korunmak için girdiyi <i>htmlentities()</i> işleviyle filtrelememiz gerekir.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span> 
<span style="color: #990000;">echo</span> <span style="color: #990000;">htmlentities</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'mesaj'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

]]></content:encoded>
			<wfw:commentRss>http://www.zihni.net/php/guvenli-php-uygulamalari-cross-site-scripting-xss/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Güvenli PHP Uygulamaları-Sql enjektelerine karşı önlemler</title>
		<link>http://www.zihni.net/php/guvenli-php-uygulamalari-sql-enjeksiyon-saldirilarina-karsi-onlemler/</link>
		<comments>http://www.zihni.net/php/guvenli-php-uygulamalari-sql-enjeksiyon-saldirilarina-karsi-onlemler/#comments</comments>
		<pubDate>Sun, 25 Jan 2009 22:09:38 +0000</pubDate>
		<dc:creator>Zihni</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[güvenlik]]></category>
		<category><![CDATA[mysql_real_escape_string]]></category>
		<category><![CDATA[sql enjeksiyon]]></category>

		<guid isPermaLink="false">http://www.zihni.net/?p=282</guid>
		<description><![CDATA[Veritabanına gönderilen her bir değişken mysql_real_escape_string() işlevinden geçirilerek sql enjeksiyonlarına karşı önlem alınabilir. Bu işlev veritabanları için özel anlamı olan karakterleri escape-kurtarma işlemine tabii tutar, bu karakterlerden bazıları: \n, \r, \, &#8216;, &#8221; Aşağıdaki gibi kullanıcı adı ve şifre alanlarından oluşan bir giriş formumuz olsun: 1 2 3 4 5 6 7 8 9 10 [...]]]></description>
			<content:encoded><![CDATA[<p>Veritabanına gönderilen her bir değişken mysql_real_escape_string()<br />
işlevinden geçirilerek sql enjeksiyonlarına karşı önlem alınabilir.<br />
Bu işlev  veritabanları için özel anlamı olan karakterleri escape-kurtarma işlemine tabii tutar,<br />
bu karakterlerden bazıları:  \n, \r, \, &#8216;, &#8221;</p>
<p>Aşağıdaki gibi kullanıcı adı ve şifre alanlarından oluşan bir giriş formumuz olsun:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #339933;">&lt;</span>html<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>head<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>meta http<span style="color: #339933;">-</span>equiv<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;Content-Type&quot;</span> content<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;text/html; charset=UTF-8&quot;</span> <span style="color: #339933;">/&gt;</span>
<span style="color: #339933;">&lt;</span>title<span style="color: #339933;">&gt;</span>mysql_real_escape_string<span style="color: #339933;">&lt;/</span>title<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;/</span>head<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>body<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;</span>form name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;form1&quot;</span> action<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;&quot;</span> method<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;post&quot;</span><span style="color: #339933;">&gt;</span>
Kullanıcı adı<span style="color: #339933;">:&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;text&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;kullanici_adi&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;&quot;</span> <span style="color: #339933;">/&gt;</span> <span style="color: #339933;">&lt;</span>br <span style="color: #339933;">/&gt;</span>
Şifre<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;password&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;sifre&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;&quot;</span> <span style="color: #339933;">/&gt;</span> <span style="color: #339933;">&lt;</span>br <span style="color: #339933;">/&gt;</span>
<span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;submit&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;gönder&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;gonder&quot;</span> <span style="color: #339933;">/&gt;&lt;/</span>div<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;/</span>body<span style="color: #339933;">&gt;</span>
<span style="color: #339933;">&lt;/</span>html<span style="color: #339933;">&gt;</span></pre></td></tr></table></div>

<p>Kullanıcının formdan aşağıdaki bilgileri gönderdiğini varsayalım.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'kullanici_adi'</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">'zihni'</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'sifre'</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;' OR ''='&quot;</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<p>Kullanıci adi ve sifre verilerinin veritabanında olup olmadığını kontrol edelim</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #000088;">$sorgu</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;SELECT * FROM kullanicilar
WHERE kullanici_adi='<span style="color: #006699; font-weight: bold;">{$_POST['kullanici_adi']}</span>' AND sifre='<span style="color: #006699; font-weight: bold;">{$_POST['sifre']}</span>'&quot;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000088;">$sonuc</span> <span style="color: #339933;">=</span> <span style="color: #990000;">mysql_query</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sorgu</span><span style="color: #009900;">&#41;</span> or <span style="color: #990000;">die</span><span style="color: #009900;">&#40;</span><span style="color: #990000;">mysql_error</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$satir</span> <span style="color: #339933;">=</span> <span style="color: #990000;">mysql_fetch_array</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sonuc</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #000088;">$satir</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'kullanici_adi'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>mysql&#8217;e gönderilen sorgu aşağıdaki gibi olur:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="php" style="font-family:monospace;">SELECT <span style="color: #339933;">*</span> FROM kullanicilar WHERE kullanici_adi<span style="color: #339933;">=</span><span style="color: #0000ff;">'zihni'</span> AND sifre<span style="color: #339933;">=</span><span style="color: #0000ff;">''</span> OR <span style="color: #0000ff;">''</span><span style="color: #339933;">=</span><span style="color: #0000ff;">''</span></pre></td></tr></table></div>

<p>Görüldüğü gibi sifre geçersiz olsa bile sorgu sonucu başarılı olur.</p>
<p>Eğer formdan gelen bilgileri  mysql_real_escape_string() işlevinden geçirdikten sonra veritabanına gönderirsek:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
</pre></td><td class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">&lt;?php</span>
<span style="color: #000088;">$sorgu</span> <span style="color: #339933;">=</span> <span style="color: #990000;">sprintf</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;SELECT * FROM kullanicilar
WHERE kullanici_adi='<span style="color: #009933; font-weight: bold;">%s</span>' AND sifre='<span style="color: #009933; font-weight: bold;">%s</span>'&quot;</span><span style="color: #339933;">,</span>
<span style="color: #990000;">mysql_real_escape_string</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'kullanici_adi'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span>
<span style="color: #990000;">mysql_real_escape_string</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'sifre'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #000088;">$sonuc</span> <span style="color: #339933;">=</span> <span style="color: #990000;">mysql_query</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sorgu</span><span style="color: #009900;">&#41;</span> or <span style="color: #990000;">die</span><span style="color: #009900;">&#40;</span><span style="color: #990000;">mysql_error</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$satir</span> <span style="color: #339933;">=</span> <span style="color: #990000;">mysql_fetch_array</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sonuc</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #000088;">$satir</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'kullanici_adi'</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #000088;">$sorgu</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">?&gt;</span></pre></td></tr></table></div>

<p>mysql&#8217;e gönderilen sorgu aşağıdaki gibi olur ve bir sonuç döndürmez.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="php" style="font-family:monospace;">SELECT <span style="color: #339933;">*</span> FROM kullanicilar WHERE kullanici_adi<span style="color: #339933;">=</span><span style="color: #0000ff;">'zihni'</span> AND sifre<span style="color: #339933;">=</span><span style="color: #0000ff;">'\'</span> OR \<span style="color: #0000ff;">'\'</span><span style="color: #339933;">=</span>\<span style="color: #0000ff;">''</span></pre></td></tr></table></div>

]]></content:encoded>
			<wfw:commentRss>http://www.zihni.net/php/guvenli-php-uygulamalari-sql-enjeksiyon-saldirilarina-karsi-onlemler/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
	</channel>
</rss>

