<?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</title>
	<atom:link href="http://www.zihni.net/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.zihni.net</link>
	<description></description>
	<lastBuildDate>Mon, 26 Oct 2009 14:40:14 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.4</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<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;;       
// Çıktı: bekar
?&#62;

Saldırganın aşağıdaki formu(form.php) kendi bilgisayarından gönderdiğini [...]]]></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>5</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;

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

1
2
3
&#60;?php 
echo $_POST&#91;'mesaj'&#93;;
?&#62;

Yukardaki kodun [...]]]></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>1</slash:comments>
		</item>
		<item>
		<title>Güvenli PHP Uygulamaları &#8211; Kullanıcı Girdilerinin Filtrelenmesi</title>
		<link>http://www.zihni.net/php/kullanici-girdilerini-filtrelenmesi/</link>
		<comments>http://www.zihni.net/php/kullanici-girdilerini-filtrelenmesi/#comments</comments>
		<pubDate>Mon, 02 Feb 2009 04:26:20 +0000</pubDate>
		<dc:creator>Zihni</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[htmlentities]]></category>
		<category><![CDATA[strip_tags]]></category>

		<guid isPermaLink="false">http://www.zihni.net/?p=316</guid>
		<description><![CDATA[Kullanıcı girdilerine güvenilmemeli, betiklerimizin güvenliği için
tüm girdiler filtrelenmelidir.
Örneğin kullanıcıdan yaş bilgisini isteyelim:
Kullanıcıdan beklenen girdi, sayı türünde bir değerdir.
Aşağıdaki kod bu doğrulamayı yapar.

$sonuc = preg_match&#40;&#34;/[0-9]{1,3}/&#34;,$_POST&#91;'yas'&#93;&#41;;
if&#40;$sonuc === true&#41;
echo &#34;Girdi doğrulandı&#34;;
else
echo &#34;Girdi sayı değil&#34;;

Kullanıcının hayat hikayesini istediğimizi varsayalım, yukardaki gibi bir basit bir doğrulama yapamayız, bunun yerine php nin bize sunduğu temel filtreleme işlevlerinden yararlanabiliriz.
Html tagları sorunlara yol [...]]]></description>
			<content:encoded><![CDATA[<p>Kullanıcı girdilerine güvenilmemeli, betiklerimizin güvenliği için<br />
tüm girdiler filtrelenmelidir.</p>
<p>Örneğin kullanıcıdan yaş bilgisini isteyelim:</p>
<p>Kullanıcıdan beklenen girdi, sayı türünde bir değerdir.<br />
Aşağıdaki kod bu doğrulamayı yapar.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$sonuc</span> <span style="color: #339933;">=</span> <span style="color: #990000;">preg_match</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;/[0-9]{1,3}/&quot;</span><span style="color: #339933;">,</span><span style="color: #000088;">$_POST</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'yas'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$sonuc</span> <span style="color: #339933;">===</span> <span style="color: #000000; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span>
<span style="color: #990000;">echo</span> <span style="color: #0000ff;">&quot;Girdi doğrulandı&quot;</span><span style="color: #339933;">;</span>
<span style="color: #b1b100;">else</span>
<span style="color: #990000;">echo</span> <span style="color: #0000ff;">&quot;Girdi sayı değil&quot;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Kullanıcının hayat hikayesini istediğimizi varsayalım, yukardaki gibi bir basit bir doğrulama yapamayız, bunun yerine php nin bize sunduğu temel filtreleme işlevlerinden yararlanabiliriz.<br />
Html tagları sorunlara yol açabilir.<br />
stript_tags() işlevi html etiketlerini yok eder.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$girdi</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;&lt;h1&gt;büyük bi başlık&lt;/h1&gt;&lt;span&gt;span etiketi&lt;/span&gt;&quot;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #990000;">strip_tags</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$girdi</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Yukardaki örneğin çıktısı:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;">büyük bi başlık span etiketi</pre></div></div>

<p>Bazı etiketlere izin vermek istiyorsak:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$girdi</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;&lt;h1&gt;büyük bi başlık&lt;/h1&gt;&lt;span&gt;span etiketi&lt;/span&gt;&quot;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #990000;">strip_tags</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$girdi</span><span style="color: #339933;">,</span><span style="color: #0000ff;">&quot;&lt;span&gt;&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;&lt;/</span>span<span style="color: #339933;">&gt;</span></pre></div></div>

<p>Yukardaki örneğin çıktısı:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;">büyük bi başlık <span style="color: #339933;">&lt;</span>span<span style="color: #339933;">&gt;</span>span etiketi<span style="color: #339933;">&lt;/</span>span<span style="color: #339933;">&gt;</span></pre></div></div>

<p>htmlentities() işlevi tüm html karakterlerini html entitilerine çevirir.</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$girdi</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;&lt;h1&gt;büyük bi başlık&lt;/h1&gt;&quot;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">echo</span> <span style="color: #990000;">htmlentities</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$girdi</span><span style="color: #339933;">,</span> ENT_QUOTES<span style="color: #339933;">,</span><span style="color: #0000ff;">'UTF-8'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>yukarıdaki örneğin çıktısı:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #339933;">&amp;</span>lt<span style="color: #339933;">;</span>h1<span style="color: #339933;">&amp;</span>gt<span style="color: #339933;">;</span>büyük bi başlık<span style="color: #339933;">&amp;</span>lt<span style="color: #339933;">;</span>h1<span style="color: #339933;">&amp;</span>gt<span style="color: #339933;">;</span></pre></div></div>

]]></content:encoded>
			<wfw:commentRss>http://www.zihni.net/php/kullanici-girdilerini-filtrelenmesi/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Javascript Hatası:&#8230;submit is not a function</title>
		<link>http://www.zihni.net/dom/javascript-hatasithisformsubmit-is-not-a-function/</link>
		<comments>http://www.zihni.net/dom/javascript-hatasithisformsubmit-is-not-a-function/#comments</comments>
		<pubDate>Wed, 28 Jan 2009 20:47:54 +0000</pubDate>
		<dc:creator>Zihni</dc:creator>
				<category><![CDATA[Document Object Model]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[çarpışma]]></category>
		<category><![CDATA[collision]]></category>

		<guid isPermaLink="false">http://www.zihni.net/?p=561</guid>
		<description><![CDATA[Javascripteki ayrılmış kelimeler(reserved words), button ismi ve fonksiyon olarak kullanıldığında çatışma(collision) meydana geliyor.
Hata Mesajı:

1
this.form.submit is not a function

&#8220;Submit&#8221; metodunu kullandığım yer:

1
&#60;select  onchange=&#34;this.form.submit();&#34;&#62;

Buton adı olarak &#8220;submit&#8221; kulladığım yer:

1
&#60;input type=&#34;submit&#34; name=&#34;submit&#34; value=&#34;Ekle&#34;&#62;

Buton adını &#8220;submit&#8221;ten başka bir adla, örneğin &#8220;ekle&#8221; olarak değiştirdiğimde sorun düzeliyor.

1
&#60;input type=&#34;submit&#34; name=&#34;ekle&#34;  value=&#34;Ekle&#34;&#62;

]]></description>
			<content:encoded><![CDATA[<p>Javascripteki ayrılmış kelimeler(reserved words), button ismi ve fonksiyon olarak kullanıldığında çatışma(collision) meydana geliyor.</p>
<p>Hata Mesajı:</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;">this<span style="color: #339933;">.</span>form<span style="color: #339933;">.</span>submit is not a <span style="color: #000000; font-weight: bold;">function</span></pre></td></tr></table></div>

<p>&#8220;Submit&#8221; metodunu kullandığım yer:</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;"><span style="color: #339933;">&lt;</span>select  onchange<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;this.form.submit();&quot;</span><span style="color: #339933;">&gt;</span></pre></td></tr></table></div>

<p>Buton adı olarak &#8220;submit&#8221; kulladığım yer:</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;"><span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;submit&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;submit&quot;</span> value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;Ekle&quot;</span><span style="color: #339933;">&gt;</span></pre></td></tr></table></div>

<p>Buton adını &#8220;submit&#8221;ten başka bir adla, örneğin &#8220;ekle&#8221; olarak değiştirdiğimde sorun düzeliyor.</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;"><span style="color: #339933;">&lt;</span>input type<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;submit&quot;</span> name<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;ekle&quot;</span>  value<span style="color: #339933;">=</span><span style="color: #0000ff;">&quot;Ekle&quot;</span><span style="color: #339933;">&gt;</span></pre></td></tr></table></div>

]]></content:encoded>
			<wfw:commentRss>http://www.zihni.net/dom/javascript-hatasithisformsubmit-is-not-a-function/feed/</wfw:commentRss>
		<slash:comments>0</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
11
12
&#60;html&#62;
&#60;head&#62;
&#60;meta http-equiv=&#34;Content-Type&#34; content=&#34;text/html; charset=UTF-8&#34; /&#62;
&#60;title&#62;mysql_real_escape_string&#60;/title&#62;
&#60;/head&#62;
&#60;body&#62;
&#60;form name=&#34;form1&#34; action=&#34;&#34; method=&#34;post&#34;&#62;
Kullanıcı adı:&#60;input type=&#34;text&#34; name=&#34;kullanici_adi&#34; value=&#34;&#34; /&#62; [...]]]></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>
