<?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; rand</title>
	<atom:link href="http://www.zihni.net/tag/rand/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>
	</channel>
</rss>

