AnonymPHP Uploader ile resim ve normal dosyalarınızı tekil ve çoğul olarak basit bir şekilde yapabilirsiniz.
- AnonymUploader
- Kurulum
- Yükleme İşlemleri
- YARDIMCI FONKSİYONLAR
- YÜKLEMEDEN SONRAKİ İŞLEMLER
- Resimlerle Gelişmiş İşlemler Yapmak
Sunucunuzun max post ve gd gibi kütüphanelerini ayarlamanız önerilir.
Dikkat: Yükleme işlemlerinin başarılı olmasını istiyorsanız dosyalarınızın izinlerini iyi ayarlamalısınız
Anonym Uploader composer autoload sistemi üzerine kuruludur, composer ile kullanılması önerilir.
"require": {
"anonym-php/anonym-upload": "dev-master"
}
composer install
Autoload olayının aktif edilmesi için composer kurulduktan sonra dosyanızda "vendor/autoload.php" include edilmelidir.
include "vendor/autoload.php";
Bu kısımda tekil ve çoğul olarak nasıl dosya yükleyebileceğiniz yer almaktadır.
use Anonym\Components\Upload\FileUpload;
$upload = new FileUpload($_FILES['upload'], 'hedef');
var_dump($upload->upload());
use Anonym\Components\Upload\ImageUpload;
$upload = new ImageUpload($_FILES['upload'], 'hedef');
var_dump($upload->upload());
Ftp e tekil dosya yüklerken normal yüklemelerden farklı olarak ilk parametreye ftp bilgilerini girmelisiniz
use Anonym\Components\Upload\Ftp\FtpUpload;
$upload = new FtpUpload([
'username' => 'ftpkullanıcıadı',
'password' => 'ftpşifresi',
'host' => 'ftpsucusu'
],$_FILES['upload'], 'hedef');
var_dump($upload->upload());
use Anonym\Components\Upload\Ftp\FtpImageUpload;
$upload = new FtpImageUpload([
'username' => 'ftpkullanıcıadı',
'password' => 'ftpşifresi',
'host' => 'ftpsucusu'
],$_FILES['upload'], 'hedef');
var_dump($upload->upload());
Çoğul dosya yükleme işleminde dönen veri bir dizi olarak döner ve bunları işlemek size kalır. Örnek olarak;
use Anonym\Components\Upload\Multiple\MultipleUpload;
$upload = new MultipleUpload($_FILES['upload'], 'hedef');
print_r($upload->upload()); // array
Çoğul dosya yükleme işleminde dönen veri bir dizi olarak döner ve bunları işlemek size kalır. Örnek olarak;
use Anonym\Components\Upload\Multiple\MultipleImageUpload;
$upload = new MultipleImageUpload($_FILES['upload'], 'hedef');
print_r($upload->upload()); // array
Ftp adresine çoğul dosya yüklemek için normal yüklemeden farklı olarak ilrk parametreye ftp bilgilerini girmelisini
use Anonym\Components\Upload\Multipile\FtpMultipileUpload;
$upload = new FtpMultipileUpload([
'username' => 'ftpkullanıcıadı',
'password' => 'ftpşifresi',
'host' => 'ftpsucusu'
],$_FILES['upload'], 'hedef');
print_r($upload->upload()); // array
Ftp adresine çoğul dosya yüklemek için normal yüklemeden farklı olarak ilrk parametreye ftp bilgilerini girmelisini
use Anonym\Components\Upload\Multipile\FtpMutlipileImage;
$upload = new FtpMutlipileImage([
'username' => 'ftpkullanıcıadı',
'password' => 'ftpşifresi',
'host' => 'ftpsucusu'
],$_FILES['upload'], 'hedef');
print_r($upload->upload()); // array
Burada size yükleme yarken yardımcı olacak fonksiyonları bulacaksınız
Bu özellik dosyada olmasını istediğiniz uzantıları kontrol eder, ilk parametre olması gerekenler, ikinci parametrede dosya isminde olmaması gereken uzantılardır, örnek olarak;
$upload->setAllowedExt(['png', 'jpg','gif'],'.php');
Dosyaların sahip olduğu mime tipi'ni denetleyebilirsiniz örnek olarak
$upload->setAllowedMimeTypes(['image/png', 'image/jpeg']);
Yükleyeceğiniz dosyaların sahip olabileceği maksimum boyutu kontrol edebilirsiniz.
Parametre olarak eğer byte cinsinden vermek istiyorsanız integer
bir değer, eğer mb,kb,gb,tb
gibi değerleri vermek istiyorsanız string
olarak dosya boyutunun arkasına tipi yazarak girebilirsiniz.
$upload->setMaxSize(1024); // 1024 byte => 1kb
$upload->setMaxSize('1MB'); // 1 mb
Dosyanın yüklenirken hangi isimle yükleneceğini değiştirebilirsiniz.
$upload->setNewName('yenidosyaismi');
Eğer dosya isminin rastgele belirlenmesini istiyor iseniz;
use Anonym\Components\Upload\NewNameGenerator;
$upload->setNewName(new NewNameGenerator());
Eğer FileUpload
veya ImageUpload
sınıflarıyla yükleme yaptıysanız size FileCapsule
ve ImageCapsule
gibi sınıflar döndürecektir, bu sınıflarla ne yapabilirsiniz onlara bakalım.
$name = $upload->getName();
// dosyanın adını döndürür
// örnek:test.png
$filePath = $upload->getFilePath();
// dosyanın tüm uzantısını dönrürür
// örnek :: upload/test.png
$size = $upload->getSize();
// dosyanın byte tipinindeki boyutunu döndürür
// örnek : 1001233
$ext = $upload->getExt();
// dosyanın uzantısını döndürür
// örnek : png
$target = $upload->getTarget();
// dosyanın kaydedildiği dosyanın yolunu verir
// örnek : upload
Aynı verilere şu şekildede erişebilirsiniz
$name = $upload['name'];
// dosyanın adını döndürür
// örnek:test.png
$filePath = $upload['filepath'];
// dosyanın tüm uzantısını dönrürür
// örnek :: upload/test.png
$size = $upload['size'];
// dosyanın byte tipinindeki boyutunu döndürür
// örnek : 1001233
$ext = $upload['ext'];
// dosyanın uzantısını döndürür
// örnek : png
$target = $upload['target'];
// dosyanın kaydedildiği dosyanın yolunu verir
// örnek : upload
bu kısımda dosyalarla kopyalama, yer değiştirme ve silme işlemleri vardır
Dosyayı Kopyalamak
Bu işlem ilk parametre olarak kopyalanacak yolu alır;
$upload->copy($target);
Dosyayı Taşımak
Bu işlem ilk parametre olarak taşınacak yolu alır;
$upload->move($target);
Dosyayı Silmek
Bu işlem dosyayı siler ve sınıfı sonlandırır;
$upload->delete();
Bu Kısımda ImageUpload
sınıfı ile yükleme yaptıktan sonra oluşan ImageCapsule
sınıfıyla yapabileceğiniz resmi sıkıştırma, yeniden boyutlandırma, resmi döndürme ve tip dönüşümleri yer alıcak.
yüklenen dosyanız .png formatında değilse dosyanızı .png formatına dönüştürebilirsiniz.
$upload->convertToPng();
yüklenen dosyanız .jpg formatında değilse dosyanızı .png formatına dönüştürebilirsiniz.
$upload->convertToJpg();
yüklenen dosyanız .gif formatında değilse dosyanızı .gif formatına dönüştürebilirsiniz.
$upload->convertToGif();
Dosyayı yükledikden sonra boyutunu küçültmek için sıkıştırabilirsiniz
$upload->compress(90);
paremetre olarak resmin düşürüleceği kaliteyi alır, % lik olarak.
Resmi sağa, sola yukarı,aşağı istediğiniz açıda döndürebilirsiniz.Parametre olarak döndürülecek açıyı alır.
$upload->rotate(90);
Resmi yeniden boyutlandırmak için kullanılabilir, ilk parametre olarak genişlik değerini ikinci parametre olarakda yükseklik değerini alır.
$upload->reSize(400, 500);