Frmacil

Frmacil

Acil Sorunlara Acil Çözüm



Geri git   Frmacil >
(¯`·.(¯`·.Mulltimedia-Grafik.·´¯).·´¯)
> Webmaster Köşesi > HTML-PHP-ASP-JAVA

Forum Kuralları İletiler Kayıt ol Yardım Üye Listesi Ajanda Arama Bugünkü Mesajlar Bütün Forumları okunmuş kabul et

PHP de Dosya Gönderim ( File Upload )
Görüntülemeler : 178 / Konudaki Cevap Sayısı : 0
Bu Konuyu E-Mail Olarak Arkadaşına Gönder
Şu an bu konuyu görüntüleyen kullanıcı sayısı: ( üye ve misafir)

Cevapla
 
Konu Araçları Stil
Alt 19-01-2008   #1
Profil Bilgileri
Devamlı Üye
 
Börtecine - ait Kullanıcı Resmi (Avatar)
 
Üyelik tarihi: Dec 2007
Yaş: 16
Mesaj: 2,584
Üye No: 4618
Tecrübe Puanı: 38
Rep Puanı : 6272
Rep Derecesi
Börtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond reputeBörtecine has a reputation beyond repute
Börtecine RSS Feed
Börtecine - MSN üzeri Mesaj gönder
Reklam
www.dantel-orgu.com
Standart PHP de Dosya Gönderim ( File Upload )

Bu dökümanda size PHP ile nasıl ; ’’ Dosya Gönderildiği / File Upload ’’ konusunda bazı bilgiler vermek istiyorum Aşağıda yazılı olanlar her zaman tekrarladığım ...

Bu dökümanda size PHP ile nasıl ; ’’ Dosya Gönderildiği / File Upload ’’ konusunda bazı bilgiler vermek istiyorum Aşağıda yazılı olanlar her zaman tekrarladığım gibi en basit ve sade dille anlatılmıştır Bunun nedeni bir kod parçacığının ne kadar ilerlerse okadar karmaşıklaşmasıdır Tabi basit derken abartılmış bir derecede basitlik olmıyacak
Dökümanın akışı sırasında sizlere sık sık önemli notlar vermeye çalışacam bu sayede ’’ Dosya Gönderme ’’ işleminin güvenlik açıklarınıda öğrenmiş olacaksınız Fazla geyiğe girmeden hemen dökümana başlıyorum

Aşağıdaki kodu bir dosyaya kaydedin

<form name=’’form1’’ enctype=’’multipart/form-data’’ action=’’<? echo $PHP_SELF;?>’’ method=’’post’’><input type=’’file’’ name=’’dosya’’><br><input type=’’submit’’ name=’’gonder’’ value=’’Gönder’’></form>
<?if(@$gonder == ’’Gönder’’) {copy ( $dosya, $dosya_name ) or die ( ’’Dosya Kopyalanamiyor’’ );echo $dosya_name;echo ’’<br>’’;echo $dosya_size ’’ Kb’’;echo ’’<br>’’;echo $dosya_type;echo ’’<br>’’;echo ’’<a href= "’$dosya_name’’>Tiklayiniz</a>’’;}?>


Yukarıdaki kodlara göz attığımız zaman html ve php kodlarını göreceksiniz Şimdi bu kodları anlatmaya başlamadan önce ilk denememizi yapalım Dosyayı kaydedip çalıştırdığınız zaman Karşınıza iki tane form elamanı çıkacak İkiside web sayfalarından görmeye alışık olduğunuz elamanlar

Bunlardan biri dosya göndermenizi sağlayan ’’ Form - File ’’ elamanı Diğeri ise ’’ Form - Button ’’

Şimdi Browse tuşuna basip bir dosya seçelim ( Resim Dosyası seçebilirsiniz ) sonrada gönder tuşuna basalım

Muhtemelen ( klasöre yazma izinleri vs gibi etkenler yoksa ) aşağıdaki gibi bir çıktı alacaksınız

dosyadixxx
15723 Kb
image/pjpeg
Tıklayınız

İlk satırda dosya adı, sonrakinde dosya boyutu, sonrakinde dosya tipi ve en sonda tıklayın adlı bir link Eğer gönderdiğiniz dosya bir resim yada benzeri bir dosya ise bu linke tıklayarak resmi görebileceksiniz

Not : Eğer sunucunuzun kendi üzerinde çalıştıramıyacağı bir dosya ise ; bu dosyayı download etmeniz için size gönderecektir

Buraya kadar yazılanlar bu işe yeni başlamış arkadaşlar için açıklayıcı nitelikteydi şimdi kodları teker teker açıklmaya başlıyalım

form name=’’form1’’ enctype=’’multipart/form-data’’ action=’’<? echo $PHP_SELF;?>’’ method=’’post’’> // bu satırı html den biraz anlıyan yada daha önce web sayfası yapmış olan pek çok kişi bilecektir <form name=’’form1’’ // bu bölüm ie form1 adında bir form oluşturduk enctype=’’multipart/form-data bu alan ile form tipini belirledir

action=’’<? echo $PHP_SELF;?>’’ // bu satırda formun gönder tuşuna bastığımız zaman form bilgilerinin hangi dosyaya gönderileceğini belirledik Anlıyacağınız gibi PHP nin kendinden gelen $PHP_SELF değişkeni ile form bilgilerini tekrar aynı dosyaya gönderdik Bunun nedenini birazdan göreceksiniz

method=’’post’’ // bu bölüm ilede formumuzun bilgileri göndereceği zamanki metodu belirledik

Not : Form methodu olarak ( Java vs hariç ) iki adet method vardır bunlardan biri ’’ post’’ diğeri ’’get’’ İkisi arasındaki temel fark ; post metodunda gönderilen form bilgileri URL kısmında görülmezken, get methodunda form bilgileri URL kısmında görünür Teknik olarak hemen herkesin post methodu kullanmak istemesi düşünülsede her ikisininde farklı özellikleri vardır ( Konumuz dışında olduğu için uzatmıyorum Gerekirse ileride bir döküman yazarız )

<input type=’’file’’ name=’’dosya’’> // ikinci satırda ise dosya göndermemizi sağlayan bir ’’ Form - File ’’ elamanı yaptık Burada name=’’dosya’’ ki alanda; ’’ name ’’ in bir değişken ve değerinin ’’dosya’’ olduğunu belirteyim

<input type=’’submit’’ name=’’gonder’’ value=’’Gönder’’> // bu satırda yine formdaki bilgileri istediğimiz dosyaya göndermemizi sağlayan ’’ Form - Submit ’’ elemanını kullandık name=’’gonder’’ value=’’Gönder’’ buradan anlıyacağınız gibi ’’ gonder ’’ adında ve değeri ’’ Gönder ’’ olan bir değişken tanımladık

</form> // bu satır ilede form alanımızı bitirdik ( html de formlar <form> </form> arasındaki bilgileri gönderir Bu alan dışındaki bilgiler işlenmez )

Şimdi gelelim php kodlarımıza

<?
if(@$gonder == ’’Gönder’’) { // bu satır ile önce <? ile php kodumuzu başlattık sonra php nin koşul fonksiyonlarından biri olan if() ( eğer ) fonksiyonu ile mantık olarak şöyle bir şey yazdık

Eğer $gonder değişkeninin değeri ’’Gönder’’ değerine eşitse aşağıdaki kodları uygula $gonder değişkeninin başında @ işaretide böyle bir değişken yoksa hata mesajı verme anlamındadır

Not : Dökümanın başında bahsettiğim dosya gönderme işleminin tek dosyada yapılması bu sayde oluşuyor Yani form gönderilmediği sürece dosyayı çalıştırdığınız zaman karşınıza sadece ; dosya seçme ve gönderme butonları çıkıyor Eğer dosya göndere basarsak <input type=’’submit’’ name=’’gonder’’ value=’’Gönder’’> bu satır vasıtasıyla $gonder değişkeninin değeri ’’ Gönder ’’ olduğundan php kodlarımız çalışmaya başlıyor

copy ( $dosya, $dosya_name ) or die ( ’’Dosya Kopyalanamıyor’’ ); // bu satır ile php deki copy() fonksiyonu kullanılarak $dosya değişkeni ( formdan gelen ) , $dosya değişkeninin _name dizesi adıyla kaydediliyor

echo $dosya_name; // bu satır ile $dosya değişkeninin adını ( name dizesini ) ekrana bastırıyoruz

echo $dosya_size ’’ Kb’’; // bu satır ile $dosya değişkeninin size ( boyut ) dizesini

echo $dosya_type; // bu satır ilede dosya tipini ekrana bastırıyoruz

echo ’’<a href= "’$dosya_name’’>Tıklayınız</a>’’; // bu satır ilede html de yazılara yada nesnelere link vermemizi sağlayan <a href> komutu ile gönderdiğimiz dosyanın adına bir link veriyoruz

}
?> // son olarak bu satırlarlada kodumuzu bitiriyoruz

Dikkat edilmesi gereken hususlar ve püf noktalar :

- Dosya gönderme islemlerinde dikkat edilmesi gereken en önemli seylerden biri; sitenize gelen bir saldirganin sitenize zarar vermek amaciyla sisteminize göndermek isteyecegi kötü kodlardir Mesala php kodlarinizdaki degiskenleri ( database sifre degiskenleri, kullanici sifre degiskenleri vs ) ögrenmek için belirli bir kod yazabilirler Bunun için gönderilen dosyalarda çesitli scriptlerle belirli dosya uzantilarini yasakliyabilirsiniz

- Sitenize gelen saldirgan çok büyük dosya boyutlari ile web alaninizi düsürmek için girisimdebulunabilir Bunun için form nesneleriniz arasina dosya boyutunu sinirlaran <INPUT TYPE=’’hidden’’ NAME=’’MAX_FILE_SIZE’’ VALUE=’’500000’’> su satiri ekleyebilirsiniz

- Sitenize gelen saldirgan dosya gönderirken; dosyanin gönderilecegi dizini degistirerek sizin belirttiginiz klasör disina ulasabilir

- Mantik olarak bu gün çogu kisi tarafindan bilinen pek çok fikirlerden yaralanarak sitenize zarar vermemesi için en ince ayrintilara kadar düsünmek sizlerin görevidir

 

Msn nickleri, güzel nickler, kaspersky key, eylem resimleri, dini film, filmler, aşk resimleri, Bedava Oyun indir, Program, Bedava indir, Aşk Resimleri, Aşk Şiirleri, Temalar, Video, Youtube, Güncel Haber, Resimleri, Eylem, Gaffur Resimleri, Şarkı Sözleri, Sohbet, Eğlence, Bedava, Msn, Download, Msn Programları, Manzara Resimleri, Fıkralar, Sinema, Video Klip, Sanatçı Resimleri, Müzik Notaları, Msn nickleri, Güzel nickler, Aşk resimleri, Değişik Avatarlar Bedava Oyun Program İndir - Ödev İndir - Resim Galerisi - Youtube Videolar - Komik Resimler İndir - Aşk Resimleri - Oyun indir -Temalar - Program indir - Msn Programları - Resim Galerisi - Diziler - Youtube Videolar - Resim Galerisi - Eylem Resimleri - Dini Konular - Sağlık Arşivi - Cep Telefonu - Spor Haberleri - Sanatçılar - Aşk&Sevgi - Burçlar - Chat - Film - Komik Videolar - Bilgisayar Programları - Online Oyunlar - Bedava indir - Şarkı Sözleri - Ödev Arşivi - Program Download - Hayvanlar Alemi - Bjk Resimleri  
Sponsored Links

Google'a ekle
Frmalev   Mumsema   Derya Gibi
Cevapla

Bookmarks

Konu Araçları
Stil


Benzer Konular
Konu Konuyu Başlatan Forum Cevap son Mesaj
FlySim 1.5.1 Re-Upload Reloladed Oyunlar E-F 2 4 Gün önce 16:02
Flash yükleme siteleri, flash upload, swf upload Gizliyara Network ve İnternet 2 4 Gün önce 11:06
Rapidsheare sitesine dosya upload etmek için... Uğur Baki Frmacil Kullanım Klavuzu 0 22-07-2008 23:29
Retroshare v.0.4.09b - İletişim ve güvenli dosya paylaşım programı P2P dosya paylaşım altyapısı i Börtecine Program Download 0 22-06-2008 15:55
XShare(Dosya upload etme) AGMEHMET GSM Karışık Programlar 0 19-12-2007 22:18


Pr 0-1-2 Domainler ve bomblananlar silinmiştir | Mumsema | Dantel | Modelleri | RSS-2 | Tags | Derya | Klub |


Saat 01:54.
Web Site Ekle Pagerank Toplist TOPlist TOPlist Add to Google
Powered by vBulletin® Version 3.7.4
Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.2.0 ©2008, Crawlability, Inc.
Yudumla