DevProTalk

Forumi IT profesionalaca
web development, web design, e-business, SEO


Idite nazad   DevProTalk > DevProTalk > Sva početnička pitanja
Želite da se reklamirate ekskluzivno na ovoj poziciji? Javite se

Sva početnička pitanja Sva početnička pitanja bi trebala da se postavljaju u ovom forumu, a ako se pretvori u kvalitetnu diskusiju interesantnu svima - prebacićemo je u odgovarajući forum. Molimo "znalce" da ne omalovažavaju početnike, ako žele da pomognu svi ćemo biti zahvalni, ako ne žele, neka preskoče ovaj forum.

Odgovori
 
Alati teme Način prikaza
Staro 02. 02. 2008.   #1
Ministar
član
Na probnom radu
 
Datum učlanjenja: 07.09.2006
Poruke: 30
Hvala: 0
0 "Hvala" u 0 poruka
Ministar is on a distinguished road
Question Upload php skripta

Pozz, evo ovdje jedna upload skripta, moze nekome kasnije i posluzit.

PHP kôd:

<?php 
$target     
'albums/ljudi/';  
$extension  'jpg';      
$max_size   100000;    
$width_max  1300;        
$height_max 800;       
$nom_file   $_FILES['fichier']['name']; 
$taille     $_FILES['fichier']['size']; 
$tmp        $_FILES['fichier']['tmp_name']; 
?> 

<?php 
if(!empty($_POST['posted'])) { 

    if(!empty(
$_FILES['fichier']['name'])) { 
    if(
substr($nom_file, -3) == $extension) { 
    
$infos_img getimagesize($_FILES['fichier']['tmp_name']); 
    if((
$infos_img[0] <= $width_max) && ($infos_img[1] <= $height_max) && ($_FILES['fichier']['size'] <= $max_size)) { 
    if(
move_uploaded_file($_FILES['fichier']['tmp_name'],$target.$_FILES['fichier']['name'])) { 
                    echo 
'<b>Informacije:</b>'
                    echo 
'<hr />'
                    echo 
'<b>Slika:</b> '$_FILES['fichier']['name'], '<br />'
                    echo 
'<b>Tezina :</b> '$_FILES['fichier']['size'], ' Octets<br />'
                    echo 
'<b>Duzina :</b> '$infos_img[0], ' px<br />'
                    echo 
'<b>Sirina :</b> '$infos_img[1], ' px<br />'
                    echo 
'<hr />'
                    echo 
'<br /><br />'
                } else { 
                    
// Sinon on affiche une erreur syst?e 
                    
echo '<b>Greska pri uploadu, pokusajte ponovo!</b><br /><br /><b>'$_FILES['fichier']['error'], '</b><br /><br />'
                } 
            } else { 
                
// Sinon on affiche une erreur pour les dimensions et taille de l'image 
                
echo '<b>Prevelika slika!</b><br /><br />'
            } 
        } else { 
            
// Sinon on affiche une erreur pour l'extension 
            
echo '<b>samo .jpg molim !</b><br /><br />'
        } 
    } else { 
        
// Sinon on affiche une erreur pour le champ vide 
        
echo '<b>Izaberi fotku!</b><br /><br />'
    } 

?>        <form enctype="multipart/form-data" action="<?php echo $PHP_SELF?>" method="POST"> 
            <b>Izaberite sliku sa vase lokacije:</b><br /><br /> 
            <input type="hidden" name="posted" value="1" /> 
            <input name="fichier" type="file" /> 
            <input type="submit" value="Upload" /> 
        </form>

E sad treba mi pomoc, ocu dole gdje je browse i Upload dugme kako mogu ubacit list box, da stavim recimo tri kategorije: ljudi, dogadjaji i gradovi. I da na osnovu tog list boxa meni mjenja gore u koji ce folder da uploaduje sliku, slab sam sa php pa molim pomoc.
Ministar je offline   Odgovorite uz citat
Staro 03. 02. 2008.   #2
staseprimate
NoProfessional
Certified
 
Datum učlanjenja: 29.09.2007
Lokacija: sta te bole
Poruke: 88
Hvala: 1
1 "Hvala" u 1 poruci
staseprimate is on a distinguished road
Default

pa stavis u web formu da korisnik izvrsi selekciju foldera/kategorije

<select name="kategorija">
<option value="ljudi">ljudi</option>
<option value="dogadjaji">dogadjaji</option>
<option value="gradovi">gradovi</option>
</select>

posle toga u php kodu ako sam dobro skontao samo stavis
$kategorija = $_POST['kategorija'];
$target = 'albums/$kategorija/';

pa ako je korisnik selektovao ljudi putanja ce biti albums/ljudi/, ako je odabrao gradove bice /albums/gradovi/

ako sam te uopste dobro razumeo
staseprimate je offline   Odgovorite uz citat
Staro 03. 02. 2008.   #3
Dušan Dželebdžić
Nekad bio ddz
Expert
 
Avatar Dušan Dželebdžić
 
Datum učlanjenja: 09.06.2005
Poruke: 590
Hvala: 88
402 "Hvala" u 51 poruka
Dušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoro
Pošaljite poruku preko MSN za Dušan Dželebdžić Pošaljite poruku preko Skype™ za Dušan Dželebdžić
Default

Obrati samo pažnju na to da ovim praviš ogroman bezbednosni propust, jer omogućavaš posetiocima da menjanjem jedne promenljive biraju u koji folder žele da postave fajl. Dodavanjem "../" mogu da se popnu jedan folder na gore, tako da mogu da ti upisuju fajlove gde god požele.

Bolja varijanta bi ti bila da opcije u formularu imaju numeričke vrednosti, a onda u funkciji u kojoj obrađuješ fajl staviš nešto tipa:
Kôd:
switch ($_POST['kategorija'])
{
     case 1:
     $folder="ljudi";
     break;

     case 2:
     $folder="mesta";
     break;
...

     default:
     $folder="svasta";    
}
$target="/albums/$folder/";

Poslednja izmena od Dušan Dželebdžić : 03. 02. 2008. u 09:32.
Dušan Dželebdžić je offline   Odgovorite uz citat
Staro 03. 02. 2008.   #4
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

^ ne moraju nuzno da budu numericke vrednosti (teze za debug i naknadne prepravke koda kroz 2 godine), ali svakako treba koristiti switch/case da se mapiraju u realne putanje na disku. Ovo nije samo zbog sigurnosti, mada je to najvaznije, nego i zbog flexibilnosti - ako zelis da pomeris fajlove negde drugde samo promenis jedan case, sve ostalo radi transparentno..
__________________
Leadership is the art of getting people to want to do what you know must be done.
ivanhoe je offline   Odgovorite uz citat
Staro 03. 02. 2008.   #5
Dušan Dželebdžić
Nekad bio ddz
Expert
 
Avatar Dušan Dželebdžić
 
Datum učlanjenja: 09.06.2005
Poruke: 590
Hvala: 88
402 "Hvala" u 51 poruka
Dušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoro
Pošaljite poruku preko MSN za Dušan Dželebdžić Pošaljite poruku preko Skype™ za Dušan Dželebdžić
Default

Off Topic:
^ my mistake, bio sam ubeđen da sam negde u postu napisao i "npr", kad sam predlagao brojeve
Dušan Dželebdžić je offline   Odgovorite uz citat
Staro 03. 02. 2008.   #6
Ministar
član
Na probnom radu
 
Datum učlanjenja: 07.09.2006
Poruke: 30
Hvala: 0
0 "Hvala" u 0 poruka
Ministar is on a distinguished road
Default

U mom slucaju skriptom je ogranicen upload samo na jpg ekstenziju, tako i ako neko promjeni putanju i uploaduje u drugi folder nemoze nanijet stetu.

A na kraju krajeva ne kontam bas ako je list box na stranici i u njemu su zapisane opcije kako ce neko to promjenit.

Hvala na odgovoru.
Ministar je offline   Odgovorite uz citat
Staro 03. 02. 2008.   #7
Ministar
član
Na probnom radu
 
Datum učlanjenja: 07.09.2006
Poruke: 30
Hvala: 0
0 "Hvala" u 0 poruka
Ministar is on a distinguished road
Default

Imam problem:

Javlja mi ovu gresku:

Warning: move_uploaded_file(albums/$kategorija/moj-ipod.jpg) [function.move-uploaded-file]: failed to open stream: No such file or directory

ne moze da ucita vrijednost polja u varijablu ?
Ministar je offline   Odgovorite uz citat
Staro 03. 02. 2008.   #8
JovanT
profesionalac
Qualified
 
Datum učlanjenja: 11.01.2006
Lokacija: Niš
Poruke: 100
Hvala: 66
11 "Hvala" u 9 poruka
JovanT is on a distinguished road
Default

Пошаљи део кода где се налази та линија. Делује ми као да Php ту променљиву третира као обичан текст. Вероватно си негде погрешио код наводника.
JovanT je offline   Odgovorite uz citat
Staro 05. 02. 2008.   #9
Ministar
član
Na probnom radu
 
Datum učlanjenja: 07.09.2006
Poruke: 30
Hvala: 0
0 "Hvala" u 0 poruka
Ministar is on a distinguished road
Default Evo ga

PHP kôd:

<?php  
$kategorija 
$_POST['kategorija'];
$target 'albums/$kategorija/';
$extension  'jpg';       
$max_size   100000;     
$width_max  1300;         
$height_max 800;        
$nom_file   $_FILES['fichier']['name'];  
$taille     $_FILES['fichier']['size'];  
$tmp        $_FILES['fichier']['tmp_name'];  
?>  

<?php  
if(!empty($_POST['posted'])) {  

    if(!empty(
$_FILES['fichier']['name'])) {  
    if(
substr($nom_file, -3) == $extension) {  
    
$infos_img getimagesize($_FILES['fichier']['tmp_name']);  
    if((
$infos_img[0] <= $width_max) && ($infos_img[1] <= $height_max) && ($_FILES['fichier']['size'] <= $max_size)) {  
    if(
move_uploaded_file($_FILES['fichier']['tmp_name'],$target.$_FILES['fichier']['name'])) {  
                    echo 
'<b>Informacije:</b>';  
                    echo 
'<hr />';  
                    echo 
'<b>Slika:</b> '$_FILES['fichier']['name'], '<br />';  
                    echo 
'<b>Tezina :</b> '$_FILES['fichier']['size'], ' Octets<br />';  
                    echo 
'<b>Duzina :</b> '$infos_img[0], ' px<br />';  
                    echo 
'<b>Sirina :</b> '$infos_img[1], ' px<br />';  
                    echo 
'<hr />';  
                    echo 
'<br /><br />';  
                } else {  
                    
// Sinon on affiche une erreur syst?e  
                    
echo '<b>Greska pri uploadu, pokusajte ponovo!</b><br /><br /><b>'$_FILES['fichier']['error'], '</b><br /><br />';  
                }  
            } else {  
                
// Sinon on affiche une erreur pour les dimensions et taille de l'image  
                
echo '<b>Prevelika slika!</b><br /><br />';  
            }  
        } else {  
            
// Sinon on affiche une erreur pour l'extension  
            
echo '<b>samo .jpg molim !</b><br /><br />';  
        }  
    } else {  
        
// Sinon on affiche une erreur pour le champ vide  
        
echo '<b>Izaberi fotku!</b><br /><br />';  
    }  
}  
?>        <form enctype="multipart/form-data" action="<?php echo $PHP_SELF?>" method="POST">  
            <b>Izaberite sliku sa vase lokacije:</b><br /><br />  

<select name="kategorija">
<option value="ljudi">ljudi</option>
<option value="dogadjaji">dogadjaji</option>
<option value="gradovi">gradovi</option>
</select>


            <input type="hidden" name="posted" value="1" />  
            <input name="fichier" type="file" />  
            <input type="submit" value="Upload" />  
        </form>
Ministar je offline   Odgovorite uz citat
Staro 06. 02. 2008.   #10
Dušan Dželebdžić
Nekad bio ddz
Expert
 
Avatar Dušan Dželebdžić
 
Datum učlanjenja: 09.06.2005
Poruke: 590
Hvala: 88
402 "Hvala" u 51 poruka
Dušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoroDušan Dželebdžić će postati "faca" uskoro
Pošaljite poruku preko MSN za Dušan Dželebdžić Pošaljite poruku preko Skype™ za Dušan Dželebdžić
Default

http://www.jeroenmulder.com/weblog/2...ble_quotes.php

echo $var; // Results in the value of $var being printed
echo '$var'; // Results in the word '$var'
echo "$var"; // Results in the value of $var being printed
Dušan Dželebdžić je offline   Odgovorite uz citat
Odgovori


Alati teme
Način prikaza

Pravila pisanja
Možete ne započinjati nove teme
Možete ne slati odgovore
Možete ne slati priloge
Možete ne izmeniti svoje poruke
vB kôd je Uključen
Smajliji su Uključen
[IMG] kod je Uključen
HTML kôd je Isključen
Pogledajte forum

Slične teme
Tema Početna poruka teme Forum Odgovori Poslednja poruka
TV Program Skripta djole1989 Web design, Layout, User Interface 4 30. 08. 2008. 23:42
newsletter skripta Mitrović Srđan PHP 5 17. 07. 2008. 23:45
PHP video skripta Filip_B Web aplikacije, web servisi i software 0 13. 04. 2008. 10:41
ROI tracking PHP skripta Mr.Paja PHP 1 24. 12. 2007. 03:11
Download skripta Bojan Zivanovic PHP 8 18. 01. 2006. 00:21


Vreme je GMT +2. Trenutno vreme je 18:44.


Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.
Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.